12 gen_namelist_defines ( char * dirname
, int sw_dimension
)
19 sprintf( fn
, "namelist_defines%s.inc", sw_dimension
?"":"2" ) ;
20 if ( strlen(dirname
) > 0 ) { sprintf(fname
,"%s/%s",dirname
,fn
) ; }
21 if ((fp
= fopen( fname
, "w" )) == NULL
) return(1) ;
22 print_warning(fp
,fname
) ;
24 fprintf(fp
,"integer :: first_item_in_struct\n") ;
25 for ( p
= Domain
.fields
; p
!= NULL
; p
= p
-> next
)
27 if ( p
->node_kind
& RCONFIG
)
31 if ( !strcmp( p
->nentries
, "1" ) )
32 fprintf(fp
,"%s :: %s\n",p
->type
->name
,p
->name
) ;
33 else if ( strcmp( p
->nentries
, "-" ) ) /* if not equal to "-" */
34 fprintf(fp
,"%s , DIMENSION(%s) :: %s\n",p
->type
->name
,p
->nentries
,p
->name
) ;
38 fprintf(fp
,"%s :: %s\n",p
->type
->name
,p
->name
) ;
42 fprintf(fp
,"integer :: last_item_in_struct\n") ;
44 close_the_file( fp
) ;
49 gen_namelist_defaults ( char * dirname
)
53 char *fn
= "namelist_defaults.inc" ;
56 if ( strlen(dirname
) > 0 ) { sprintf(fname
,"%s/%s",dirname
,fn
) ; }
57 if ((fp
= fopen( fname
, "w" )) == NULL
) return(1) ;
58 print_warning(fp
,fname
) ;
60 for ( p
= Domain
.fields
; p
!= NULL
; p
= p
-> next
)
62 if ( p
->node_kind
& RCONFIG
&& strcmp(p
->dflt
,"-") && strcmp(p
->dflt
,""))
64 if ( !strncmp ( p
->type
->name
, "character", 9 ) ) {
65 fprintf(fp
,"%s = \"%s\"\n",p
->name
,p
->dflt
) ;
67 fprintf(fp
,"%s = %s\n",p
->name
,p
->dflt
) ;
72 close_the_file( fp
) ;
78 gen_namelist_statements ( char * dirname
)
82 char * fn
= "namelist_statements.inc" ;
83 char howset
[NAMELEN
] ;
88 if ( strlen(dirname
) > 0 ) { sprintf(fname
,"%s/%s",dirname
,fn
) ; }
89 if ((fp
= fopen( fname
, "w" )) == NULL
) return(1) ;
90 print_warning(fp
,fname
) ;
92 for ( p
= Domain
.fields
; p
!= NULL
; p
= p
-> next
)
94 if ( p
->node_kind
& RCONFIG
)
96 strcpy(howset
,p
->howset
) ;
97 if (( p1
= strtok(howset
,",")) != NULL
)
99 p2
= strtok(NULL
,",") ;
100 if ( !strcmp(p1
,"namelist") )
105 "Warning: no namelist section specified for nl %s\n",p
->name
) ;
108 fprintf(fp
,"NAMELIST /%s/ %s\n",p2
,p
->name
) ;
114 close_the_file( fp
) ;
119 gen_get_nl_config ( char * dirname
)
122 char fname
[NAMELEN
] ;
123 char * fn
= "get_nl_config.inc" ;
125 char howset
[NAMELEN
] ;
130 strcpy( fname
, fn
) ;
131 if ( strlen(dirname
) > 0 ) { sprintf(fname
,"%s/%s",dirname
,fn
) ; }
132 if ((fp
= fopen( fname
, "w" )) == NULL
) return(1) ;
133 print_warning(fp
,fname
) ;
135 for ( sw
= 0 ; sw
< 2 ; sw
++ )
137 if ( sw
== 0 ) { gs
= "get" ; intnt
= "OUT" ; } else { gs
= "set" ; intnt
= "IN" ; }
138 for ( p
= Domain
.fields
; p
!= NULL
; p
= p
-> next
)
140 if ( p
->node_kind
& RCONFIG
)
142 strcpy(howset
,p
->howset
) ;
143 fprintf(fp
,"SUBROUTINE nl_%s_%s ( id_id , %s )\n",gs
,p
->name
, p
->name
) ;
144 if ( sw_ifort_kludge
) {
145 fprintf(fp
," USE module_configure\n") ;
147 fprintf(fp
," %s , INTENT(%s) :: %s\n",p
->type
->name
,intnt
,p
->name
) ;
148 fprintf(fp
," INTEGER id_id\n") ;
149 fprintf(fp
," CHARACTER*80 emess\n") ;
150 if ( sw
== 0 ) /* get */
152 if ( !strcmp( p
->nentries
, "1" )) {
153 if ( ! sw_ifort_kludge
) {
154 fprintf(fp
," IF ( id_id .NE. 1 ) THEN\n") ;
155 fprintf(fp
," call wrf_debug(1,&\n'WARNING in nl_%s_%s: %s applies to all domains. First arg ignored.')\n",
156 gs
,p
->name
, p
->name
) ;
157 fprintf(fp
," ENDIF\n" ) ;
159 if ( !strncmp(p
->type
->name
,"character",9)) {
160 fprintf(fp
," %s = trim(model_config_rec%%%s)\n",p
->name
,p
->name
) ;
162 fprintf(fp
," %s = model_config_rec%%%s\n",p
->name
,p
->name
) ;
165 if ( ! sw_ifort_kludge
) {
166 if ( !strcmp( p
->nentries
, "max_domains" )) {
167 fprintf(fp
," IF ( id_id .LT. 1 .OR. id_id .GT. model_config_rec%%max_dom ) THEN\n") ;
168 fprintf(fp
," WRITE(emess,*)'nl_%s_%s: Out of range domain number: ',id_id\n",gs
,p
->name
) ;
169 } else if ( !strcmp( p
->nentries
, "max_moves" )) {
170 fprintf(fp
," IF ( id_id .LT. 1 .OR. id_id .GT. model_config_rec%%num_moves ) THEN\n") ;
171 fprintf(fp
," WRITE(emess,*)'nl_%s_%s: Out of range move number: ',id_id\n",gs
,p
->name
) ;
172 } else if ( !strcmp( p
->nentries
, "max_eta" )) {
173 fprintf(fp
," IF ( id_id .LT. 1 .OR. id_id .GT. model_config_rec%%e_vert(1) ) THEN\n") ;
174 fprintf(fp
," WRITE(emess,*)'nl_%s_%s: Out of range eta_level number: ',id_id\n",gs
,p
->name
) ;
176 fprintf(stderr
,"Registry WARNING: multi element rconfig entry must be either max_domains, max_moves, or max_eta \n") ;
178 fprintf(fp
," CALL wrf_error_fatal(emess)\n") ;
179 fprintf(fp
," ENDIF\n" ) ;
181 fprintf(fp
," %s = model_config_rec%%%s(id_id)\n",p
->name
,p
->name
) ;
186 if ( !strcmp( p
->nentries
, "1" )) {
187 if ( ! sw_ifort_kludge
) {
188 fprintf(fp
," IF ( id_id .NE. 1 ) THEN\n") ;
189 fprintf(fp
," call wrf_debug(1,&\n'WARNING in nl_%s_%s: %s applies to all domains. First arg ignored.')\n",
190 gs
,p
->name
, p
->name
) ;
191 fprintf(fp
," ENDIF\n" ) ;
193 if ( !strncmp(p
->type
->name
,"character",9)) {
194 fprintf(fp
," model_config_rec%%%s = trim(%s) \n",p
->name
,p
->name
) ;
196 fprintf(fp
," model_config_rec%%%s = %s \n",p
->name
,p
->name
) ;
199 if ( ! sw_ifort_kludge
) {
200 if ( !strcmp( p
->nentries
, "max_domains" )) {
201 fprintf(fp
," IF ( id_id .LT. 1 .OR. id_id .GT. model_config_rec%%max_dom ) THEN\n") ;
202 fprintf(fp
," WRITE(emess,*)'nl_%s_%s: Out of range domain number: ',id_id\n",gs
,p
->name
) ;
203 } else if ( !strcmp( p
->nentries
, "max_moves" )) {
204 fprintf(fp
," IF ( id_id .LT. 1 .OR. id_id .GT. model_config_rec%%num_moves ) THEN\n") ;
205 fprintf(fp
," WRITE(emess,*)'nl_%s_%s: Out of range move number: ',id_id\n",gs
,p
->name
) ;
206 } else if ( !strcmp( p
->nentries
, "max_eta" )) {
207 fprintf(fp
," IF ( id_id .LT. 1 .OR. id_id .GT. model_config_rec%%e_vert(1) ) THEN\n") ;
208 fprintf(fp
," WRITE(emess,*)'nl_%s_%s: Out of range eta_level number: ',id_id\n",gs
,p
->name
) ;
210 fprintf(stderr
,"Registry WARNING: multi element rconfig entry must be either max_domains, max_moves, or max_eta \n") ;
212 fprintf(fp
," CALL wrf_error_fatal(emess)\n") ;
213 fprintf(fp
," ENDIF\n" ) ;
215 fprintf(fp
," model_config_rec%%%s(id_id) = %s\n",p
->name
,p
->name
) ;
218 fprintf(fp
," RETURN\n") ;
219 fprintf(fp
,"END SUBROUTINE nl_%s_%s\n",gs
,p
->name
) ;
223 close_the_file( fp
) ;
228 gen_config_assigns ( char * dirname
)
231 char fname
[NAMELEN
] ;
232 char * fn
= "config_assigns.inc" ;
236 strcpy( fname
, fn
) ;
237 if ( strlen(dirname
) > 0 ) { sprintf(fname
,"%s/%s",dirname
,fn
) ; }
238 if ((fp
= fopen( fname
, "w" )) == NULL
) return(1) ;
239 print_warning(fp
,fname
) ;
241 fprintf(fp
,"! Contains config assign statements for module_domain.F.\n") ;
242 fprintf(fp
,"#ifndef SOURCE_RECORD\n") ;
243 fprintf(fp
,"# define SOURCE_RECORD cfg%%\n") ;
244 fprintf(fp
,"#endif\n") ;
245 fprintf(fp
,"#ifndef SOURCE_REC_DEX\n") ;
246 fprintf(fp
,"# define SOURCE_REC_DEX\n") ;
247 fprintf(fp
,"#endif\n") ;
248 fprintf(fp
,"#ifndef DEST_RECORD\n") ;
249 fprintf(fp
,"# define DEST_RECORD new_grid%%\n") ;
250 fprintf(fp
,"#endif\n") ;
252 for ( p
= Domain
.fields
; p
!= NULL
; p
= p
-> next
)
254 if ( p
->node_kind
& RCONFIG
)
256 if ( !strcmp( p
->nentries
, "1" ))
259 strcpy( tmp
, "SOURCE_REC_DEX" ) ;
260 fprintf(fp
," DEST_RECORD %-26s = SOURCE_RECORD %s %s\n",p
->name
,p
->name
,tmp
) ;
263 close_the_file( fp
) ;
268 gen_config_reads ( char * dirname
)
271 char fname
[NAMELEN
] ;
272 char * fn
= "config_reads.inc" ;
273 char howset
[NAMELEN
] ;
277 strcpy( fname
, fn
) ;
278 if ( strlen(dirname
) > 0 ) { sprintf(fname
,"%s/%s",dirname
,fn
) ; }
279 if ((fp
= fopen( fname
, "w" )) == NULL
) return(1) ;
280 print_warning(fp
,fname
) ;
282 fprintf(fp
,"! Contains namelist statements for module_config.F.\n") ;
283 fprintf(fp
,"#ifndef NAMELIST_READ_UNIT\n") ;
284 fprintf(fp
,"# define NAMELIST_READ_UNIT nml_unit\n") ;
285 fprintf(fp
,"#endif\n") ;
286 fprintf(fp
,"#ifndef NAMELIST_READ_ERROR_LABEL\n") ;
287 fprintf(fp
,"# define NAMELIST_READ_ERROR_LABEL 9200\n") ;
288 fprintf(fp
,"#endif\n") ;
293 for ( p
= Domain
.fields
; p
!= NULL
; p
= p
-> next
)
295 if ( p
->node_kind
& RCONFIG
)
297 strcpy(howset
,p
->howset
) ;
298 p1
= strtok(howset
,",") ;
299 p2
= strtok(NULL
,",") ;
300 if ( !strcmp(p1
,"namelist") )
305 "Warning: no namelist section specified for nl %s\n",p
->name
) ;
308 if (sym_get( p2
) == NULL
) /* not in table yet */
310 fprintf(fp
," REWIND ( UNIT = NAMELIST_READ_UNIT )\n") ;
311 fprintf(fp
," READ ( UNIT = NAMELIST_READ_UNIT , NML = %s , ERR = NAMELIST_READ_ERROR_LABEL , END = NAMELIST_READ_ERROR_LABEL )\n",p2
) ;
312 fprintf(fp
,"#ifndef NO_NAMELIST_PRINT\n") ;
313 fprintf(fp
," WRITE ( UNIT = * , NML = %s )\n",p2
) ;
314 fprintf(fp
,"#endif\n") ;
321 close_the_file( fp
) ;