diff options
Diffstat (limited to 'ds9/library/mecube.tcl')
-rw-r--r-- | ds9/library/mecube.tcl | 133 |
1 files changed, 133 insertions, 0 deletions
diff --git a/ds9/library/mecube.tcl b/ds9/library/mecube.tcl new file mode 100644 index 0000000..824497a --- /dev/null +++ b/ds9/library/mecube.tcl @@ -0,0 +1,133 @@ +# 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 LoadMECubeFile {fn} { + global loadParam + + set loadParam(file,type) fits + set loadParam(file,mode) {ext cube} + set loadParam(load,type) mmapincr + set loadParam(file,name) $fn + + # mask not supported + set loadParam(load,layer) {} + + ConvertFitsFile + ProcessLoad +} + +proc LoadMECubeAlloc {path fn} { + global loadParam + + set loadParam(file,type) fits + set loadParam(file,mode) {ext cube} + set loadParam(load,type) allocgz + set loadParam(file,name) $fn + set loadParam(file,fn) $path + + # mask not supported + set loadParam(load,layer) {} + + ProcessLoad +} + +proc LoadMECubeSocket {sock fn} { + global loadParam + + set loadParam(file,type) fits + set loadParam(file,mode) {ext cube} + set loadParam(load,type) socketgz + set loadParam(file,name) $fn + set loadParam(socket,id) $sock + + # mask not supported + set loadParam(load,layer) {} + + return [ProcessLoad 0] +} + +proc SaveMECubeFile {fn} { + global current + + if {$fn == {} || $current(frame) == {}} { + return + } + + if {![$current(frame) has fits]} { + return + } + + $current(frame) save fits ext cube file "\{$fn\}" +} + +proc SaveMECubeSocket {sock} { + global current + + if {$current(frame) == {}} { + return + } + + if {![$current(frame) has fits]} { + return + } + + $current(frame) save fits ext cube socket $sock +} + +proc ProcessMECubeCmd {varname iname sock fn} { + upvar $varname var + upvar $iname i + + switch -- [string tolower [lindex $var $i]] { + new { + incr i + CreateFrame + } + mask { + incr i + # not supported + } + slice { + incr i + # not supported + } + } + set param [lindex $var $i] + + StartLoad + if {$sock != {}} { + # xpa + if {![LoadMECubeSocket $sock $param]} { + InitError xpa + LoadMECubeFile $param + } + } else { + # comm + if {$fn != {}} { + LoadMECubeAlloc $fn $param + } else { + LoadMECubeFile $param + } + } + FinishLoad +} + +proc ProcessSendMECubeCmd {proc id param sock fn} { + global current + + if {$current(frame) == {}} { + return + } + + if {$sock != {}} { + # xpa + SaveMECubeSocket $sock + } elseif {$fn != {}} { + # comm + SaveMECubeFile $fn + $proc $id {} $fn + } +} |