File: analysisparam.tcl

package info (click to toggle)
saods9 8.6%2Brepack-6
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 23,272 kB
  • sloc: tcl: 78,253; cpp: 71,015; ansic: 3,955; xml: 1,555; sh: 968; makefile: 183; perl: 68
file content (337 lines) | stat: -rw-r--r-- 9,049 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
#  Copyright (C) 1999-2021
#  Smithsonian Astrophysical Observatory, Cambridge, MA, USA
#  For conditions of distribution and use, see copyright notice in "copyright"

package provide DS9 1.0

proc AnalysisParam {strname param} {
    upvar $strname str
    global ianalysis
    global ed

    # find it
    for {set ii 0} {$ii<$ianalysis(param,count)} {incr ii} {
	if {$ianalysis(param,$ii) == "$param"} {
	    break
	}
    }
    if {$ii == $ianalysis(param,count)} {
	return
    }

    set w {.param}
    set mb {.parammb}

    set ed(top) $w
    set ed(ok) 0

    DialogCreate $w $param ed(ok)

    $w configure -menu $mb
    ThemeMenu $mb

    # file
    $mb add cascade -label [msgcat::mc {File}] -menu $mb.file
    ThemeMenu $mb.file
    $mb.file add command -label [msgcat::mc {Apply}] -command {set ed(ok) 1}
    $mb.file add command -label [msgcat::mc {Reset}] \
	-command [list AnalysisParamReset $ii]
    $mb.file add separator
    $mb.file add command -label [msgcat::mc {Cancel}] -command {set ed(ok) 0}

    # edit
    $mb add cascade -label [msgcat::mc {Edit}] -menu $mb.edit
    EditMenu $mb ed

    # Param
    set f [ttk::frame $w.param]

    if {$ianalysis(param,$ii,count) == 1 && $ianalysis(param,$ii,0) == {def}} {
	# simple case
	set jj 0
	for {set kk 0} {$kk<$ianalysis(param,$ii,$jj,count)} {incr kk} {
	    AnalysisParamItem $f $ii $jj $kk
	}
    } else {
	# tree view

	ttk::scrollbar $f.scroll -command [list $f.box yview]
	set ianalysis(listbox) [ttk::treeview $f.box \
				    -yscroll [list $f.scroll set] \
				    -selectmode browse \
				    -show tree \
				   ]

	grid $f.box $f.scroll -sticky news
	grid rowconfigure $f 0 -weight 1
	grid columnconfigure $f 2 -weight 1

	bind $ianalysis(listbox) <<TreeviewSelect>> AnalysisParamListUpdate

	set ianalysis(tabs) {}

	for {set jj 0} {$jj<$ianalysis(param,$ii,count)} {incr jj} {
	    set gg [ttk::frame $f.t$ii-$jj]
	    $ianalysis(listbox) insert {} end -id $gg \
		-text "$ianalysis(param,$ii,$jj)"

	    for {set kk 0} {$kk<$ianalysis(param,$ii,$jj,count)} {incr kk} {
		AnalysisParamItem $gg $ii $jj $kk
	    }
	}

	# select first item
	$ianalysis(listbox) selection set $f.t$ii-0
    }

    # Buttons
    set f [ttk::frame $w.buttons]
    ttk::button $f.ok -text [msgcat::mc {OK}] -command {set ed(ok) 1} \
	-default active
    ttk::button $f.reset -text [msgcat::mc {Reset}] \
	-command [list AnalysisParamReset $ii]
    ttk::button $f.cancel -text [msgcat::mc {Cancel}] -command {set ed(ok) 0}
    pack $f.ok $f.reset $f.cancel -side left -expand true -padx 2 -pady 4

    bind $w <Return> {set ed(ok) 1}

    # Fini
    ttk::separator $w.sep -orient horizontal
    pack $w.buttons $w.sep -side bottom -fill x
    pack $w.param -side top -fill both -expand true

    DialogWait $w ed(ok) $w.buttons.ok
    destroy $w
    destroy $mb

    if {$ed(ok)} {
	for {set jj 0} {$jj<$ianalysis(param,$ii,count)} {incr jj} {
	    for {set kk 0} {$kk<$ianalysis(param,$ii,$jj,count)} {incr kk} {
		set exp "\\\$$ianalysis(param,$ii,$jj,$kk,var)"
		if {[regexp $exp $str]} {
		    regsub -all $exp $str \
			"$ianalysis(param,$ii,$jj,$kk,value)" str
		}
		set ianalysis(param,$ii,$jj,$kk,last) \
		    $ianalysis(param,$ii,$jj,$kk,value)
	    }
	}
    }

    set rr $ed(ok)
    unset ed
    return $rr
}

proc AnalysisParamReset {ii} {
    global ianalysis
    global current

    for {set jj 0} {$jj<$ianalysis(param,$ii,count)} {incr jj} {
	for {set kk 0} {$kk<$ianalysis(param,$ii,$jj,count)} {incr kk} {
	    switch $ianalysis(param,$ii,$jj,$kk,type) {
		entry -
		text -
		open -
		save {
		    set cmd $ianalysis(param,$ii,$jj,$kk,default)
		    AnalysisParamMacro cmd $current(frame)
		    set ianalysis(param,$ii,$jj,$kk,last) $cmd
		    set ianalysis(param,$ii,$jj,$kk,value) \
			$ianalysis(param,$ii,$jj,$kk,last)
		}
		checkbox {
		    set ianalysis(param,$ii,$jj,$kk,last) \
			$ianalysis(param,$ii,$jj,$kk,default)
		    set ianalysis(param,$ii,$jj,$kk,value) \
			$ianalysis(param,$ii,$jj,$kk,last)
		}
		menu {
		    # default can contain the full menu 'aaa|bbb|ccc'
		    # set last to first item
		    set pp [split $ianalysis(param,$ii,$jj,$kk,default) |]
		    set ianalysis(param,$ii,$jj,$kk,last) [lindex $pp 0]
		    set ianalysis(param,$ii,$jj,$kk,value) \
			$ianalysis(param,$ii,$jj,$kk,last)

		    $ianalysis(param,$ii,$jj,$kk,menubutton) configure \
			-text $ianalysis(param,$ii,$jj,$kk,value)
		}
		combobox {
		    # default can contain the full menu 'aaa|bbb|ccc'
		    # set last to first item
		    set pp [split $ianalysis(param,$ii,$jj,$kk,default) |]
		    set ianalysis(param,$ii,$jj,$kk,last) [lindex $pp 0]
		    set ianalysis(param,$ii,$jj,$kk,value) \
			$ianalysis(param,$ii,$jj,$kk,last)
		}
	    }
	}
    }
}

proc AnalysisParamItem {f ii jj kk} {
    global ds9
    global pds9
    global ianalysis
    global current

    ttk::label $f.l$ii-$jj-$kk -text "$ianalysis(param,$ii,$jj,$kk,title)"

    switch -- $ianalysis(param,$ii,$jj,$kk,type) {
	entry {
	    set cmd $ianalysis(param,$ii,$jj,$kk,last)
	    AnalysisParamMacro cmd $current(frame)
	    set ianalysis(param,$ii,$jj,$kk,value) $cmd

	    ttk::entry $f.a$ii-$jj-$kk \
		-textvariable ianalysis(param,$ii,$jj,$kk,value) \
		-width 40
	}
	text {
	    set cmd $ianalysis(param,$ii,$jj,$kk,last)
	    AnalysisParamMacro cmd $current(frame)
	    set ianalysis(param,$ii,$jj,$kk,value) $cmd

	    ttk::label $f.a$ii-$jj-$kk \
		-textvariable ianalysis(param,$ii,$jj,$kk,value) \
		-width 40
	}
	open {
	    set cmd $ianalysis(param,$ii,$jj,$kk,last)
	    AnalysisParamMacro cmd $current(frame)
	    set ianalysis(param,$ii,$jj,$kk,value) $cmd

	    ttk::frame $f.a$ii-$jj-$kk
	    ttk::entry $f.a$ii-$jj-$kk.e \
		-textvariable ianalysis(param,$ii,$jj,$kk,value) \
		-width 30
	    ttk::button $f.a$ii-$jj-$kk.b -text [msgcat::mc {Browse}] \
		-command \
		[list AnalysisParamFileOpen param,$ii,$jj,$kk,value]
	    grid $f.a$ii-$jj-$kk.e $f.a$ii-$jj-$kk.b \
		-padx 2 -pady 2 -sticky w
	}
	save {
	    set cmd $ianalysis(param,$ii,$jj,$kk,last)
	    AnalysisParamMacro cmd $current(frame)
	    set ianalysis(param,$ii,$jj,$kk,value) $cmd

	    ttk::frame $f.a$ii-$jj-$kk
	    ttk::entry $f.a$ii-$jj-$kk.e \
		-textvariable ianalysis(param,$ii,$jj,$kk,value) \
		-width 30
	    ttk::button $f.a$ii-$jj-$kk.b -text [msgcat::mc {Browse}] \
		-command \
		[list AnalysisParamFileSave param,$ii,$jj,$kk,value]
	    grid $f.a$ii-$jj-$kk.e $f.a$ii-$jj-$kk.b \
		-padx 2 -pady 2 -sticky w
	}
	checkbox {
	    set ianalysis(param,$ii,$jj,$kk,value) \
		$ianalysis(param,$ii,$jj,$kk,last)

	    ttk::checkbutton $f.a$ii-$jj-$kk -text {} \
		-variable ianalysis(param,$ii,$jj,$kk,value)
	}
	menu {
	    set ianalysis(param,$ii,$jj,$kk,value) \
		$ianalysis(param,$ii,$jj,$kk,last)

	    ttk::menubutton $f.a$ii-$jj-$kk \
		-text "$ianalysis(param,$ii,$jj,$kk,value)" \
		-menu $f.a$ii-$jj-$kk.menu

	    set ianalysis(param,$ii,$jj,$kk,menubutton) $f.a$ii-$jj-$kk
	    set mm [ThemeMenu $f.a$ii-$jj-$kk.menu]
	    set pp [split $ianalysis(param,$ii,$jj,$kk,default) |]
	    for {set nn 0} {$nn<[llength $pp]} {incr nn} {
		$mm add command -label [lindex $pp $nn] \
		    -command [list AnalysisParamMenu [lindex $pp $nn] $ii $jj $kk]
	    }
	}
	combobox {
	    set ianalysis(param,$ii,$jj,$kk,value) \
		$ianalysis(param,$ii,$jj,$kk,last)

	    ttk::combobox $f.a$ii-$jj-$kk \
		-textvariable ianalysis(param,$ii,$jj,$kk,value) \
		-values [split $ianalysis(param,$ii,$jj,$kk,default) |]
	}

    }

    ttk::label $f.i$ii-$jj-$kk -text "$ianalysis(param,$ii,$jj,$kk,info)" \
	-font "{$ds9(times)} $pds9(font,size) normal italic"

    grid $f.l$ii-$jj-$kk $f.a$ii-$jj-$kk $f.i$ii-$jj-$kk \
	-padx 2 -pady 2 -sticky w
}

proc AnalysisParamListUpdate {} {
    global ianalysis

    if {$ianalysis(tabs) != {}} {
	grid forget $ianalysis(tabs)
    }
    set ianalysis(tabs) [$ianalysis(listbox) selection]
    if {$ianalysis(tabs) != {}} {
	grid $ianalysis(tabs) -row 0 -column 2 -sticky new
    }
}

proc AnalysisParamFileOpen {which} {
    global ianalysis

    FileLast analysisparamfbox $ianalysis($which)
    set ianalysis($which) [OpenFileDialog analysisparamfbox]
}

proc AnalysisParamFileSave {which} {
    global ianalysis

    FileLast analysisparamfbox $ianalysis($which)
    set ianalysis($which) [SaveFileDialog analysisparamfbox]
}

proc AnalysisParamMenu {value ii jj kk} {
    global ianalysis

    set ianalysis(param,$ii,$jj,$kk,value) $value
    $ianalysis(param,$ii,$jj,$kk,menubutton) configure -text $value
}

proc AnalysisParamMacro {varname {frame {}}} {
    upvar $varname var

    if {$frame == {}} {
	return
    }
    
    # escaped macros
    SetEscapedMacros var

    # $xdim,$ydim,$bitpix
    ParseXYBitpixMacro var $frame

    # $filename[$regions]
    ParseFilenameRegionMacro var $frame

    # $filename
    ParseFilenameMacro var $frame

    # $regions
    ParseRegionMacro var $frame

    # $env
    ParseEnvMacro var

    # $cen
    ParsePanMacro var $frame

    # $z
    ParseZMacro var $frame

    # escaped macros
    UnsetEscapedMacros var
}