source: trunk/SRC/ToBeReviewed/WIDGET/AUTOUR_de_XXX/selectfile.pro @ 114

Last change on this file since 114 was 114, checked in by smasson, 18 years ago

new compilation options (compile_opt idl2, strictarrsubs) in each routine

  • Property svn:eol-style set to native
  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
File size: 10.7 KB
Line 
1;*********************************************************************
2PRO selectfile_event, event
3;
4;
5  compile_opt idl2, strictarrsubs
6;
7@common
8;
9  widget_control, event.id, get_uvalue = eventuvalue
10; default definition of messenger when selectfile_event is called
11; directly without calling xmanager
12  widget_control, event.handler, get_uvalue = messenger
13  *messenger = -1
14
15  IF chkstru(eventuvalue, 'name') EQ 0 THEN return
16
17  case eventuvalue.name of
18; cancel button
19    'Global Cancel':BEGIN
20      widget_control, event.handler, get_uvalue = messenger
21      *messenger = -1
22      widget_control, event.handler, /destroy
23    END
24; data file informations
25    'datafilename':BEGIN
26      widget_control, event.id, get_value = filename
27      filename = isafile(filename = filename[0], iodir = iodir, /onlync, title = 'data file name')
28      if size(filename, /type) NE 7 then BEGIN
29        widget_control, event.id, set_value = ''
30        return
31      ENDIF
32      widget_control, event.id, set_value = filename
33    END
34    'browse datafilename':BEGIN
35      filename = isafile(iodir = iodir, /onlync, title = 'data file name')
36      if size(filename, /type) NE 7 then return
37      widget_control, widget_info(event.handler, find_by_uname = 'datafilename') $
38                      , set_value = filename
39    END
40; switch automatic/by and mesh definition buttons
41    'gridload':BEGIN
42      IF event.select EQ 1 THEN BEGIN
43        widget_control, widget_info(event.handler, find_by_uname = 'argtxt'), set_value = ''
44        widget_control, widget_info(event.handler, find_by_uname = 'kwdtxt'), set_value = ''
45        widget_control, widget_info(event.handler, find_by_uname = 'kwd base'), sensitive = 1
46        CASE event.value OF
47          'via initnetcdf':BEGIN
48            widget_control, widget_info(event.handler, find_by_uname = 'meshload'), set_value = 'initncdf', editable = 0
49            widget_control, widget_info(event.handler, find_by_uname = 'arg base'), sensitive = 0
50            widget_control, widget_info(event.handler, find_by_uname = 'kwdlab'), set_value = 'initncdf keywords:'
51          END
52          'via perso':BEGIN
53            widget_control, widget_info(event.handler, find_by_uname = 'meshload'), set_value = '', editable = 1
54            widget_control, widget_info(event.handler, find_by_uname = 'arg base'), sensitive = 1
55            widget_control, widget_info(event.handler, find_by_uname = 'kwdlab'), set_value = 'keywords of IDL procedure:'
56          END
57        ENDCASE
58      ENDIF
59    END
60; name of the procedure or batch file
61    'meshload':BEGIN
62      widget_control, event.id, get_value = filename
63      filename = (find(filename[0], /onlypro, /firstfound))[0]
64      if filename EQ 'NOT FOUND' then begin
65        widget_control, event.id, set_value = ''
66        return
67      endif
68      CASE protype(filename) OF
69; this is a procedure
70        'proc':BEGIN
71          widget_control, widget_info(event.handler, find_by_uname = 'arg base'), sensitive = 1
72          widget_control, widget_info(event.handler, find_by_uname = 'kwd base'), sensitive = 1
73          widget_control, widget_info(event.handler, find_by_uname = 'kwdlab'), set_value = file_basename(filename, '.pro')+' keywords:'
74        END
75; this is a function, this case is not accepted
76        'func':BEGIN
77          widget_control, event.id, set_value = ''
78          return
79        END
80; this is an IDL batch file
81        'batch':BEGIN
82          widget_control, widget_info(event.handler, find_by_uname = 'arg base'), sensitive = 0
83          widget_control, widget_info(event.handler, find_by_uname = 'kwd base'), sensitive = 0
84          widget_control, widget_info(event.handler, find_by_uname = 'kwdlab'), set_value = 'no keywords:'
85        END
86      ENDCASE
87      widget_control, widget_info(event.handler, find_by_uname = 'argtxt'), set_value = ''
88      widget_control, widget_info(event.handler, find_by_uname = 'kwdtxt'), set_value = ''
89      widget_control, event.id, set_value = file_basename(filename, '.pro')
90    END
91    'browse meshload':BEGIN
92      filename = isafile(iodir = homedir, /onlypro, title = 'to load the grid file')
93      if size(filename, /type) NE 7 then return
94      meshload_id = widget_info(event.handler, find_by_uname = 'meshload')
95      widget_control, meshload_id, set_value = filename
96      selectfile_event, {ID:meshload_id, TOP:event.top, HANDLER:event.handler}
97    END
98; 'Lets Go!' button
99    'Lets Go!':BEGIN
100      widget_control, widget_info(event.handler, find_by_uname = 'datafilename') $
101                      , get_value = datafilename
102      datafilename = datafilename[0]
103      IF datafilename EQ '' THEN return
104      datafilename = isafile(filename = datafilename, iodir = iodir, /onlync, title = 'data file name')
105      if size(datafilename, /type) NE 7 then BEGIN
106        widget_control, widget_info(event.handler, find_by_uname = 'datafilename') $
107                        , set_value = ''
108        return
109      ENDIF
110      widget_control, widget_info(event.handler, find_by_uname = 'gridload') $
111                      , get_value = gridload
112      widget_control, widget_info(event.handler, find_by_uname = 'argtxt') $
113                      , get_value = argtxt
114      argtxt = strtrim(argtxt[0], 2)
115      IF strpos(argtxt, ',') EQ 0 THEN argtxt = strmid(argtxt, 1)
116      widget_control, widget_info(event.handler, find_by_uname = 'kwdtxt') $
117                      , get_value = kwdtxt
118      kwdtxt = strtrim(kwdtxt[0], 2)
119      IF strpos(kwdtxt, ',') EQ 0 THEN kwdtxt = strmid(kwdtxt, 1)
120
121      CASE gridload[0] OF
122        'via perso':BEGIN
123          meshload_id = widget_info(event.handler, find_by_uname = 'meshload')
124          widget_control, meshload_id, get_value = meshload
125          meshload = meshload[0]
126          IF meshload EQ '' THEN return
127          meshload = (find(meshload[0], /onlypro, /firstfound))[0]
128          if meshload EQ 'NOT FOUND' then begin
129            widget_control, meshload_id, set_value = ''
130            return
131          endif
132        END
133        'via initnetcdf':meshload = datafilename
134      ENDCASE
135      IF strlen(argtxt) NE 0 THEN meshload = meshload + ', ' + argtxt
136      IF strlen(kwdtxt) NE 0 THEN meshload = meshload + ', ' + kwdtxt
137      widget_control, event.handler, get_uvalue = messenger
138      *messenger = create_struct('datafilename', datafilename, 'meshload', meshload)
139      widget_control, event.handler, /destroy
140    END
141
142  endcase
143  return
144end
145;*********************************************************************
146FUNCTION selectfile, datafilename, idlfile, argspro, _extra = ex
147;
148;
149  compile_opt idl2, strictarrsubs
150;
151@common
152;------------------------------------------------------------
153;------------------------------------------------------------
154;
155; pour recuperer les reponses possees lors de l''utilisation de ce
156; widget on cree un pointeur que l''on place dans la uvalue. Comme ca
157; une fois que le widget est detruit dans la procedure ...event.pro,
158; la variable surlaquelle pointait le pointeur (contenue ds la uvalue
159; du widget) n''est pas detruite est on peut recuperer le resultat!
160;
161  messenger = ptr_new(/allocate_heap)
162  base = widget_base(/column, title = 'selectfile', /align_center, uvalue = messenger, _EXTRA = ex)
163; cancel button
164  dummyid = widget_button(base, value = 'Cancel', uvalue = {name:'Global Cancel'})
165; data file informations
166  basea = widget_base(base, /row, /align_center)
167  dummyid = widget_label(basea, value = 'Data file name: ')
168  database = widget_text(basea, value = '', uvalue = {name:'datafilename'} $
169                        , uname = 'datafilename', xsize = 45, /EDITABLE)
170  dummyid = widget_button(basea, value = 'Browse', uvalue = {name:'browse datafilename'})
171; switch automatic/by and mesh definition buttons
172  baseb = widget_base(base, /row, /align_center)
173  gdldid = cw_bgroup(baseb, ['automatic grid construction with initncdf.pro' $
174                              , 'grid construction with other IDL batch or procedure'] $
175                      , /exclusive, set_value = 0, uvalue = {name:'gridload'} $
176                      , uname = 'gridload', button_uvalue = ['via initnetcdf', 'via perso'])
177; name of the procedure or batch file
178  basec = widget_base(base, /row, /align_center, uname = 'pro base')
179  dummyid = widget_label(basec, value = 'IDL batch file of procedure')
180  basemeshload = widget_text(basec, value = 'initncdf', uvalue = {name:'meshload'} $
181                        , uname = 'meshload', xsize = 45, editable = 0)
182  dummyid = widget_button(basec, value = 'Browse', uvalue = {name:'browse meshload'})
183; arguments informations
184  based = widget_base(base, /row, /align_center, uname = 'arg base', sensitive = 0)
185  dummyid = widget_label(based, value = 'procedure arguments')
186  agrbase = widget_text(based, value = '', uvalue = {name:'argtxt'} $
187                        , uname = 'argtxt', xsize = 45, /EDITABLE)
188; keyword informations
189  basee = widget_base(base, /row, /align_center, uname = 'kwd base')
190  dummyid = widget_label(basee, uname = 'kwdlab', value = '     keywords of initncdf:')
191  dummyid = widget_text(basee, value = '' $
192                        , uvalue = {name:'kwdtxt'}, uname = 'kwdtxt', xsize = 45, /EDITABLE)
193; 'Lets Go!' button
194  basego = widget_button(base, value = 'Lets Go!', uvalue = {name:'Lets Go!'})
195
196;------------------------------------------------------------
197  IF n_elements(datafilename) NE 0 THEN BEGIN
198    widget_control, database, set_value = datafilename
199    selectfile_event, {ID:database, TOP:base, HANDLER:base}
200  ENDIF
201  IF n_elements(idlfile) NE 0 THEN BEGIN
202    widget_control, basemeshload, set_value = idlfile
203    selectfile_event, {ID:basemeshload, TOP:base, HANDLER:base}
204    widget_control, basemeshload, get_value = idlfile2
205    IF idlfile2[0] NE '' THEN widget_control, gdldid, set_value = 1
206  ENDIF
207  IF n_elements(argspro) NE 0 THEN widget_control, argbase, set_value = argspro
208;------------------------------------------------------------
209  IF n_elements(datafilename) EQ 0 THEN BEGIN
210    widget_control, base, /realize
211    xmanager, 'selectfile', base, event_handler = 'selectfile_event', no_block = 0
212  ENDIF ELSE selectfile_event, {ID:basego, TOP:base, HANDLER:base}
213;------------------------------------------------------------
214; get back the information from selectfile_event
215  res = *messenger
216  ptr_free, messenger
217  if size(res, /type) NE 8 then return, -1
218
219  loadgrid, res.meshload, _extra = ex
220
221  ccreadparameters = {funclec_name:'read_ncdf' $
222          , jpidta:jpidta, jpjdta:jpjdta, jpkdta:jpkdta $
223          , ixmindta:ixmindta, ixmaxdta:ixmaxdta $
224          , iymindta:iymindta, iymaxdta:iymaxdta $
225          , izmindta:izmindta, izmaxdta:izmaxdta}
226
227  res3 = scanfile(res.datafilename, iodir = iodir, _extra = ex)
228  if size(res3, /type) NE 8 then return,  -1
229
230  return, {fileparameters:res3, readparameters:ccreadparameters, meshparameters:ccmeshparameters}
231end
Note: See TracBrowser for help on using the repository browser.