1 | <!DOCTYPE html> |
---|
2 | <html> |
---|
3 | <head> |
---|
4 | <title>FCM: User Guide: Annex: Declarations in FCM 1 build configuration |
---|
5 | file</title> |
---|
6 | <meta name="author" content="FCM team" /> |
---|
7 | <meta name="viewport" content="width=device-width, initial-scale=1.0" /> |
---|
8 | <link rel="icon" href="../etc/fcm-icon.png" type="image/png" /> |
---|
9 | <link rel="shortcut icon" href="../etc/fcm-icon.png" type="image/png" /> |
---|
10 | <link href="../etc/bootstrap/css/bootstrap.min.css" rel="stylesheet" media="screen" /> |
---|
11 | <link href="../etc/fcm.css" rel="stylesheet" media="screen" /> |
---|
12 | </head> |
---|
13 | <body> |
---|
14 | <div class="navbar navbar-inverse"> |
---|
15 | <div class="container-fluid"> |
---|
16 | <div class="navbar-header"> |
---|
17 | <a class="navbar-brand" href=".."><span class="fcm-version">FCM</span></a> |
---|
18 | </div> |
---|
19 | <div class="collapse navbar-collapse"> |
---|
20 | <ul class="nav navbar-nav"> |
---|
21 | <li><a href="../installation/">Installation</a></li> |
---|
22 | |
---|
23 | <li><a class="active" href="#">User Guide</a></li> |
---|
24 | </ul> |
---|
25 | </div> |
---|
26 | </div> |
---|
27 | </div> |
---|
28 | |
---|
29 | <div class="page-header"> |
---|
30 | <div class="fcm-page-content pull-right well well-sm"></div> |
---|
31 | <h1>FCM: User Guide: Annex: Declarations in FCM 1 build configuration |
---|
32 | file</h1> |
---|
33 | </div> |
---|
34 | |
---|
35 | <div class="container"> |
---|
36 | <div class="row"> |
---|
37 | <div class="col-md-12"> |
---|
38 | |
---|
39 | <p><em>The FCM 1 build system is deprecated. The documentation for the current |
---|
40 | build system can be found at <a href="make.html">FCM Make</a>.</em></p> |
---|
41 | |
---|
42 | <p>The following is a list of supported declarations for the configuration |
---|
43 | file used by the FCM build system. Unless otherwise stated, the fields in all |
---|
44 | declaration labels are not case sensitive. Build declarations can be made |
---|
45 | either in a build configuration file or in an extract configuration file. In |
---|
46 | the latter case, the prefix <code>BLD::</code> must be added at the beginning |
---|
47 | of each label to inform the extract system that the declaration is a build |
---|
48 | system declaration. (In a build configuration file, the prefix |
---|
49 | <code>BLD::</code> is optional.)</p> |
---|
50 | |
---|
51 | <dl> |
---|
52 | <dt>CFG::TYPE</dt> |
---|
53 | |
---|
54 | <dd> |
---|
55 | <p>The configuration file type, the value should always be |
---|
56 | <samp>bld</samp> for a build configuration file. This declaration is |
---|
57 | compulsory for all build configuration files. (This declaration is |
---|
58 | automatic when the extract system creates a build configuration |
---|
59 | file.)</p> |
---|
60 | |
---|
61 | <p>Example:</p> |
---|
62 | <pre> |
---|
63 | cfg::type bld |
---|
64 | </pre> |
---|
65 | </dd> |
---|
66 | |
---|
67 | <dt>CFG::VERSION</dt> |
---|
68 | |
---|
69 | <dd> |
---|
70 | <p>The file format version, currently <samp>1.0</samp> - a version is |
---|
71 | included so that we shall be able to read the configuration file |
---|
72 | correctly should we decide to change its format in the future. (This |
---|
73 | declaration is automatic when the extract system creates a build |
---|
74 | configuration file.)</p> |
---|
75 | |
---|
76 | <p>Example:</p> |
---|
77 | <pre> |
---|
78 | cfg::version 1.0 |
---|
79 | </pre> |
---|
80 | </dd> |
---|
81 | |
---|
82 | <dt>%<name></dt> |
---|
83 | |
---|
84 | <dd> |
---|
85 | <p><code>%<name></code> declares an internal variable |
---|
86 | <var><name></var> that can later be re-used.</p> |
---|
87 | |
---|
88 | <p>Example:</p> |
---|
89 | <pre> |
---|
90 | %my_variable -foo -bar |
---|
91 | tool::fflags %my_variable |
---|
92 | tool::cflags %my_variable |
---|
93 | </pre> |
---|
94 | </dd> |
---|
95 | |
---|
96 | <dt>INC</dt> |
---|
97 | |
---|
98 | <dd> |
---|
99 | <p>This declares the name of a file containing build configuration. The |
---|
100 | lines in the declared file will be included inline to the current |
---|
101 | configuration file.</p> |
---|
102 | |
---|
103 | <p>Example:</p> |
---|
104 | <pre> |
---|
105 | inc ~frva/var_stable_22.0/cfg/bld.cfg |
---|
106 | # ... and then your changes ... |
---|
107 | </pre> |
---|
108 | </dd> |
---|
109 | |
---|
110 | <dt> |
---|
111 | DEST[::ROOTDIR]<br /> |
---|
112 | <del>DIR::ROOT</del> |
---|
113 | </dt> |
---|
114 | |
---|
115 | <dd> |
---|
116 | <p>The destination of the build. It must be declared for each build. |
---|
117 | (This declaration is automatic when the extract system creates a build |
---|
118 | configuration file. The value is normally the path of the extract |
---|
119 | destination.)</p> |
---|
120 | |
---|
121 | <p>Example:</p> |
---|
122 | <pre> |
---|
123 | dest $HOME/my_build |
---|
124 | </pre> |
---|
125 | </dd> |
---|
126 | |
---|
127 | <dt>USE</dt> |
---|
128 | |
---|
129 | <dd> |
---|
130 | <p>This inherits settings from a previous build. The value must be must |
---|
131 | be either the configuration file or the root directory of a successful |
---|
132 | build. Output of the build, the tools, the exclude dependency |
---|
133 | declarations, the file type registers declarations are automatically |
---|
134 | inherited from the declared build. Source directories and build targets |
---|
135 | declarations may be inherited depending on the INHERIT declarations. (If |
---|
136 | you have a USE declaration in an extract, the resulting build |
---|
137 | configuration file will contain an automatic USE declaration, which |
---|
138 | expects an inherited build at the extract destination.)</p> |
---|
139 | |
---|
140 | <p>Example:</p> |
---|
141 | <pre> |
---|
142 | # Use VAR build 22.0 |
---|
143 | USE ~frva/var_22.0 |
---|
144 | </pre> |
---|
145 | </dd> |
---|
146 | |
---|
147 | <dt>INHERIT::<name>[::<pcks>]</dt> |
---|
148 | |
---|
149 | <dd> |
---|
150 | <p>This declares whether build targets (<name> = |
---|
151 | <samp>target</samp>) or source directories (<name> = |
---|
152 | <samp>src</samp>) can be inherited using the USE statement. By default, |
---|
153 | source directories are inherited, while build targets are not. Use the |
---|
154 | value <samp>true</samp> to switch on inheritance, or <samp>false</samp> |
---|
155 | to switch off. For source directories declarations, the name of a |
---|
156 | sub-package <pcks> can be specified. If a sub-package pcks is |
---|
157 | specified, the declaration applies only to the files and directories |
---|
158 | under the sub-package. Otherwise, the declaration applies globally.</p> |
---|
159 | |
---|
160 | <p>Example:</p> |
---|
161 | <pre> |
---|
162 | inherit::target true |
---|
163 | inherit::src false |
---|
164 | </pre> |
---|
165 | </dd> |
---|
166 | |
---|
167 | <dt>SRC[::<pcks>]</dt> |
---|
168 | |
---|
169 | <dd> |
---|
170 | <p>This declares a source file/directory. You must specify the |
---|
171 | sub-package <pcks> if the source file/directory is located outside |
---|
172 | of the <samp>src/</samp> sub-directory of the build destination or if you |
---|
173 | want to redefine the sub-package name of the source file/directory. The |
---|
174 | name of the sub-package <pcks> must be unique. Package names are |
---|
175 | delimited by double colons <code>::</code> or double underscores |
---|
176 | <code>__</code>. If you declare a relative path, it is assumed to be |
---|
177 | relative to the <samp>src/</samp> sub-directory of the build destination. |
---|
178 | (This declaration is automatic when the extract system creates the build |
---|
179 | configuration file. The list of declared source directories will be the |
---|
180 | list of extracted source directories.)</p> |
---|
181 | |
---|
182 | <p>Example:</p> |
---|
183 | <pre> |
---|
184 | src::var/code/VarMod_PF $HOME/var/src/code/VarMod_PF |
---|
185 | </pre> |
---|
186 | </dd> |
---|
187 | |
---|
188 | <dt>SEARCH_SRC</dt> |
---|
189 | |
---|
190 | <dd> |
---|
191 | <p>This declares a flag to determine whether the build system should |
---|
192 | search the <samp>src/</samp> sub-directory of the build root for a list |
---|
193 | of source files. The automatic search is useful if the build system is |
---|
194 | invoked standalone and the <samp>src/</samp> sub-directory contains the |
---|
195 | full source tree of the build. The default is to search |
---|
196 | (<samp>true</samp>). Set the flag to <samp>false</samp> to switch off the |
---|
197 | behaviour. (When the extract system creates a build configuration file, |
---|
198 | it declares all source files. Searching of the source sub-directory |
---|
199 | should not be required, and so this flag is automatically set to |
---|
200 | <samp>false</samp>.)</p> |
---|
201 | |
---|
202 | <p>Example:</p> |
---|
203 | <pre> |
---|
204 | search_src false |
---|
205 | </pre> |
---|
206 | </dd> |
---|
207 | |
---|
208 | <dt>TARGET</dt> |
---|
209 | |
---|
210 | <dd> |
---|
211 | <p>Specify the targets for the build. Multiple targets can be declared in |
---|
212 | one or more declarations. These targets become the dependencies of the |
---|
213 | default <samp>all</samp> target in the <em>Makefile</em>. It is worth |
---|
214 | noting that <code>TARGET</code> declarations are cumulative. A later |
---|
215 | declaration does not override an earlier one - it simply adds more targets |
---|
216 | to the list.</p> |
---|
217 | |
---|
218 | <p>Example:</p> |
---|
219 | <pre> |
---|
220 | target VarScr_AnalysePF VarScr_CovAccStats |
---|
221 | target VarScr_CovPFstats |
---|
222 | </pre> |
---|
223 | </dd> |
---|
224 | |
---|
225 | <dt>TOOL::<label>[::<pcks>]</dt> |
---|
226 | |
---|
227 | <dd> |
---|
228 | <p>This declaration is used to specify a build tool such as the Fortran |
---|
229 | compiler or its flags. The <label> determines the tool you are |
---|
230 | declaring. A TOOL declaration normally applies globally. However, where |
---|
231 | it is sensible to do so, a sub-package <pcks> can be specified. In |
---|
232 | which case, the declaration applies only to the files and directories |
---|
233 | under the sub-package. A list of <label> fields is available |
---|
234 | <a href="#tools-list">later in this annex</a>.</p> |
---|
235 | |
---|
236 | <p>Example:</p> |
---|
237 | <pre> |
---|
238 | tool::fc sxmpif90 |
---|
239 | tool::fflags -Chopt -Pstack |
---|
240 | |
---|
241 | tool::cc sxmpic++ |
---|
242 | tool::cflags -O nomsg -pvctl nomsg |
---|
243 | |
---|
244 | tool::ar sxar |
---|
245 | </pre> |
---|
246 | </dd> |
---|
247 | |
---|
248 | <dt>EXE_DEP[::<target>]</dt> |
---|
249 | |
---|
250 | <dd> |
---|
251 | <p>This declares an extra dependency for either all main program targets |
---|
252 | or only <target> if it is specified. If <target> is |
---|
253 | specified, it must be the name of a main program target. The value of the |
---|
254 | declaration is a space delimited list. Each item in the list can either |
---|
255 | be a valid name of a sub-package or the name of a valid object target. If |
---|
256 | a sub-package name is used, the <em>make</em> rule for the main program |
---|
257 | will be set to depend on all (non-program) object files within the |
---|
258 | sub-package.</p> |
---|
259 | |
---|
260 | <p>Example:</p> |
---|
261 | <pre> |
---|
262 | # Only foo.exe to depend on the package foo::bar and egg.o |
---|
263 | exe_dep::foo.exe foo::bar egg.o |
---|
264 | |
---|
265 | # All executables to depend on the package foo::bar and egg.o |
---|
266 | exe_dep foo::bar egg.o |
---|
267 | |
---|
268 | # Only foo.exe to depend on all objects |
---|
269 | exe_dep::foo.exe |
---|
270 | |
---|
271 | # All executables to depend on all objects |
---|
272 | exe_dep |
---|
273 | </pre> |
---|
274 | </dd> |
---|
275 | |
---|
276 | <dt>BLOCKDATA[::<target>]</dt> |
---|
277 | |
---|
278 | <dd> |
---|
279 | <p>This declares a BLOCKDATA dependency for either all main program |
---|
280 | targets or only <target> if it is specified. If <target> is |
---|
281 | specified, it must be the name of a main program target. The value of the |
---|
282 | declaration is a space delimited list. Each item in the list must be the |
---|
283 | name of a valid object target containing a Fortran BLOCKDATA program |
---|
284 | unit.</p> |
---|
285 | |
---|
286 | <p>Example:</p> |
---|
287 | <pre> |
---|
288 | # Only foo.exe to depend on blkdata.o |
---|
289 | blockdata::foo.exe blkdata.o |
---|
290 | |
---|
291 | # All executables to depend on fbd.o |
---|
292 | blockdata fbd.o |
---|
293 | </pre> |
---|
294 | </dd> |
---|
295 | |
---|
296 | <dt>EXCL_DEP[::<pcks>]</dt> |
---|
297 | |
---|
298 | <dd> |
---|
299 | <p>This declaration is used to specify whether a particular dependency |
---|
300 | should be ignored during the automatic dependency scan. If a sub-package |
---|
301 | <pcks> is specified, the declaration applies only to the files and |
---|
302 | directories under the sub-package. Otherwise, the declaration applies |
---|
303 | globally. The value of this declaration must contain one or two fields |
---|
304 | (separated by the double colon <code>::</code>). The first field denotes |
---|
305 | the dependency type, and the second field is the dependency target. If |
---|
306 | the second field is specified, it will only exclude the dependency to the |
---|
307 | specified target. Otherwise, it will exclude all dependency to the |
---|
308 | specified type. The following dependency types are supported:</p> |
---|
309 | |
---|
310 | <dl id="dependency-types"> |
---|
311 | <dt>USE</dt> |
---|
312 | |
---|
313 | <dd>The dependency target is a Fortran module.</dd> |
---|
314 | |
---|
315 | <dt>INTERFACE</dt> |
---|
316 | |
---|
317 | <dd>The dependency target is a Fortran 9X interface block file.</dd> |
---|
318 | |
---|
319 | <dt>INC</dt> |
---|
320 | |
---|
321 | <dd>The dependency target is a Fortran INCLUDE file.</dd> |
---|
322 | |
---|
323 | <dt>H</dt> |
---|
324 | |
---|
325 | <dd>The dependency target is a pre-processor #include header file.</dd> |
---|
326 | |
---|
327 | <dt>OBJ</dt> |
---|
328 | |
---|
329 | <dd>The dependency target is a compiled binary object file.</dd> |
---|
330 | |
---|
331 | <dt>EXE</dt> |
---|
332 | |
---|
333 | <dd>The dependency target is an executable binary or script.</dd> |
---|
334 | </dl> |
---|
335 | |
---|
336 | <p>N.B. The following dependency targets are in the default list of |
---|
337 | excluded dependencies:</p> |
---|
338 | |
---|
339 | <dl> |
---|
340 | <dt>Intrinsic Fortran modules:</dt> |
---|
341 | |
---|
342 | <dd> |
---|
343 | <ul> |
---|
344 | <li>USE::ISO_C_BINDING</li> |
---|
345 | |
---|
346 | <li>USE::IEEE_EXCEPTIONS</li> |
---|
347 | |
---|
348 | <li>USE::IEEE_ARITHMETIC</li> |
---|
349 | |
---|
350 | <li>USE::IEEE_FEATURES</li> |
---|
351 | </ul> |
---|
352 | </dd> |
---|
353 | |
---|
354 | <dt>Intrinsic Fortran subroutines:</dt> |
---|
355 | |
---|
356 | <dd> |
---|
357 | <ul> |
---|
358 | <li>OBJ::CPU_TIME</li> |
---|
359 | |
---|
360 | <li>OBJ::GET_COMMAND</li> |
---|
361 | |
---|
362 | <li>OBJ::GET_COMMAND_ARGUMENT</li> |
---|
363 | |
---|
364 | <li>OBJ::GET_ENVIRONMENT_VARIABLE</li> |
---|
365 | |
---|
366 | <li>OBJ::MOVE_ALLOC</li> |
---|
367 | |
---|
368 | <li>OBJ::MVBITS</li> |
---|
369 | |
---|
370 | <li>OBJ::RANDOM_NUMBER</li> |
---|
371 | |
---|
372 | <li>OBJ::RANDOM_SEED</li> |
---|
373 | |
---|
374 | <li>OBJ::SYSTEM_CLOCK</li> |
---|
375 | </ul> |
---|
376 | </dd> |
---|
377 | |
---|
378 | <dt>Dummy declarations:</dt> |
---|
379 | |
---|
380 | <dd> |
---|
381 | <ul> |
---|
382 | <li>OBJ::NONE</li> |
---|
383 | |
---|
384 | <li>EXE::NONE</li> |
---|
385 | </ul> |
---|
386 | </dd> |
---|
387 | </dl> |
---|
388 | |
---|
389 | <p>Example:</p> |
---|
390 | <pre> |
---|
391 | excl_dep USE::YourFortranMod |
---|
392 | excl_dep INTERFACE::HerFortran.interface |
---|
393 | excl_dep INC::HisFortranInc.inc |
---|
394 | excl_dep H::TheirHeader.h |
---|
395 | excl_dep OBJ |
---|
396 | excl_dep EXE |
---|
397 | </pre> |
---|
398 | </dd> |
---|
399 | |
---|
400 | <dt>DEP::<pcks></dt> |
---|
401 | |
---|
402 | <dd> |
---|
403 | <p>This declaration is used to specify a dependency for a source file in |
---|
404 | <pcks>. The value of this declaration must contain two fields |
---|
405 | (separated by the double colon <code>::</code>). The first field denotes |
---|
406 | the dependency type, and the second field is the dependency target. The |
---|
407 | dependency types are the same as those for EXCL_DEP described <a href= |
---|
408 | "#dependency-types">above</a>.</p> |
---|
409 | |
---|
410 | <p>Example:</p> |
---|
411 | <pre> |
---|
412 | dep::foo/bar.f USE::your_fortran_mod |
---|
413 | dep::foo/bar.f INTERFACE::her_fortran.interface |
---|
414 | dep::foo/bar.f INC::his_fortran_inc.inc |
---|
415 | dep::foo/bar.f H::their_header.h |
---|
416 | dep::foo/bar.f OBJ::its_object.o |
---|
417 | dep::foo/egg EXE::ham |
---|
418 | </pre> |
---|
419 | </dd> |
---|
420 | |
---|
421 | <dt>NO_DEP::<pcks></dt> |
---|
422 | |
---|
423 | <dd> |
---|
424 | <p>This declaration is used to switch off/on dependency checking. If |
---|
425 | <pcks> is specified in the label, the declaration applies to the |
---|
426 | specified sub-package only.</p> |
---|
427 | |
---|
428 | <p>Example:</p> |
---|
429 | <pre> |
---|
430 | # Switch on dependency checking only for "foo" |
---|
431 | no_dep true |
---|
432 | no_dep::foo false |
---|
433 | </pre> |
---|
434 | </dd> |
---|
435 | |
---|
436 | <dt>EXE_NAME::<name></dt> |
---|
437 | |
---|
438 | <dd> |
---|
439 | <p>This renames the executable target of a main program source file |
---|
440 | <name> to the specified value.</p> |
---|
441 | |
---|
442 | <p>Example:</p> |
---|
443 | <pre> |
---|
444 | # Rename executable target of foo.f90 from "foo.exe" to "bar" |
---|
445 | exe_name::foo bar |
---|
446 | </pre> |
---|
447 | </dd> |
---|
448 | |
---|
449 | <dt>LIB[::<pcks>]</dt> |
---|
450 | |
---|
451 | <dd> |
---|
452 | <p>This declares the name of a library archive target. If <pcks> is |
---|
453 | specified in the label, the declaration applies to the library archive |
---|
454 | target for that sub-package only. If set, the name of the library archive |
---|
455 | target will be named <samp>lib<value>.a</samp>, where <value> |
---|
456 | is the value of the declaration. If not specified, the default is to name |
---|
457 | the global library <samp>libfcm_default.a</samp>. For a library archive |
---|
458 | of a sub-package, the default is to name its library after the name of |
---|
459 | the sub-package.</p> |
---|
460 | |
---|
461 | <p>Example:</p> |
---|
462 | <pre> |
---|
463 | # Rename the top level library "libfoo.a" |
---|
464 | lib foo |
---|
465 | |
---|
466 | # Rename the library for the sub-package "egg::ham" |
---|
467 | # from "libegg__ham.a" to "libegg-ham.a" |
---|
468 | lib::egg/ham egg-ham |
---|
469 | </pre> |
---|
470 | </dd> |
---|
471 | |
---|
472 | <dt>PP[::<pcks>]</dt> |
---|
473 | |
---|
474 | <dd> |
---|
475 | <p>This declares whether a pre-processing stage is required. To switch on |
---|
476 | pre-processing, set the value to <samp>true</samp>. If <pcks> is |
---|
477 | specified in the label, the flag applies to the files within that |
---|
478 | sub-package only. Otherwise, the flag affects source directories in all |
---|
479 | packages. The pre-processing stage is useful if the pre-processor changes |
---|
480 | the dependency and/or the argument list of the source files. The default |
---|
481 | behaviour is skip the pre-processing stage for all source.</p> |
---|
482 | |
---|
483 | <p>Example:</p> |
---|
484 | <pre> |
---|
485 | pp::gen true # switch on pre-processing for "gen" only |
---|
486 | pp true # switch on pre-processing globally |
---|
487 | </pre> |
---|
488 | </dd> |
---|
489 | |
---|
490 | <dt>SRC_TYPE::<pcks></dt> |
---|
491 | |
---|
492 | <dd> |
---|
493 | <p>This declaration is used to (re-)register the file type of the |
---|
494 | sub-package <pcks> to associate with different file types. The |
---|
495 | value of the declaration is a list of type flags delimited by the double |
---|
496 | colon <code>::</code>. Each type flag is used internally to describe the |
---|
497 | nature of the file. For example, a Fortran free source form containing a |
---|
498 | main program is registered as |
---|
499 | <code>FORTRAN::FORTRAN9X::SOURCE::PROGRAM</code>. A list of type flags is |
---|
500 | available <a href="#infile-ext-types">later in this annex</a>.</p> |
---|
501 | |
---|
502 | <p>Example:</p> |
---|
503 | <pre> |
---|
504 | src_type::foo/bar.f FORTRAN::FORTRAN9X::SOURCE::PROGRAM |
---|
505 | </pre> |
---|
506 | </dd> |
---|
507 | |
---|
508 | <dt>INFILE_EXT::<ext></dt> |
---|
509 | |
---|
510 | <dd> |
---|
511 | <p>This declaration is used to re-register particular file name |
---|
512 | extensions <ext> to associate with different file types. The value |
---|
513 | of the declaration has a similar format to that of SRC_TYPE declaration |
---|
514 | described above. A list of type flags is available <a href= |
---|
515 | "#infile-ext-types">later in this annex</a>.</p> |
---|
516 | |
---|
517 | <p>Example:</p> |
---|
518 | <pre> |
---|
519 | infile_ext::h90 CPP::INCLUDE |
---|
520 | infile_ext::inc FORTRAN::FORTRAN9X::INCLUDE |
---|
521 | </pre> |
---|
522 | </dd> |
---|
523 | |
---|
524 | <dt>OUTFILE_EXT::<type></dt> |
---|
525 | |
---|
526 | <dd> |
---|
527 | <p>This declaration is used to re-register the output file extension for |
---|
528 | a particular <type> of output files. The value must be a valid file |
---|
529 | extension. The following is a list of output file types in-use by the |
---|
530 | build system:</p> |
---|
531 | |
---|
532 | <dl id="outfile-ext-types"> |
---|
533 | <dt>OBJ</dt> |
---|
534 | |
---|
535 | <dd>compiled object files<br /> |
---|
536 | [default = .o]</dd> |
---|
537 | |
---|
538 | <dt>MOD</dt> |
---|
539 | |
---|
540 | <dd>compiled Fortran module information files<br /> |
---|
541 | [default = .mod]</dd> |
---|
542 | |
---|
543 | <dt>EXE</dt> |
---|
544 | |
---|
545 | <dd>binary executables<br /> |
---|
546 | [default = .exe]</dd> |
---|
547 | |
---|
548 | <dt>DONE</dt> |
---|
549 | |
---|
550 | <dd><em>done</em> files for compiled source<br /> |
---|
551 | [default = .done]</dd> |
---|
552 | |
---|
553 | <dt>IDONE</dt> |
---|
554 | |
---|
555 | <dd><em>done</em> files for included source<br /> |
---|
556 | [default = .idone]</dd> |
---|
557 | |
---|
558 | <dt>FLAGS</dt> |
---|
559 | |
---|
560 | <dd><em>flags</em> files, compiler flags config<br /> |
---|
561 | [default = .flags]</dd> |
---|
562 | |
---|
563 | <dt>INTERFACE</dt> |
---|
564 | |
---|
565 | <dd>interface files for F9X standalone subroutines/functions<br /> |
---|
566 | [default = .interface]</dd> |
---|
567 | |
---|
568 | <dt>LIB</dt> |
---|
569 | |
---|
570 | <dd>archive object library<br /> |
---|
571 | [default = .a]</dd> |
---|
572 | |
---|
573 | <dt>TAR</dt> |
---|
574 | |
---|
575 | <dd>TAR archive<br /> |
---|
576 | [default = .tar]</dd> |
---|
577 | </dl> |
---|
578 | |
---|
579 | <p>Example:</p> |
---|
580 | <pre> |
---|
581 | # Output F9X interface files will now have ".foo" extension |
---|
582 | outfile_ext::interface .foo |
---|
583 | </pre> |
---|
584 | </dd> |
---|
585 | </dl> |
---|
586 | |
---|
587 | <p id="tools-list">The following is a list of <label> fields that can |
---|
588 | be used with a <code>TOOL</code> declaration. Those marked with an asterisk |
---|
589 | (*) accept declarations at sub-package levels.</p> |
---|
590 | |
---|
591 | <dl> |
---|
592 | <dt>FC</dt> |
---|
593 | |
---|
594 | <dd>The Fortran compiler.<br /> |
---|
595 | [default = <samp>f90</samp>]</dd> |
---|
596 | |
---|
597 | <dt>FFLAGS *</dt> |
---|
598 | |
---|
599 | <dd>Options used by the Fortran compiler.<br /> |
---|
600 | [default = ""]</dd> |
---|
601 | |
---|
602 | <dt>FC_COMPILE</dt> |
---|
603 | |
---|
604 | <dd>The option used by the Fortran compiler to suppress the linking |
---|
605 | stage.<br /> |
---|
606 | [default = <samp>-c</samp>]</dd> |
---|
607 | |
---|
608 | <dt>FC_INCLUDE</dt> |
---|
609 | |
---|
610 | <dd>The option used by the Fortran compiler to specify the include search |
---|
611 | path.<br /> |
---|
612 | [default = <samp>-I</samp>]</dd> |
---|
613 | |
---|
614 | <dt>FC_MODSEARCH</dt> |
---|
615 | |
---|
616 | <dd>The option used by the Fortran compiler to specify the search |
---|
617 | path for the compiled module definition files. This option is often |
---|
618 | unnecessary as it is normally covered by the include search path.<br /> |
---|
619 | [default = ""]</dd> |
---|
620 | |
---|
621 | <dt>FC_DEFINE</dt> |
---|
622 | |
---|
623 | <dd>The option used by the Fortran compiler to define a pre-processor |
---|
624 | definition macro.<br /> |
---|
625 | [default = <samp>-D</samp>]</dd> |
---|
626 | |
---|
627 | <dt>FC_OUTPUT</dt> |
---|
628 | |
---|
629 | <dd>The option used by the Fortran compiler to specify the output file |
---|
630 | name.<br /> |
---|
631 | [default = <samp>-o</samp>]</dd> |
---|
632 | |
---|
633 | <dt>CC</dt> |
---|
634 | |
---|
635 | <dd>The C compiler.<br /> |
---|
636 | [default = <samp>cc</samp>]</dd> |
---|
637 | |
---|
638 | <dt>CFLAGS *</dt> |
---|
639 | |
---|
640 | <dd>Options used by the C compiler.<br /> |
---|
641 | [default = ""]</dd> |
---|
642 | |
---|
643 | <dt>CC_COMPILE</dt> |
---|
644 | |
---|
645 | <dd>The option used by the C compiler to suppress the linking stage.<br /> |
---|
646 | [default = <samp>-c</samp>]</dd> |
---|
647 | |
---|
648 | <dt>CC_INCLUDE</dt> |
---|
649 | |
---|
650 | <dd>The option used by the C compiler to specify the include search |
---|
651 | path.<br /> |
---|
652 | [default = <samp>-I</samp>]</dd> |
---|
653 | |
---|
654 | <dt>CC_DEFINE</dt> |
---|
655 | |
---|
656 | <dd>The option used by the C compiler to define a pre-processor definition |
---|
657 | macro.<br /> |
---|
658 | [default = <samp>-D</samp>]</dd> |
---|
659 | |
---|
660 | <dt>CC_OUTPUT</dt> |
---|
661 | |
---|
662 | <dd>The option used by the C compiler to specify the output file |
---|
663 | name.<br /> |
---|
664 | [default = <samp>-o</samp>]</dd> |
---|
665 | |
---|
666 | <dt>LD *</dt> |
---|
667 | |
---|
668 | <dd>Name of the linker or loader for linking object files into an |
---|
669 | executable. If not set, use the compiler of the source file containing the |
---|
670 | main program.<br /> |
---|
671 | [default = ""]</dd> |
---|
672 | |
---|
673 | <dt>LDFLAGS *</dt> |
---|
674 | |
---|
675 | <dd>The flags used by the linker or loader.<br /> |
---|
676 | [default = ""]</dd> |
---|
677 | |
---|
678 | <dt>LD_OUTPUT</dt> |
---|
679 | |
---|
680 | <dd>The option used by the linker or loader for the output file name (other |
---|
681 | than the default <samp>a.out</samp>).<br /> |
---|
682 | [default = <samp>-o</samp>]</dd> |
---|
683 | |
---|
684 | <dt>LD_LIBSEARCH</dt> |
---|
685 | |
---|
686 | <dd>The option used by the linker or loader for specifying the search path |
---|
687 | for link libraries.<br /> |
---|
688 | [default = <samp>-L</samp>]</dd> |
---|
689 | |
---|
690 | <dt>LD_LIBLINK</dt> |
---|
691 | |
---|
692 | <dd>The option used by the linker or loader command for linking with a |
---|
693 | library.<br /> |
---|
694 | [default = <samp>-l</samp>]</dd> |
---|
695 | |
---|
696 | <dt>AR</dt> |
---|
697 | |
---|
698 | <dd>The archive command.<br /> |
---|
699 | [default = <samp>ar</samp>]</dd> |
---|
700 | |
---|
701 | <dt>ARFLAGS</dt> |
---|
702 | |
---|
703 | <dd>The options used for the archive command to create a library.<br /> |
---|
704 | [default = <samp>rs</samp>]</dd> |
---|
705 | |
---|
706 | <dt>FPP</dt> |
---|
707 | |
---|
708 | <dd>The Fortran pre-processor command.<br /> |
---|
709 | [default = <samp>cpp</samp>]</dd> |
---|
710 | |
---|
711 | <dt>FPPKEYS *</dt> |
---|
712 | |
---|
713 | <dd>The Fortran pre-processor will pre-define each word in this setting as |
---|
714 | a macro.<br /> |
---|
715 | [default = ""]</dd> |
---|
716 | |
---|
717 | <dt>FPPFLAGS *</dt> |
---|
718 | |
---|
719 | <dd>The options used by the Fortran pre-processor.<br /> |
---|
720 | [default = <samp>-P -traditional</samp>]</dd> |
---|
721 | |
---|
722 | <dt>FPP_DEFINE</dt> |
---|
723 | |
---|
724 | <dd>The option used by the Fortran pre-processor to define a macro.<br /> |
---|
725 | [default = <samp>-D</samp>]</dd> |
---|
726 | |
---|
727 | <dt>FPP_INCLUDE</dt> |
---|
728 | |
---|
729 | <dd>The option used by the Fortran pre-processor to specify the include |
---|
730 | search path.<br /> |
---|
731 | [default = <samp>-I</samp>]</dd> |
---|
732 | |
---|
733 | <dt>CPP</dt> |
---|
734 | |
---|
735 | <dd>The C pre-processor command.<br /> |
---|
736 | [default = <samp>cpp</samp>]</dd> |
---|
737 | |
---|
738 | <dt>CPPKEYS *</dt> |
---|
739 | |
---|
740 | <dd>The C pre-processor will pre-define each word in this setting as a |
---|
741 | macro.<br /> |
---|
742 | [default = ""]</dd> |
---|
743 | |
---|
744 | <dt>CPPFLAGS *</dt> |
---|
745 | |
---|
746 | <dd>The options used by the C pre-processor.<br /> |
---|
747 | [default = <samp>-C</samp>]</dd> |
---|
748 | |
---|
749 | <dt>CPP_DEFINE</dt> |
---|
750 | |
---|
751 | <dd>The option used by the C pre-processor to define a macro.<br /> |
---|
752 | [default = <samp>-D</samp>]</dd> |
---|
753 | |
---|
754 | <dt>CPP_INCLUDE</dt> |
---|
755 | |
---|
756 | <dd>The option used by the C pre-processor to specify the include search |
---|
757 | path.<br /> |
---|
758 | [default = <samp>-I</samp>]</dd> |
---|
759 | |
---|
760 | <dt>MAKE</dt> |
---|
761 | |
---|
762 | <dd>The <code>make</code> command.<br /> |
---|
763 | [default = <samp>make</samp>]</dd> |
---|
764 | |
---|
765 | <dt>MAKEFLAGS</dt> |
---|
766 | |
---|
767 | <dd>The options used by the <code>make</code> command.<br /> |
---|
768 | [default = ""]</dd> |
---|
769 | |
---|
770 | <dt>MAKE_SILENT</dt> |
---|
771 | |
---|
772 | <dd>The option used by the <code>make</code> command to specify silent |
---|
773 | operation.<br /> |
---|
774 | [default = <samp>-s</samp>]</dd> |
---|
775 | |
---|
776 | <dt>MAKE_JOB</dt> |
---|
777 | |
---|
778 | <dd>The option used by the <code>make</code> command to specify the number |
---|
779 | jobs to run simultaneously.<br /> |
---|
780 | [default = <samp>-j</samp>]</dd> |
---|
781 | |
---|
782 | <dt>GENINTERFACE *</dt> |
---|
783 | |
---|
784 | <dd>The command/method to extract the calling interfaces of top level |
---|
785 | subroutines and functions in a Fortran 9X source. Supported values are |
---|
786 | <samp>f90aib</samp> and <samp>none</samp> (to switch off interface |
---|
787 | generation). If not specified, the system will use its own internal logic. |
---|
788 | <br /> |
---|
789 | [default = (not specified)]</dd> |
---|
790 | |
---|
791 | <dt>INTERFACE *</dt> |
---|
792 | |
---|
793 | <dd>Generate Fortran 9X interface files with root names according to either |
---|
794 | the root name of the source <samp>file</samp> or the name of the |
---|
795 | <samp>program</samp> unit.<br /> |
---|
796 | [default = <samp>file</samp>]</dd> |
---|
797 | </dl> |
---|
798 | |
---|
799 | <p id="infile-ext-types">The following is a list of type flags that are |
---|
800 | currently in-use (or <dfn>* reserved</dfn>) by the build system for TYPE and |
---|
801 | INFILE_EXT declarations:</p> |
---|
802 | |
---|
803 | <dl> |
---|
804 | <dt>SOURCE</dt> |
---|
805 | |
---|
806 | <dd>a source file containing program code of a supported language |
---|
807 | (currently Fortran, FPP, C and CPP).</dd> |
---|
808 | |
---|
809 | <dt>INCLUDE</dt> |
---|
810 | |
---|
811 | <dd>an include file containing program code of a supported language |
---|
812 | (currently Fortran, FPP, C and CPP).</dd> |
---|
813 | |
---|
814 | <dt>FORTRAN</dt> |
---|
815 | |
---|
816 | <dd>a file containing Fortran code.</dd> |
---|
817 | |
---|
818 | <dt>FORTRAN9X</dt> |
---|
819 | |
---|
820 | <dd>a file containing the Fortran free source form. This word must be used |
---|
821 | in conjunction with the word <code>FORTRAN</code>.</dd> |
---|
822 | |
---|
823 | <dt>FPP</dt> |
---|
824 | |
---|
825 | <dd>a file containing Fortran code requiring pre-processing.</dd> |
---|
826 | |
---|
827 | <dt>FPP9X</dt> |
---|
828 | |
---|
829 | <dd>a file containing Fortran free source form requiring pre-processing. |
---|
830 | This word must be used in conjunction with the word <code>FPP</code>.</dd> |
---|
831 | |
---|
832 | <dt>C</dt> |
---|
833 | |
---|
834 | <dd>a file containing C code.</dd> |
---|
835 | |
---|
836 | <dt>CPP</dt> |
---|
837 | |
---|
838 | <dd>a file containing CPP include header.</dd> |
---|
839 | |
---|
840 | <dt>INTERFACE</dt> |
---|
841 | |
---|
842 | <dd>a file containing a Fortran 9X interface block.</dd> |
---|
843 | |
---|
844 | <dt>PROGRAM</dt> |
---|
845 | |
---|
846 | <dd>a file containing a main program.</dd> |
---|
847 | |
---|
848 | <dt>MODULE</dt> |
---|
849 | |
---|
850 | <dd>a file containing a Fortran 9X module.</dd> |
---|
851 | |
---|
852 | <dt>BINARY</dt> |
---|
853 | |
---|
854 | <dd>a binary file.</dd> |
---|
855 | |
---|
856 | <dt>EXE</dt> |
---|
857 | |
---|
858 | <dd>an executable file. This word must be used in conjunction with the word |
---|
859 | <code>BINARY</code>.</dd> |
---|
860 | |
---|
861 | <dt>LIB</dt> |
---|
862 | |
---|
863 | <dd>an archive library. This word must be used in conjunction with the word |
---|
864 | <code>BINARY</code>.</dd> |
---|
865 | |
---|
866 | <dt>SCRIPT</dt> |
---|
867 | |
---|
868 | <dd>a file containing source code of a scripting language.</dd> |
---|
869 | |
---|
870 | <dt>PVWAVE</dt> |
---|
871 | |
---|
872 | <dd>a file containing executable PVWAVE scripts. This word must be used in |
---|
873 | conjunction with the word <code>SCRIPT</code>.</dd> |
---|
874 | |
---|
875 | <dt>SQL</dt> |
---|
876 | |
---|
877 | <dd>a file containing SQL scripts. This word must be used in conjunction |
---|
878 | with the word <code>SCRIPT</code>.</dd> |
---|
879 | |
---|
880 | <dt>GENLIST</dt> |
---|
881 | |
---|
882 | <dd>a GEN List file.</dd> |
---|
883 | |
---|
884 | <dt>OBJ</dt> |
---|
885 | |
---|
886 | <dd><dfn>(* reserved)</dfn> an object file. This word must be used in |
---|
887 | conjunction with the word <code>BINARY</code>.</dd> |
---|
888 | |
---|
889 | <dt>SHELL</dt> |
---|
890 | |
---|
891 | <dd><dfn>(* reserved)</dfn> a file containing executable shell scripts. |
---|
892 | This word must be used in conjunction with the word |
---|
893 | <code>SCRIPT</code>.</dd> |
---|
894 | |
---|
895 | <dt>PERL</dt> |
---|
896 | |
---|
897 | <dd><dfn>(* reserved)</dfn> a file containing executable Perl scripts. This |
---|
898 | word must be used in conjunction with the word <code>SCRIPT</code>.</dd> |
---|
899 | |
---|
900 | <dt>PYTHON</dt> |
---|
901 | |
---|
902 | <dd><dfn>(* reserved)</dfn> a file containing executable Python scripts. |
---|
903 | This word must be used in conjunction with the word |
---|
904 | <code>SCRIPT</code>.</dd> |
---|
905 | |
---|
906 | <dt>TCL</dt> |
---|
907 | |
---|
908 | <dd><dfn>(* reserved)</dfn> a file containing executable TCL scripts. This |
---|
909 | word must be used in conjunction with the word <code>SCRIPT</code>.</dd> |
---|
910 | </dl> |
---|
911 | |
---|
912 | </div> |
---|
913 | </div> |
---|
914 | </div> |
---|
915 | |
---|
916 | <hr/> |
---|
917 | <div class="container-fluid text-center"> |
---|
918 | <div class="row"><div class="col-md-12"> |
---|
919 | <address><small> |
---|
920 | Copyright © 2006-2021 British Crown (Met Office) & Contributors. |
---|
921 | <a href="http://www.metoffice.gov.uk">Met Office</a>. |
---|
922 | See <a href="../etc/fcm-terms-of-use.html">Terms of Use</a>.<br /> |
---|
923 | This document is released under the British <a href= |
---|
924 | "http://www.nationalarchives.gov.uk/doc/open-government-licence/" rel= |
---|
925 | "license">Open Government Licence</a>.<br /> |
---|
926 | </small></address> |
---|
927 | </div></div> |
---|
928 | </div> |
---|
929 | |
---|
930 | <script type="text/javascript" src="../etc/jquery.min.js"></script> |
---|
931 | <script type="text/javascript" src="../etc/bootstrap/js/bootstrap.min.js"></script> |
---|
932 | <script type="text/javascript" src="../etc/fcm.js"></script> |
---|
933 | <script type="text/javascript" src="../etc/fcm-version.js"></script> |
---|
934 | </body> |
---|
935 | </html> |
---|