/[MITgcm]/MITgcm/model/src/packages_check.F
ViewVC logotype

Diff of /MITgcm/model/src/packages_check.F

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph | View Patch Patch

revision 1.33 by jmc, Fri Mar 17 03:55:43 2006 UTC revision 1.58 by jmc, Mon Apr 2 21:30:02 2012 UTC
# Line 10  C     !INTERFACE: Line 10  C     !INTERFACE:
10        SUBROUTINE PACKAGES_CHECK( myThid )        SUBROUTINE PACKAGES_CHECK( myThid )
11  C     !DESCRIPTION: \bv  C     !DESCRIPTION: \bv
12  C     *==========================================================*  C     *==========================================================*
13  C     | SUBROUTINE PACKAGES_CHECK                                  C     | SUBROUTINE PACKAGES_CHECK
14  C     | o Check runtime activated packages have been built in.      C     | o Check runtime activated packages have been built in.
15  C     *==========================================================*  C     *==========================================================*
16  C     | All packages can be selected/deselected at build time      C     | All packages can be selected/deselected at build time
17  C     | ( when code is compiled ) and activated/deactivated at      C     | ( when code is compiled ) and activated/deactivated at
18  C     | runtime. This routine does a quick check to trap packages  C     | runtime. This routine does a quick check to trap packages
19  C     | that were activated at runtime but that were not compiled  C     | that were activated at runtime but that were not compiled
20  C     | in at build time.                                          C     | in at build time.
21  C     *==========================================================*  C     *==========================================================*
22  C     \ev  C     \ev
23    
# Line 30  C     === Global variables === Line 30  C     === Global variables ===
30    
31  C     !INPUT/OUTPUT PARAMETERS:  C     !INPUT/OUTPUT PARAMETERS:
32  C     === Routine arguments ===  C     === Routine arguments ===
33  C     myThid ::  Number of this instances  C     myThid :: my Thread Id number
34        INTEGER myThid        INTEGER myThid
35    
36  C     !LOCAL VARIABLES:  C     !LOCAL VARIABLES:
37  C     === Local variables ===  C     === Local variables ===
38  C     msgBuf      :: Informational/error meesage buffer  C     msgBuf :: Informational/error message buffer
39  c     CHARACTER*(MAX_LEN_MBUF) msgBuf        CHARACTER*(MAX_LEN_MBUF) msgBuf
40  CEOP  CEOP
41    
42          _BEGIN_MASTER(myThid)
43          WRITE(msgBuf,'(A)')
44         &'== Packages configuration : Check & print summary =='
45          CALL PRINT_MESSAGE( msgBuf, standardMessageUnit,
46         &                    SQUEEZE_RIGHT, myThid )
47          WRITE(msgBuf,'(A)') ' '
48          CALL PRINT_MESSAGE( msgBuf, standardMessageUnit,
49         &                    SQUEEZE_RIGHT, myThid )
50          _END_MASTER(myThid)
51    
52    C---  Start with non-standard packages (without or with non standard flag)
53    
54    #ifndef ALLOW_MNC
55          IF (useMNC) THEN
56            _BEGIN_MASTER(myThid)
57            WRITE(msgBuf,'(2A)') '** WARNING **',
58         &   ' PACKAGES_CHECK: useMNC is TRUE'
59            CALL PRINT_MESSAGE( msgBuf, errorMessageUnit,
60         &                      SQUEEZE_RIGHT, myThid )
61            WRITE(msgBuf,'(2A)') '** WARNING **',
62         &   ' but pkg/mnc has not been compiled (#undef ALLOW_MNC)'
63            CALL PRINT_MESSAGE( msgBuf, errorMessageUnit,
64         &                      SQUEEZE_RIGHT, myThid )
65            _END_MASTER(myThid)
66          ENDIF
67    #endif
68    
69    #ifndef ALLOW_MOM_VECINV
70          IF ( momStepping .AND. vectorInvariantMomentum ) THEN
71            WRITE(msgBuf,'(2A)')
72         &   'PACKAGES_CHECK: cannot step forward Momentum',
73         &   ' without pkg/mom_vecinv'
74            CALL PRINT_ERROR( msgBuf , myThid )
75            WRITE(msgBuf,'(2A)') 'PACKAGES_CHECK: ',
76         &   'Re-compile with pkg "mom_vecinv" in packages.conf'
77            CALL PRINT_ERROR( msgBuf , myThid )
78            CALL ALL_PROC_DIE( myThid )
79            STOP 'ABNORMAL END: S/R PACKAGES_CHECK'
80          ENDIF
81    #endif
82    #ifndef ALLOW_MOM_FLUXFORM
83          IF ( momStepping .AND. .NOT.vectorInvariantMomentum ) THEN
84            WRITE(msgBuf,'(2A)')
85         &   'PACKAGES_CHECK: cannot step forward Momentum',
86         &   ' without pkg/mom_fluxform'
87            CALL PRINT_ERROR( msgBuf , myThid )
88            WRITE(msgBuf,'(2A)') 'PACKAGES_CHECK: ',
89         &   'Re-compile with pkg "mom_fluxform" in packages.conf'
90            CALL PRINT_ERROR( msgBuf , myThid )
91            CALL ALL_PROC_DIE( myThid )
92            STOP 'ABNORMAL END: S/R PACKAGES_CHECK'
93          ENDIF
94    #endif
95    
96    #ifndef ALLOW_GENERIC_ADVDIFF
97          IF ( tempStepping .OR. saltStepping ) THEN
98            WRITE(msgBuf,'(2A)')
99         &  'PACKAGES_CHECK: cannot step forward Temp or Salt',
100         &  ' without pkg/generic_advdiff'
101            CALL PRINT_ERROR( msgBuf , myThid )
102            WRITE(msgBuf,'(2A)') 'PACKAGES_CHECK: ',
103         &  'Re-compile with pkg "generic_advdiff" in packages.conf'
104            CALL PRINT_ERROR( msgBuf , myThid )
105            CALL ALL_PROC_DIE( myThid )
106            STOP 'ABNORMAL END: S/R PACKAGES_CHECK'
107          ENDIF
108    #endif
109    
110    #ifndef ALLOW_MONITOR
111    C     If monitorFreq is finite, make sure the pkg/monitor is being compiled
112          IF (monitorFreq.NE.0.) CALL PACKAGES_ERROR_MSG(
113         &                  'MONITOR', 'monitorFreq <> 0', myThid )
114    #endif
115    
116    #ifndef ALLOW_TIMEAVE
117    C     If taveFreq is finite, make sure the pkg/timeave is being compiled
118          IF (taveFreq.NE.0.) CALL PACKAGES_ERROR_MSG(
119         &                  'TIMEAVE', 'taveFreq <> 0', myThid )
120    #endif
121    
122    #ifndef ALLOW_CD_CODE
123           IF (useCDscheme) CALL PACKAGES_ERROR_MSG(
124         &                  'CD_CODE', 'useCDscheme=.T.', myThid )
125    #endif
126    
127    C---  Continue with standard packages (with standard usePKG flag)
128    
129  #ifdef ALLOW_RUNCLOCK  #ifdef ALLOW_RUNCLOCK
130        IF (useRunClock) CALL RUNCLOCK_CHECK( myThid )        IF (useRunClock) CALL RUNCLOCK_CHECK( myThid )
131  #else  #else
132        IF (useRunClock) CALL PACKAGES_CHECK_ERROR('RUNCLOCK', myThid)        IF (useRunClock) CALL PACKAGES_ERROR_MSG('RunClock',' ',myThid)
133  #endif  #endif
134    
135  #ifdef ALLOW_KPP  #ifdef ALLOW_KPP
136        IF (useKPP) CALL KPP_CHECK( myThid )        IF (useKPP) CALL KPP_CHECK( myThid )
137  #else  #else
138        IF (useKPP) CALL PACKAGES_CHECK_ERROR('KPP', myThid)        IF (useKPP) CALL PACKAGES_ERROR_MSG('KPP',' ',myThid)
139  #endif  #endif
140    
141  #ifdef ALLOW_PP81  #ifdef ALLOW_PP81
142        IF (usePP81) CALL PP81_CHECK( myThid )        IF (usePP81) CALL PP81_CHECK( myThid )
143  #else  #else
144        IF (usePP81) CALL PACKAGES_CHECK_ERROR('PP81', myThid)        IF (usePP81) CALL PACKAGES_ERROR_MSG('PP81',' ',myThid)
145  #endif  #endif
146    
147  #ifdef ALLOW_MY82  #ifdef ALLOW_MY82
148        IF (useMY82) CALL MY82_CHECK( myThid )        IF (useMY82) CALL MY82_CHECK( myThid )
149  #else  #else
150        IF (useMY82) CALL PACKAGES_CHECK_ERROR('MY82', myThid)        IF (useMY82) CALL PACKAGES_ERROR_MSG('MY82',' ',myThid)
151  #endif  #endif
152    
153  #ifdef ALLOW_GGL90  #ifdef ALLOW_GGL90
154        IF (useGGL90) CALL GGL90_CHECK( myThid )        IF (useGGL90) CALL GGL90_CHECK( myThid )
155  #else  #else
156        IF (useGGL90) CALL PACKAGES_CHECK_ERROR('GGL90', myThid)        IF (useGGL90) CALL PACKAGES_ERROR_MSG('GGL90',' ',myThid)
157  #endif  #endif
158    
159  #ifdef ALLOW_OPPS  #ifdef ALLOW_OPPS
160        IF (useOPPS) CALL OPPS_CHECK( myThid )        IF (useOPPS) CALL OPPS_CHECK( myThid )
161  #else  #else
162        IF (useOPPS) CALL PACKAGES_CHECK_ERROR('OPPS', myThid)        IF (useOPPS) CALL PACKAGES_ERROR_MSG('OPPS',' ',myThid)
163  #endif  #endif
164    
165  #ifdef ALLOW_GMREDI  #ifdef ALLOW_GMREDI
166        IF (useGMRedi) CALL GMREDI_CHECK( myThid )        IF (useGMRedi) CALL GMREDI_CHECK( myThid )
167  #else  #else
168        IF (useGMRedi) CALL PACKAGES_CHECK_ERROR('GMREDI', myThid)        IF (useGMRedi) CALL PACKAGES_ERROR_MSG('GMRedi',' ',myThid)
169    #endif
170    
171    #ifndef ALLOW_DOWN_SLOPE
172          IF (useDOWN_SLOPE)
173         &            CALL PACKAGES_ERROR_MSG('DOWN_SLOPE',' ',myThid)
174    #endif
175    
176    #ifdef ALLOW_BBL
177          IF (useBBL) CALL BBL_CHECK( myThid )
178    #else
179          IF (useBBL) CALL PACKAGES_ERROR_MSG('BBL',' ',myThid)
180  #endif  #endif
181    
182  #ifdef ALLOW_OBCS  #ifdef ALLOW_OBCS
183        IF (useOBCS) CALL OBCS_CHECK( myThid )        IF (useOBCS) CALL OBCS_CHECK( myThid )
184  #else  #else
185        IF (useOBCS) CALL PACKAGES_CHECK_ERROR('OBCS', myThid)        IF (useOBCS) CALL PACKAGES_ERROR_MSG('OBCS',' ',myThid)
186    #endif
187    
188    #ifdef ALLOW_EXF
189          IF (useEXF) CALL EXF_CHECK( myThid )
190    #else
191          IF (useEXF) CALL PACKAGES_ERROR_MSG('EXF',' ',myThid)
192  #endif  #endif
193    
194  #ifndef ALLOW_BULK_FORCE  #ifndef ALLOW_BULK_FORCE
195        IF (useBulkForce) CALL PACKAGES_CHECK_ERROR('BULK?FORCE',myThid)        IF (useBulkForce) CALL PACKAGES_ERROR_MSG(
196         &                  'BULK_FORCE', 'useBulkForce=.T.', myThid )
197    #endif
198    
199    #ifndef ALLOW_EBM
200          IF (useEBM) CALL PACKAGES_ERROR_MSG('EBM',' ',myThid)
201    #endif
202    
203    #ifndef ALLOW_CHEAPAML
204          IF (useCheapAML) CALL PACKAGES_ERROR_MSG('CheapAML',' ',myThid)
205  #endif  #endif
206    
207  #ifndef ALLOW_THSICE  #ifndef ALLOW_FRAZIL
208        IF (useThSIce) CALL PACKAGES_CHECK_ERROR('THSICE', myThid)        IF (useFRAZIL) CALL PACKAGES_ERROR_MSG('FRAZIL',' ',myThid)
209    #endif
210    
211    #ifdef ALLOW_THSICE
212          IF (useThSIce) CALL THSICE_CHECK( myThid )
213    #else
214          IF (useThSIce) CALL PACKAGES_ERROR_MSG('ThSIce',' ',myThid)
215    #endif
216    
217    #ifndef ALLOW_ATM2D
218          IF (useATM2D) CALL PACKAGES_ERROR_MSG('ATM2D',' ',myThid)
219  #endif  #endif
220    
221  #ifndef ALLOW_AIM  #ifndef ALLOW_AIM
222        IF (useAIM) CALL PACKAGES_CHECK_ERROR('AIM', myThid)        IF (useAIM) CALL PACKAGES_ERROR_MSG('AIM',' ',myThid)
223  #endif  #endif
224    
225  #ifndef ALLOW_LAND  #ifndef ALLOW_LAND
226        IF (useLand) CALL PACKAGES_CHECK_ERROR('LAND', myThid)        IF (useLand) CALL PACKAGES_ERROR_MSG('Land',' ',myThid)
227  #endif  #endif
228    
229  #ifndef ALLOW_PTRACERS  #ifndef ALLOW_FIZHI
230        IF (usePTRACERS) CALL PACKAGES_CHECK_ERROR('PTRACERS', myThid)        IF (useFizhi) CALL PACKAGES_ERROR_MSG('Fizhi',' ',myThid)
231  #endif  #endif
232    
233  #ifndef ALLOW_MATRIX  #ifndef ALLOW_GRIDALT
234        IF (useMATRIX) CALL PACKAGES_CHECK_ERROR('MATRIX', myThid)        IF (useGridAlt) CALL PACKAGES_ERROR_MSG('GridAlt',' ',myThid)
235    #endif
236    
237    #ifndef ALLOW_PTRACERS
238          IF (usePTRACERS) CALL PACKAGES_ERROR_MSG('PTRACERS',' ',myThid)
239  #endif  #endif
240    
241  #ifdef ALLOW_GCHEM  #ifdef ALLOW_GCHEM
242        IF (useGCHEM) CALL GCHEM_CHECK( myThid )        IF (useGCHEM) CALL GCHEM_CHECK( myThid )
243  #else  #else
244        IF (useGCHEM) CALL PACKAGES_CHECK_ERROR('GCHEM', myThid)        IF (useGCHEM) CALL PACKAGES_ERROR_MSG('GCHEM',' ',myThid)
245    #endif
246    
247    #ifndef ALLOW_RBCS
248          IF (useRBCS) CALL PACKAGES_ERROR_MSG('RBCS',' ',myThid)
249  #endif  #endif
250    
251  #ifndef ALLOW_OFFLINE  #ifndef ALLOW_OFFLINE
252        IF (useOffLine) CALL PACKAGES_CHECK_ERROR('OFFLINE', myThid)        IF (useOffLine) CALL PACKAGES_ERROR_MSG('OffLine',' ',myThid)
253    #endif
254    
255    #ifndef ALLOW_MATRIX
256          IF (useMATRIX) CALL PACKAGES_ERROR_MSG('MATRIX',' ',myThid)
257  #endif  #endif
258    
259  #ifndef ALLOW_SHAP_FILT  #ifndef ALLOW_SHAP_FILT
260        IF (useSHAP_FILT) CALL PACKAGES_CHECK_ERROR('SHAP_FILT', myThid)        IF (useSHAP_FILT)
261         &   CALL PACKAGES_ERROR_MSG( 'SHAP_FILT', ' ', myThid )
262  #endif  #endif
263    
264  #ifndef ALLOW_ZONAL_FILT  #ifndef ALLOW_ZONAL_FILT
265        IF (useZONAL_FILT) CALL PACKAGES_CHECK_ERROR('ZONAL_FILT',myThid)        IF (useZONAL_FILT)
266         &   CALL PACKAGES_ERROR_MSG( 'ZONAL_FILT', ' ', myThid )
267  #endif  #endif
268    
269  #ifndef ALLOW_FLT  #ifndef ALLOW_FLT
270        IF (useFLT) CALL PACKAGES_CHECK_ERROR('FLT', myThid)        IF (useFLT) CALL PACKAGES_ERROR_MSG('FLT',' ',myThid)
271  #endif  #endif
272    
273  #ifdef ALLOW_SBO  #ifdef ALLOW_SBO
274        IF (useSBO) CALL SBO_CHECK( myThid )        IF (useSBO) CALL SBO_CHECK( myThid )
275  #else  #else
276        IF (useSBO) CALL PACKAGES_CHECK_ERROR('SBO', myThid)        IF (useSBO) CALL PACKAGES_ERROR_MSG('SBO',' ',myThid)
277  #endif  #endif
278    
279  #ifdef ALLOW_SEAICE  #ifdef ALLOW_SEAICE
280        IF (useSEAICE) CALL SEAICE_CHECK( myThid )        IF (useSEAICE) CALL SEAICE_CHECK( myThid )
281  #else  #else
282        IF (useSEAICE) CALL PACKAGES_CHECK_ERROR('SEAICE', myThid)        IF (useSEAICE) CALL PACKAGES_ERROR_MSG('SEAICE',' ',myThid)
283    #endif
284    
285    #ifdef ALLOW_SALT_PLUME
286          IF (useSALT_PLUME)CALL SALT_PLUME_CHECK( myThid )
287    #else
288          IF (useSALT_PLUME)CALL PACKAGES_ERROR_MSG('SALT_PLUME',' ',myThid)
289  #endif  #endif
290    
291  #ifdef ALLOW_SHELFICE  #ifdef ALLOW_SHELFICE
292        IF (useShelfIce) CALL SHELFICE_CHECK( myThid )        IF (useShelfIce) CALL SHELFICE_CHECK( myThid )
293  #else  #else
294        IF (useShelfIce) CALL PACKAGES_CHECK_ERROR('SHELFICE', myThid)        IF (useShelfIce) CALL PACKAGES_ERROR_MSG('ShelfIce',' ',myThid)
295  #endif  #endif
296    
297  #ifndef ALLOW_CD_CODE  #ifdef ALLOW_STREAMICE
298        IF (useCDscheme) CALL PACKAGES_CHECK_ERROR('CD_CODE', myThid)        IF (useStreamIce) CALL STREAMICE_CHECK( myThid )
299    #else
300          IF (useStreamIce) CALL PACKAGES_ERROR_MSG('StreamIce',' ',myThid)
301    #endif
302    
303    #ifdef ALLOW_ICEFRONT
304          IF (useICEFRONT) CALL ICEFRONT_CHECK( myThid )
305    #else
306          IF (useICEFRONT) CALL PACKAGES_ERROR_MSG('ICEFRONT',' ',myThid)
307  #endif  #endif
308    
309  #ifdef ALLOW_AUTODIFF  #ifdef ALLOW_AUTODIFF
# Line 168  CEOP Line 319  CEOP
319  #endif  #endif
320    
321  #ifdef ALLOW_GRDCHK  #ifdef ALLOW_GRDCHK
322        CALL GRDCHK_CHECK( myThid )        IF (useGRDCHK) CALL GRDCHK_CHECK( myThid )
323    #endif
324    
325    #ifndef ALLOW_SMOOTH
326          IF (useSMOOTH) CALL PACKAGES_ERROR_MSG('SMOOTH',' ',myThid)
327  #endif  #endif
328    
329  #ifdef ALLOW_DIAGNOSTICS  #ifdef ALLOW_DIAGNOSTICS
330        IF (useDiagnostics) CALL DIAGNOSTICS_CHECK( myThid )        IF (useDiagnostics) CALL DIAGNOSTICS_CHECK( myThid )
331  #else  #else
332        IF (useDiagnostics)        IF (useDiagnostics)
333       &   CALL PACKAGES_CHECK_ERROR('DIAGNOSTICS', myThid )       &   CALL PACKAGES_ERROR_MSG( 'Diagnostics', ' ', myThid )
334    #endif
335    
336    #ifdef ALLOW_REGRID
337          IF (useREGRID) CALL REGRID_CHECK( myThid )
338    #else
339          IF (useREGRID) CALL PACKAGES_ERROR_MSG('REGRID',' ',myThid)
340    #endif
341    
342    #ifdef ALLOW_LAYERS
343          IF ( useLayers ) CALL LAYERS_CHECK( myThid )
344    #else
345          IF ( useLayers ) CALL PACKAGES_ERROR_MSG('LAYERS',' ',myThid)
346    #endif /* ALLOW_LAYERS */
347    
348    #ifdef ALLOW_NEST_CHILD
349          IF (useNEST_CHILD) CALL NEST_CHILD_CHECK( myThid )
350    #else
351          IF (useNEST_CHILD) CALL PACKAGES_ERROR_MSG(
352         & 'NEST_CHILD',' ',myThid)
353  #endif  #endif
354    
355    #ifdef ALLOW_NEST_PARENT
356          IF (useNEST_PARENT) CALL NEST_PARENT_CHECK( myThid )
357    #else
358          IF (useNEST_PARENT) CALL PACKAGES_ERROR_MSG(
359         & 'NEST_PARENT',' ',myThid)
360    #endif
361    
362    #ifdef ALLOW_OASIS
363          IF (useOASIS) CALL OASIS_CHECK( myThid )
364    #else
365          IF (useOASIS) CALL PACKAGES_ERROR_MSG('OASIS',' ',myThid)
366    #endif
367    
368    #ifdef ALLOW_ECCO
369          CALL ECCO_CHECK( myThid )
370    #endif
371    
372    #ifndef ALLOW_EMBED_FILES
373          IF (useEMBED_FILES) CALL PACKAGES_ERROR_MSG(
374         &                                  'EMBED_FILES',' ',myThid)
375    #endif
376    
377    #ifdef ALLOW_MYPACKAGE
378          IF (useMYPACKAGE) CALL MYPACKAGE_CHECK( myThid )
379    #else
380          IF (useMYPACKAGE) CALL PACKAGES_ERROR_MSG('MYPACKAGE',' ',myThid)
381    #endif
382    
383    #ifdef ALLOW_GENERIC_ADVDIFF
384    C-    Check generic AdvDiff setting and related overlap minimum size:
385    C     for this reason, called after other ${pkg}_check S/R
386          IF (useGAD) CALL GAD_CHECK( myThid )
387    #endif
388    
389    C---  Exclusive packages (which cannot be used together):
390          IF ( useEXF .AND. useBulkForce ) THEN
391            WRITE(msgBuf,'(2A)') 'PACKAGES_CHECK: ',
392         &  'both useEXF and useBulkForce are set'
393            CALL PRINT_ERROR( msgBuf , myThid )
394            WRITE(msgBuf,'(2A)') 'PACKAGES_CHECK: ',
395         &  ' but cannot be used together => need to select only one.'
396            CALL PRINT_ERROR( msgBuf , myThid )
397            CALL ALL_PROC_DIE( myThid )
398            STOP 'ABNORMAL END: S/R PACKAGES_CHECK'
399          ENDIF
400    
401    C---  Exclusive packages (which cannot be used together):
402          IF ( useDOWN_SLOPE .AND. useBBL ) THEN
403            WRITE(msgBuf,'(2A)') 'PACKAGES_CHECK: ',
404         &  'both useDOWN_SLOPE and useBBL are set'
405            CALL PRINT_ERROR( msgBuf , myThid )
406            WRITE(msgBuf,'(2A)') 'PACKAGES_CHECK: ',
407         &  ' but cannot be used together => need to select only one.'
408            CALL PRINT_ERROR( msgBuf , myThid )
409            CALL ALL_PROC_DIE( myThid )
410            STOP 'ABNORMAL END: S/R PACKAGES_CHECK'
411          ENDIF
412    
413        RETURN        RETURN
414        END        END

Legend:
Removed from v.1.33  
changed lines
  Added in v.1.58

  ViewVC Help
Powered by ViewVC 1.1.22