diff options
Diffstat (limited to 'ds9/library/mosaicimageiraf.tcl')
-rw-r--r-- | ds9/library/mosaicimageiraf.tcl | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/ds9/library/mosaicimageiraf.tcl b/ds9/library/mosaicimageiraf.tcl new file mode 100644 index 0000000..436a7f4 --- /dev/null +++ b/ds9/library/mosaicimageiraf.tcl @@ -0,0 +1,87 @@ +# Copyright (C) 1999-2016 +# Smithsonian Astrophysical Observatory, Cambridge, MA, USA +# For conditions of distribution and use, see copyright notice in "copyright" + +package provide DS9 1.0 + +proc LoadMosaicImageIRAFFile {fn layer} { + global loadParam + + set loadParam(file,type) fits + set loadParam(file,mode) {mosaic image iraf} + set loadParam(load,type) mmapincr + set loadParam(file,name) $fn + set loadParam(load,layer) $layer + + ConvertFitsFile + ProcessLoad +} + +proc LoadMosaicImageIRAFAlloc {path fn layer} { + global loadParam + + set loadParam(file,type) fits + set loadParam(file,mode) {mosaic image iraf} + set loadParam(load,type) allocgz + set loadParam(file,name) $fn + set loadParam(file,fn) $path + set loadParam(load,layer) $layer + + ProcessLoad +} + +proc LoadMosaicImageIRAFSocket {sock fn layer} { + global loadParam + + set loadParam(file,type) fits + set loadParam(file,mode) {mosaic image iraf} + set loadParam(load,type) socketgz + set loadParam(file,name) $fn + set loadParam(socket,id) $sock + set loadParam(load,layer) $layer + + return [ProcessLoad 0] +} + +proc ProcessMosaicImageIRAFCmd {varname iname sock fn} { + upvar $varname var + upvar $iname i + + global loadParam + global current + + set layer {} + + switch -- [string tolower [lindex $var $i]] { + new { + incr i + CreateFrame + } + mask { + incr i + set layer mask + } + slice { + incr i + # not supported + } + } + set param [lindex $var $i] + + StartLoad + if {$sock != {}} { + # xpa + if {![LoadMosaicImageIRAFSocket $sock $param $layer]} { + InitError xpa + LoadMosaicImageIRAFFile $param $layer + } + } else { + # comm + if {$fn != {}} { + LoadMosaicImageIRAFAlloc $fn $param $layer + } else { + LoadMosaicImageIRAFFile $param $layer + } + } + FinishLoad +} |