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

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

debug xxx and cie + clean data file + rm perldoc_idl

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