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

Last change on this file since 157 was 157, checked in by navarro, 18 years ago

header improvements + xxx doc

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 11.2 KB
Line 
1;+
2; @file_comments
3;
4;
5; @categories
6;
7;
8; @param EVENT
9;
10;
11; @returns
12;
13;
14; @uses
15;
16;
17; @restrictions
18;
19;
20; @examples
21;
22;
23; @history
24;
25;
26; @version
27; $Id$
28;
29; @todo
30; seb: documenter EVENT
31;-
32;*********************************************************************
33PRO selectfile_event, event
34;
35;
36  compile_opt idl2, strictarrsubs
37;
38@common
39;
40  widget_control, event.id, get_uvalue = eventuvalue
41; default definition of messenger when selectfile_event is called
42; directly without calling xmanager
43  widget_control, event.handler, get_uvalue = messenger
44  *messenger = -1
45
46  IF chkstru(eventuvalue, 'name') EQ 0 THEN return
47
48  case eventuvalue.name of
49; cancel button
50    'Global Cancel':BEGIN
51      widget_control, event.handler, get_uvalue = messenger
52      *messenger = -1
53      widget_control, event.handler, /destroy
54    END
55; data file informations
56    'datafilename':BEGIN
57      widget_control, event.id, get_value = filename
58      filename = isafile(filename = filename[0], /onlync $
59                         , title = 'data file name', /tryfind, /fully_qualify_path)
60      if size(filename, /type) NE 7 then BEGIN
61        widget_control, event.id, set_value = ''
62        return
63      ENDIF
64      widget_control, event.id, set_value = filename
65    END
66    'browse datafilename':BEGIN
67      filename = isafile(/onlync, title = 'data file name', /tryfind, /fully_qualify_path)
68      if size(filename, /type) NE 7 then return
69      widget_control, widget_info(event.handler, find_by_uname = 'datafilename') $
70                      , set_value = filename
71    END
72; switch automatic/by and mesh definition buttons
73    'gridload':BEGIN
74      IF event.select EQ 1 THEN BEGIN
75        widget_control, widget_info(event.handler, find_by_uname = 'argtxt'), set_value = ''
76        widget_control, widget_info(event.handler, find_by_uname = 'kwdtxt'), set_value = ''
77        widget_control, widget_info(event.handler, find_by_uname = 'kwd base'), sensitive = 1
78        CASE event.value OF
79          'via initnetcdf':BEGIN
80            widget_control, widget_info(event.handler, find_by_uname = 'meshload'), set_value = 'initncdf', editable = 0
81            widget_control, widget_info(event.handler, find_by_uname = 'arg base'), sensitive = 0
82            widget_control, widget_info(event.handler, find_by_uname = 'kwdlab'), set_value = 'initncdf keywords:'
83          END
84          'via perso':BEGIN
85            widget_control, widget_info(event.handler, find_by_uname = 'meshload'), set_value = '', editable = 1
86            widget_control, widget_info(event.handler, find_by_uname = 'arg base'), sensitive = 1
87            widget_control, widget_info(event.handler, find_by_uname = 'kwdlab'), set_value = 'keywords of IDL procedure:'
88          END
89        ENDCASE
90      ENDIF
91    END
92; name of the procedure or batch file
93    'meshload':BEGIN
94      widget_control, event.id, get_value = filename
95      filename = (find(filename[0], /onlypro, /firstfound))[0]
96      if filename EQ 'NOT FOUND' then begin
97        widget_control, event.id, set_value = ''
98        return
99      endif
100      CASE protype(filename) OF
101; this is a procedure
102        'proc':BEGIN
103          widget_control, widget_info(event.handler, find_by_uname = 'arg base'), sensitive = 1
104          widget_control, widget_info(event.handler, find_by_uname = 'kwd base'), sensitive = 1
105          widget_control, widget_info(event.handler, find_by_uname = 'kwdlab'), set_value = file_basename(filename, '.pro')+' keywords:'
106        END
107; this is a function, this case is not accepted
108        'func':BEGIN
109          widget_control, event.id, set_value = ''
110          return
111        END
112; this is an IDL batch file
113        'batch':BEGIN
114          widget_control, widget_info(event.handler, find_by_uname = 'arg base'), sensitive = 0
115          widget_control, widget_info(event.handler, find_by_uname = 'kwd base'), sensitive = 0
116          widget_control, widget_info(event.handler, find_by_uname = 'kwdlab'), set_value = 'no keywords:'
117        END
118      ENDCASE
119      widget_control, widget_info(event.handler, find_by_uname = 'argtxt'), set_value = ''
120      widget_control, widget_info(event.handler, find_by_uname = 'kwdtxt'), set_value = ''
121      widget_control, event.id, set_value = file_basename(filename, '.pro')
122    END
123    'browse meshload':BEGIN
124      filename = isafile(iodir = homedir, /onlypro, title = 'to load the grid file')
125      if size(filename, /type) NE 7 then return
126      meshload_id = widget_info(event.handler, find_by_uname = 'meshload')
127      widget_control, meshload_id, set_value = filename
128      selectfile_event, {ID:meshload_id, TOP:event.top, HANDLER:event.handler}
129    END
130; 'Lets Go!' button
131    'Lets Go!':BEGIN
132      widget_control, widget_info(event.handler, find_by_uname = 'datafilename') $
133                      , get_value = datafilename
134      datafilename = datafilename[0]
135      IF datafilename EQ '' THEN return
136      datafilename = isafile(filename = datafilename, /tryfind, /onlync $
137                             , title = 'data file name', /fully_qualify_path)
138      if size(datafilename, /type) NE 7 then BEGIN
139        widget_control, widget_info(event.handler, find_by_uname = 'datafilename') $
140                        , set_value = ''
141        return
142      ENDIF
143      widget_control, widget_info(event.handler, find_by_uname = 'gridload') $
144                      , get_value = gridload
145      widget_control, widget_info(event.handler, find_by_uname = 'argtxt') $
146                      , get_value = argtxt
147      argtxt = strtrim(argtxt[0], 2)
148      IF strpos(argtxt, ',') EQ 0 THEN argtxt = strmid(argtxt, 1)
149      widget_control, widget_info(event.handler, find_by_uname = 'kwdtxt') $
150                      , get_value = kwdtxt
151      kwdtxt = strtrim(kwdtxt[0], 2)
152      IF strpos(kwdtxt, ',') EQ 0 THEN kwdtxt = strmid(kwdtxt, 1)
153
154      CASE gridload[0] OF
155        'via perso':BEGIN
156          meshload_id = widget_info(event.handler, find_by_uname = 'meshload')
157          widget_control, meshload_id, get_value = meshload
158          meshload = meshload[0]
159          IF meshload EQ '' THEN return
160          meshload = (find(meshload[0], /onlypro, /firstfound))[0]
161          if meshload EQ 'NOT FOUND' then begin
162            widget_control, meshload_id, set_value = ''
163            return
164          endif
165        END
166        'via initnetcdf':meshload = datafilename
167      ENDCASE
168      IF strlen(argtxt) NE 0 THEN meshload = meshload + ', ' + argtxt
169      IF strlen(kwdtxt) NE 0 THEN meshload = meshload + ', ' + kwdtxt
170      widget_control, event.handler, get_uvalue = messenger
171      *messenger = create_struct('datafilename', datafilename, 'meshload', meshload)
172      widget_control, event.handler, /destroy
173    END
174
175  endcase
176  return
177end
178;*********************************************************************
179;+
180; @file_comments
181;
182;
183; @categories
184;
185;
186; @param DATAFILENAME
187;
188;
189; @param IDLFILE
190;
191;
192; @param ARGSPRO
193;
194;
195; @keyword _EXTRA
196; Used to pass your keywords
197;
198; @returns
199;
200;
201; @uses
202;
203;
204; @restrictions
205;
206;
207; @examples
208;
209;
210; @history
211;
212;
213; @version
214; $Id$
215;
216; @todo
217; seb: documenter les params
218;
219;-
220FUNCTION selectfile, datafilename, idlfile, argspro, _extra = ex
221;
222;
223  compile_opt idl2, strictarrsubs
224;
225@common
226;------------------------------------------------------------
227;------------------------------------------------------------
228;
229; We create a pointer in the uvalue to recuperate answers at setted
230; questions atthe time of the use of this widget. So when the widget
231; is deleted in the procedure ...event.pro, the variable on which the
232; pointer pointed (contained in the uvalue of the widget) is not
233; deleted and we can recuperate the result!
234;
235  messenger = ptr_new(/allocate_heap)
236  base = widget_base(/column, title = 'selectfile', /align_center, uvalue = messenger, _EXTRA = ex)
237; cancel button
238  dummyid = widget_button(base, value = 'Cancel', uvalue = {name:'Global Cancel'})
239; data file informations
240  basea = widget_base(base, /row, /align_center)
241  dummyid = widget_label(basea, value = 'Data file name: ')
242  database = widget_text(basea, value = '', uvalue = {name:'datafilename'} $
243                        , uname = 'datafilename', xsize = 45, /EDITABLE)
244  dummyid = widget_button(basea, value = 'Browse', uvalue = {name:'browse datafilename'})
245; switch automatic/by and mesh definition buttons
246  baseb = widget_base(base, /row, /align_center)
247  gdldid = cw_bgroup(baseb, ['automatic grid construction with initncdf.pro' $
248                              , 'grid construction with other IDL batch or procedure'] $
249                      , /exclusive, set_value = 0, uvalue = {name:'gridload'} $
250                      , uname = 'gridload', button_uvalue = ['via initnetcdf', 'via perso'])
251; name of the procedure or batch file
252  basec = widget_base(base, /row, /align_center, uname = 'pro base')
253  dummyid = widget_label(basec, value = 'IDL batch file of procedure')
254  basemeshload = widget_text(basec, value = 'initncdf', uvalue = {name:'meshload'} $
255                        , uname = 'meshload', xsize = 45, editable = 0)
256  dummyid = widget_button(basec, value = 'Browse', uvalue = {name:'browse meshload'})
257; arguments informations
258  based = widget_base(base, /row, /align_center, uname = 'arg base', sensitive = 0)
259  dummyid = widget_label(based, value = 'procedure arguments')
260  agrbase = widget_text(based, value = '', uvalue = {name:'argtxt'} $
261                        , uname = 'argtxt', xsize = 45, /EDITABLE)
262; keyword informations
263  basee = widget_base(base, /row, /align_center, uname = 'kwd base')
264  dummyid = widget_label(basee, uname = 'kwdlab', value = '     keywords of initncdf:')
265  dummyid = widget_text(basee, value = '' $
266                        , uvalue = {name:'kwdtxt'}, uname = 'kwdtxt', xsize = 45, /EDITABLE)
267; 'Lets Go!' button
268  basego = widget_button(base, value = 'Lets Go!', uvalue = {name:'Lets Go!'})
269
270;------------------------------------------------------------
271  IF n_elements(datafilename) NE 0 THEN BEGIN
272    widget_control, database, set_value = datafilename
273    selectfile_event, {ID:database, TOP:base, HANDLER:base}
274  ENDIF
275  IF n_elements(idlfile) NE 0 THEN BEGIN
276    widget_control, basemeshload, set_value = idlfile
277    selectfile_event, {ID:basemeshload, TOP:base, HANDLER:base}
278    widget_control, basemeshload, get_value = idlfile2
279    IF idlfile2[0] NE '' THEN widget_control, gdldid, set_value = 1
280  ENDIF
281  IF n_elements(argspro) NE 0 THEN widget_control, argbase, set_value = argspro
282;------------------------------------------------------------
283  IF n_elements(datafilename) EQ 0 THEN BEGIN
284    widget_control, base, /realize
285    xmanager, 'selectfile', base, event_handler = 'selectfile_event', no_block = 0
286  ENDIF ELSE selectfile_event, {ID:basego, TOP:base, HANDLER:base}
287;------------------------------------------------------------
288; get back the information from selectfile_event
289  res = *messenger
290  ptr_free, messenger
291  if size(res, /type) NE 8 then return, -1
292
293  loadgrid, res.meshload, _extra = ex
294
295  ccreadparameters = {funclec_name:'read_ncdf' $
296          , jpidta:jpidta, jpjdta:jpjdta, jpkdta:jpkdta $
297          , ixmindta:ixmindta, ixmaxdta:ixmaxdta $
298          , iymindta:iymindta, iymaxdta:iymaxdta $
299          , izmindta:izmindta, izmaxdta:izmaxdta}
300
301  res3 = scanfile(res.datafilename, _extra = ex)
302  if size(res3, /type) NE 8 then return,  -1
303
304  return, {fileparameters:res3, readparameters:ccreadparameters, meshparameters:ccmeshparameters}
305end
Note: See TracBrowser for help on using the repository browser.