1 | #!/bin/bash |
---|
2 | |
---|
3 | #==============================================================================================================================\n |
---|
4 | # MODULE : makeorchidee_fcm |
---|
5 | # |
---|
6 | # CONTACT : orchidee-help _at_ ipsl.jussieu.fr |
---|
7 | # |
---|
8 | # LICENCE : IPSL (2006) |
---|
9 | # This software is governed by the CeCILL licence see ORCHIDEE/ORCHIDEE_CeCILL.LIC |
---|
10 | # |
---|
11 | # SVN : |
---|
12 | # $HeadURL: svn://forge.ipsl.jussieu.fr/orchidee/trunk/ORCHIDEE/makeorchidee_fcm $ |
---|
13 | # $Date: $ |
---|
14 | # $Revision: $ |
---|
15 | # \n |
---|
16 | #################################################################################################### |
---|
17 | # |
---|
18 | # This script has several possible functions : |
---|
19 | # 1. Compiling ORCHIDEE |
---|
20 | # 2. Building of the documentation |
---|
21 | # |
---|
22 | #*************************************************************************************************** |
---|
23 | # |
---|
24 | # Command lines : |
---|
25 | # |
---|
26 | # 1) makeorchidee_fcm [ -parallel PARALLEL_TYPE ] |
---|
27 | # [ -driver ] |
---|
28 | # [ -arch XXX ] |
---|
29 | # [ -prod | -dev | -debug ] |
---|
30 | # |
---|
31 | # 2) makeorchidee_fcm [ -clean ] |
---|
32 | # |
---|
33 | # 3) makeorchidee_fcm [ -doc | -doc_para ] ## actually doc_para is commented |
---|
34 | # [ -rmdoc ] |
---|
35 | # [ -doc_tree ] |
---|
36 | # |
---|
37 | |
---|
38 | parallel_mode=seq |
---|
39 | is_driver_opt=FALSE |
---|
40 | is_arch_opt=FALSE |
---|
41 | clean=FALSE |
---|
42 | compile_flags="%PROD_FFLAGS" |
---|
43 | xios=FALSE |
---|
44 | full="" |
---|
45 | job=1 |
---|
46 | ext_src="" |
---|
47 | |
---|
48 | export P_P="" |
---|
49 | export SECTIONS_PARA="" |
---|
50 | |
---|
51 | ORCHDIR=`/bin/pwd` |
---|
52 | fcm_path=$ORCHDIR/tools/FCM_V1.2/bin |
---|
53 | |
---|
54 | while (($# > 0)) ; do |
---|
55 | case $1 in |
---|
56 | "-h") cat <<fin |
---|
57 | |
---|
58 | ######################################################################## |
---|
59 | # Usage of the script makeorchidee_fcm |
---|
60 | # |
---|
61 | # makeorchidee_fcm compiles ORCHIDEE using the Fcm a software developed |
---|
62 | # by the Hadley Centre. Fcm is stored in tools directory. |
---|
63 | # Platform specific compile options are found in the arch directory. |
---|
64 | ######################################################################## |
---|
65 | |
---|
66 | ./makeorchidee_fcm [Options] |
---|
67 | |
---|
68 | Main options |
---|
69 | [ -h ] : show this help |
---|
70 | |
---|
71 | [ -arch XXX ] : name of the archicture file containg platform dependent compile options. |
---|
72 | The files arch/arch-XXX.fcm and arch/arch-XXX.path must exist. |
---|
73 | |
---|
74 | [ -parallel|-p PARALLEL_TYPE ] : choose parallelization mode for ORCHIDEE : |
---|
75 | PARALLEL_TYPE = |
---|
76 | ( mpi | MPI ) : only MPI (Message Passing Interface) |
---|
77 | ( omp | OMP ) : only OpenMP |
---|
78 | ( mpi_omp | MPI_OMP ) : hybrid MPI/OpenMP mode |
---|
79 | ( none | NONE | seq ) : sequential mode (default) |
---|
80 | |
---|
81 | [ -driver ] : compilation of ORCHIDEE offline driver (default compiling only the library) |
---|
82 | |
---|
83 | Options related to cleaning |
---|
84 | | -clean ] : delete all files produceed during previous compilation |
---|
85 | | -full ] : activate full recompiling |
---|
86 | |
---|
87 | Options for XIOS, only choose one of the following |
---|
88 | [ -xios ] : linking with XIOS |
---|
89 | [ -noxios ] : compilation without XIOS (default) |
---|
90 | |
---|
91 | Options for optimization, choose only one of the following |
---|
92 | [ -prod ] : compilation for production (all optimization) |
---|
93 | [ -dev ] : compilation for development (low optimization and -g) |
---|
94 | [ -debug ] : compilation for debugging (no optmization and all debug options) |
---|
95 | |
---|
96 | Option to optimize the compilation time |
---|
97 | [ -j x ] : activate parallel compiling on x task, default 1 task |
---|
98 | |
---|
99 | Option to add extra source to compile |
---|
100 | [ -ext_src path] : path to an additional directory with fortran routines to compile with the model |
---|
101 | |
---|
102 | Options for compiling the documentation : |
---|
103 | [ -doc ] : generate documentation with Doxygen (exit after doc computation) |
---|
104 | [ -doc_para ] : generate documentation with Doxygen with parallelization calls |
---|
105 | [ -rmdoc ] : remove documentation directory (before generate new documentation with Doxygen ?) |
---|
106 | [ -doc_tree ] : generate tree of ORCHIDEE directories for each file |
---|
107 | |
---|
108 | |
---|
109 | Example 1 : compile at curie(TGCC) for MPI parallel run mode |
---|
110 | ./makeorchidee_fcm -parallel mpi -arch X64_CURIE -driver |
---|
111 | |
---|
112 | Example 2 : compile at ada(IDRIS) for MPI-OpenMP parallel run mode |
---|
113 | ./makeorchidee_fcm -parallel mpi_omp -arch X64_ADA -driver |
---|
114 | |
---|
115 | Example 3 : compile at obelix(LSCE) |
---|
116 | ./makeorchidee_fcm -arch ifort_LSCE -driver |
---|
117 | |
---|
118 | Example 4 : compile using gfortran compiler for sequential run mode |
---|
119 | First make sure that the files arch/gfortran.fcm and arch/gfortran.path are suitable for |
---|
120 | your environement especially the path to netcdf library. |
---|
121 | ./makeorchidee_fcm -parallel seq -arch gfortran -driver |
---|
122 | |
---|
123 | Example 5 : clean files created during previous compilation |
---|
124 | ./makeorchidee_fcm -clean |
---|
125 | |
---|
126 | fin |
---|
127 | exit;; |
---|
128 | |
---|
129 | ######################################################################## |
---|
130 | # Read argument |
---|
131 | ######################################################################## |
---|
132 | |
---|
133 | "-parallel") |
---|
134 | parallel_mode=$2 ; shift ; shift ;; |
---|
135 | |
---|
136 | "-driver") |
---|
137 | is_driver_opt=TRUE |
---|
138 | shift ;; |
---|
139 | |
---|
140 | "-arch") |
---|
141 | is_arch_opt=TRUE |
---|
142 | arch="$2" ; shift ; shift ;; |
---|
143 | |
---|
144 | "-xios") |
---|
145 | xios=TRUE |
---|
146 | shift ;; |
---|
147 | |
---|
148 | "-noxios") |
---|
149 | xios=FALSE |
---|
150 | shift ;; |
---|
151 | |
---|
152 | "-prod") |
---|
153 | compile_flags="%PROD_FFLAGS" |
---|
154 | shift ;; |
---|
155 | |
---|
156 | "-dev") |
---|
157 | compile_flags="%DEV_FFLAGS" |
---|
158 | shift ;; |
---|
159 | |
---|
160 | "-debug") |
---|
161 | compile_flags="%DEBUG_FFLAGS" |
---|
162 | shift ;; |
---|
163 | |
---|
164 | "-j") |
---|
165 | job="$2" ; shift ; shift ;; |
---|
166 | |
---|
167 | "-full") |
---|
168 | full='-full' |
---|
169 | shift ;; |
---|
170 | |
---|
171 | "-clean") |
---|
172 | clean=TRUE |
---|
173 | shift ;; |
---|
174 | |
---|
175 | "-ext_src") |
---|
176 | ext_src=$2 ; shift ; shift ;; |
---|
177 | |
---|
178 | # "-doc_para") |
---|
179 | # setenv P_P -DCPP_PARA |
---|
180 | # setenv SECTIONS_PARA "-e s&ENABLED_SECTIONS\ *= &ENABLED_SECTIONS = CPP_PARA&g" |
---|
181 | # goto doc |
---|
182 | |
---|
183 | "-doc") |
---|
184 | ##################################################################################################### |
---|
185 | |
---|
186 | # 2) Building the documentation: |
---|
187 | # ------------------------------ |
---|
188 | # We assume to start in the ORCHIDEE directory |
---|
189 | # |
---|
190 | #**** Directory structure: |
---|
191 | # |
---|
192 | # .. : parent of the start dir. |
---|
193 | # -- ORCHIDEE : ($MODELPATH), start directory |
---|
194 | # - src_sechiba |
---|
195 | # - src_stomate |
---|
196 | # + DOC |
---|
197 | # + webdoc |
---|
198 | # -- IOIPSL |
---|
199 | # - src |
---|
200 | # ++ modeles_doc : ($SRCPATH), source files for the documentation, emptied at start, temporary |
---|
201 | # |
---|
202 | #**** gawk scripts called : |
---|
203 | # |
---|
204 | # codeinc.awk : encaspulates code parts in Doxygen documentation |
---|
205 | # codedox.awk : transforms almost all comments in Doxygen comments for documentation |
---|
206 | # codealgo.awk : emphasizes main algorithm description of each routine in their Doxygen documentation |
---|
207 | # |
---|
208 | #**** |
---|
209 | unalias cd |
---|
210 | |
---|
211 | export REV=`svn info | grep vision | sed -e 's&.*vision.*: \([0-9]*\)&\1&' | head -n 1` |
---|
212 | export TAG=`svn info | grep URL | sed -e 's&.*URL.*: svn://forge.ipsl.jussieu.fr/orchidee/\(.*\)&\1&' | head -n 1 | xargs dirname` |
---|
213 | cd .. |
---|
214 | |
---|
215 | \rm -rf modeles_doc |
---|
216 | export MODELPATH=${PWD} |
---|
217 | \mkdir modeles_doc |
---|
218 | export SRCPATH=${MODELPATH}/modeles_doc |
---|
219 | |
---|
220 | find IOIPSL/src \( -not -path '*.svn*' \ |
---|
221 | -a \( -name '*.f90' -o -name "*.F90" -o -name "*.h" \) \) \ |
---|
222 | -exec bash -c 'mkdir -p '${SRCPATH}'/$( dirname {} ); cp -p {} '${SRCPATH}'/$( dirname {} )' \; |
---|
223 | |
---|
224 | find ORCHIDEE \( -not -path '*.svn*' \ |
---|
225 | -a \( -name '*.f90' -o -name "*.F90" -o -name "*.h" \) \) \ |
---|
226 | -exec bash -c 'mkdir -p '${SRCPATH}'/$( dirname {} ); cp -p {} '${SRCPATH}'/$( dirname {} )' \; |
---|
227 | cd ${SRCPATH} |
---|
228 | # Use standard preprocessor to suppress all preproc directives |
---|
229 | \find . -name "*.f90" -exec cpp -P -C -traditional -x assembler-with-cpp ${P_P} '{}' '{}'_ \; |
---|
230 | \find . -name "*.f90" -print -exec mv -f '{}'_ '{}' \; |
---|
231 | |
---|
232 | # use codeinc script to encaspulate code parts in Doxygen documentation |
---|
233 | \find . -name "*.f90" -exec gawk -f ${MODELPATH}/ORCHIDEE/DOC/TOOLS/codeinc.awk '{}' \; > /dev/null |
---|
234 | \find . -name "*.f90" -print -exec mv -f '{}'_preproc_codeinc '{}' \; |
---|
235 | # use codedox script to transform almost all comments in Doxygen comments for documentation (use with care !) |
---|
236 | \find . -name "*.f90" -exec gawk -f ${MODELPATH}/ORCHIDEE/DOC/TOOLS/codedox.awk '{}' \; > /dev/null |
---|
237 | \find . -name "*.f90" -print -exec mv -f '{}'_preproc_codedox '{}' \; |
---|
238 | |
---|
239 | # use codealgo script to emphasize main algorithm description of each routine in their Doxygen documentation |
---|
240 | \find . -name "*.f90" -exec gawk -f ${MODELPATH}/ORCHIDEE/DOC/TOOLS/codealgo.awk '{}' \; > /dev/null |
---|
241 | \find . -name "*.f90" -print -exec mv -f '{}'_preproc_codealgo '{}' \; |
---|
242 | cd ../ORCHIDEE |
---|
243 | \rm -f ${MODELPATH}/ORCHIDEE/Doxyfile_ORCHIDEE |
---|
244 | sed -e 's&MYPATH&'${MODELPATH}'&g' -e 's&SRCPATH&'${SRCPATH}'&g' \ |
---|
245 | -e 's&MYTAG&'${TAG}'&' -e 's&MYREV&'${REV}'&' ${SECTIONS_PARA} \ |
---|
246 | ${MODELPATH}/ORCHIDEE/Doxyfile_ORCHIDEE.init > ${MODELPATH}/ORCHIDEE/Doxyfile_ORCHIDEE |
---|
247 | \rm -f ${MODELPATH}/ORCHIDEE/DOC/header.tex |
---|
248 | sed -e "s&MYTAG&${TAG}&" -e "s&MYREV&${REV}&" \ |
---|
249 | ${MODELPATH}/ORCHIDEE/DOC/header.tex.init > ${MODELPATH}/ORCHIDEE/DOC/header.tex |
---|
250 | ln -s /home/orchidee01/maignan/ORCHIDEE/DOC/IMAGES ${MODELPATH}/ORCHIDEE/DOC/IMAGES |
---|
251 | gmake doc |
---|
252 | gmake bib |
---|
253 | gmake toc |
---|
254 | \rm -rf ${MODELPATH}/ORCHIDEE/webdoc |
---|
255 | \mv ${MODELPATH}/ORCHIDEE/docs/html ${MODELPATH}/ORCHIDEE/webdoc |
---|
256 | gmake index |
---|
257 | gmake toc |
---|
258 | \rm -rf ${SRCPATH} |
---|
259 | cp ${MODELPATH}/ORCHIDEE/docs/latex/refman.pdf ${MODELPATH}/ORCHIDEE/documentation.pdf |
---|
260 | exit |
---|
261 | shift ;; |
---|
262 | |
---|
263 | |
---|
264 | "-rmdoc") |
---|
265 | \rm -rf docs |
---|
266 | shift ;; |
---|
267 | |
---|
268 | "-doc_tree") |
---|
269 | cd .. |
---|
270 | find ORCHIDEE \( -not -path '*.svn*' \ |
---|
271 | -a \( -name '*.f90' -o -name "*.F90" -o -name "*.h" \) \) \ |
---|
272 | -exec bash -c 'mkdir -p ORCHIDEE/DOC/$( dirname {} )/$( echo $( basename {} ) | sed -e "s/\..*//" )' \; |
---|
273 | cd ORCHIDEE |
---|
274 | shift ;; |
---|
275 | |
---|
276 | *) |
---|
277 | echo "unknown option "$1" , exiting..." |
---|
278 | exit |
---|
279 | esac |
---|
280 | done |
---|
281 | |
---|
282 | ##################################################################################################### |
---|
283 | # 0) Clean directory from files produced during previous compilation |
---|
284 | # -------------------------------------- |
---|
285 | if [[ "$clean" == "TRUE" ]] ; then |
---|
286 | rm -fr .config |
---|
287 | rm -fr lib |
---|
288 | rm -fr bin |
---|
289 | rm -fr tmp_src |
---|
290 | rm -f ../../lib/intersurf.mod |
---|
291 | rm -f ../../lib/liborglob.a |
---|
292 | rm -f ../../lib/libparallel.a |
---|
293 | rm -f ../../lib/libsechiba.a |
---|
294 | rm -f ../../lib/libstomate.a |
---|
295 | rm -f ../../lib/libparameters.a |
---|
296 | rm -f ../../lib/liborchidee_ol.a |
---|
297 | rm -f ../../lib/liborchidee.a |
---|
298 | |
---|
299 | exit |
---|
300 | fi |
---|
301 | |
---|
302 | # 1) Compilation du code direct avec fcm |
---|
303 | # -------------------------------------- |
---|
304 | # Add fcm in environement path |
---|
305 | export PATH=${fcm_path}:${PATH} |
---|
306 | |
---|
307 | #define architecture files |
---|
308 | if [[ "$is_arch_opt" == "TRUE" ]] ; then |
---|
309 | if [[ -e arch/arch-${arch}.fcm ]] ; then |
---|
310 | rm -f arch.fcm |
---|
311 | ln -s arch/arch-${arch}.fcm arch.fcm |
---|
312 | else |
---|
313 | echo "architecture file : << arch/arch-${arch}.fcm >> is missing, exiting...." |
---|
314 | exit |
---|
315 | fi |
---|
316 | |
---|
317 | if [[ -e arch/arch-${arch}.path ]] ; then |
---|
318 | rm -f arch.path |
---|
319 | ln -s arch/arch-${arch}.path arch.path |
---|
320 | else |
---|
321 | echo "architecture file : << arch/arch-${arch}.path >> is missing, exiting...." |
---|
322 | exit |
---|
323 | fi |
---|
324 | else |
---|
325 | echo "Warning : architecture not specified, taking default file <<arch.fcm>> and <<arch.path>>" |
---|
326 | if [[ ! -e arch.fcm ]] ; then |
---|
327 | echo "architecture file : << arch.fcm >> is missing, exiting...." |
---|
328 | exit |
---|
329 | fi |
---|
330 | |
---|
331 | if [[ ! -e arch.fcm ]] ; then |
---|
332 | echo "architecture file : << arch.path >> is missing, exiting...." |
---|
333 | exit |
---|
334 | fi |
---|
335 | fi |
---|
336 | |
---|
337 | # set compiler flags |
---|
338 | FFLAGS="%BASE_FFLAGS" |
---|
339 | LD_FFLAGS="%BASE_LD" |
---|
340 | CPP_KEY="%FPP_DEF" |
---|
341 | |
---|
342 | # set compiler flags for optimisation |
---|
343 | FFLAGS=${FFLAGS}" "$compile_flags |
---|
344 | LD_FFLAGS=${LD_FFLAGS}" "$compile_flags |
---|
345 | |
---|
346 | # set compiler flags for parallelism |
---|
347 | echo "parallel_mode = "${parallel_mode} |
---|
348 | |
---|
349 | if [[ "$parallel_mode" == "mpi" ]] || [[ "$parallel_mode" == "MPI" ]] ; then |
---|
350 | FFLAGS="${FFLAGS} %MPI_FFLAGS" |
---|
351 | LD_FFLAGS="%MPI_LD ${LD_FFLAGS}" |
---|
352 | CPP_KEY="CPP_PARA ${CPP_KEY}" |
---|
353 | elif [[ "$parallel_mode" == "omp" ]] || [[ "$parallel_mode" == "OMP" ]] ; then |
---|
354 | FFLAGS="${FFLAGS} %OMP_FFLAGS" |
---|
355 | LD_FFLAGS="%OMP_LD ${LD_FFLAGS}" |
---|
356 | CPP_KEY="CPP_OMP CPP_PARA ${CPP_KEY}" |
---|
357 | elif [[ "$parallel_mode" == "mpi_omp" ]] || [[ "$parallel_mode" == "MPI_OMP" ]] ; then |
---|
358 | FFLAGS="${FFLAGS} %MPI_FFLAGS %OMP_FFLAGS" |
---|
359 | LD_FFLAGS="%MPI_LD %OMP_LD ${LD_FFLAGS}" |
---|
360 | CPP_KEY="CPP_OMP CPP_PARA ${CPP_KEY}" |
---|
361 | elif [[ "$parallel_mode" == "none" ]] || [[ "$parallel_mode" == "NONE" ]] || [[ "$parallel_mode" == "seq" ]] ; then |
---|
362 | echo "Compiling for sequential mode" |
---|
363 | else |
---|
364 | echo "This option for parallel_mode is not implemeted. Choose between mpi, omp, mpi_omp and none." |
---|
365 | exit |
---|
366 | fi |
---|
367 | |
---|
368 | |
---|
369 | if [[ "$xios" == "TRUE" ]] ; then |
---|
370 | CPP_KEY="XIOS ${CPP_KEY}" |
---|
371 | fi |
---|
372 | |
---|
373 | # set target |
---|
374 | TARGET=liborchidee.a |
---|
375 | if [[ "$is_driver_opt" == "TRUE" ]] ; then |
---|
376 | TARGET="liborchidee_ol.a dim2_driver.exe teststomate.exe forcesoil.exe" |
---|
377 | fi |
---|
378 | |
---|
379 | source ./arch.path |
---|
380 | |
---|
381 | # build config file |
---|
382 | config_fcm="config.fcm" |
---|
383 | rm -f $config_fcm |
---|
384 | touch $config_fcm |
---|
385 | |
---|
386 | echo "%ARCH $arch" >> $config_fcm |
---|
387 | echo "%FFLAGS $FFLAGS" >> $config_fcm |
---|
388 | echo "%CPP_KEY $CPP_KEY" >> $config_fcm |
---|
389 | echo "%EXEC $TARGET" >> $config_fcm |
---|
390 | echo "%LD_FFLAGS $LD_FFLAGS" >> $config_fcm |
---|
391 | if [[ "$xios" == "TRUE" ]] ; then |
---|
392 | echo "%INCDIR -I$NETCDF_INCDIR -I$IOIPSL_INCDIR -I$XIOS_INCDIR" >> $config_fcm |
---|
393 | echo "%LIBDIR -L$NETCDF_LIBDIR -L$IOIPSL_LIBDIR -L$XIOS_LIBDIR" >> $config_fcm |
---|
394 | else |
---|
395 | echo "%INCDIR -I$NETCDF_INCDIR -I$IOIPSL_INCDIR" >> $config_fcm |
---|
396 | echo "%LIBDIR -L$NETCDF_LIBDIR -L$IOIPSL_LIBDIR" >> $config_fcm |
---|
397 | fi |
---|
398 | echo "%EXT_SRC $ext_src" >> $config_fcm |
---|
399 | |
---|
400 | |
---|
401 | # Delete interface module from modipsl/lib directory |
---|
402 | rm -f ../../lib/intersurf.mod |
---|
403 | |
---|
404 | # Check if compiling is locked |
---|
405 | if [ -f .config/fcm.bld.lock ] ; then |
---|
406 | echo "WARNING : build lock file exists" |
---|
407 | echo "This means that either someone else is compiling this directory right now " |
---|
408 | echo "or the previous compiling was interrupt abnormally." |
---|
409 | echo "" |
---|
410 | echo "Do you whant to remove this file and start compiling? [answer yes/no]" |
---|
411 | read answer |
---|
412 | if [ $answer = "yes" ] || [ $answer = "y" ] ; then |
---|
413 | rm -f .config/fcm.bld.lock |
---|
414 | else |
---|
415 | echo "Exit now!!!" |
---|
416 | exit 1 |
---|
417 | fi |
---|
418 | fi |
---|
419 | |
---|
420 | # Do the compiling |
---|
421 | fcm build -j $job $full |
---|
422 | err=$? |
---|
423 | if [ $err != 0 ] ; then |
---|
424 | # ERROR IN COMPILING |
---|
425 | echo ERROR IN COMPILING ORCHIDEE : $err |
---|
426 | exit 1 |
---|
427 | fi |
---|
428 | |
---|
429 | # Copy into modipsl/lib directory libraries and interface module needed by LMDZ |
---|
430 | cp lib/lib*a ../../lib/. |
---|
431 | cp lib/intersurf.mod ../../lib/. |
---|
432 | |
---|
433 | # Copy executables to modipsl/bin directory |
---|
434 | if [[ "$is_driver_opt" == "TRUE" ]] ; then |
---|
435 | cp bin/dim2_driver.exe ../../bin/orchidee_ol |
---|
436 | cp bin/teststomate.exe ../../bin/teststomate |
---|
437 | cp bin/forcesoil.exe ../../bin/forcesoil |
---|
438 | fi |
---|
439 | |
---|
440 | |
---|