Conditionally Compiling Metacommands in FORTRAN Code

ID: Q49466

5.00 5.10 1.00 1.00a | 5.00 5.10 | 1.00 4.00

MS-DOS               | OS/2      | WINDOWS NT
kbprg

The information in this article applies to:

SUMMARY

You can conditionally compile metacommands in FORTRAN source code. However, you cannot use the /4cc compiler option switch to do so because the metacommand requires its dollar sign ($) in the first column of the source line while the /4cc switch requires a character specifier as the first character of the source line.

To conditionally compile code involving metacommands, use the $DEFINE metacommand or the /D compiler option switch with the $IF, $ELSEIF, $ELSE, and $ENDIF metacomands. For more information, see pages 281-284 and page 335 of the Microsoft FORTRAN "Reference" manual for versions 5.0 and 5.1 or the FORTRAN PowerStation Language Help.

MORE INFORMATION

The following code example demonstrates conditionally compiling code that includes metacommands.

Sample Code

C Compile options needed: See below

$IF DEFINED(L) $INCLUDE 'large.inc' $ELSE $INCLUDE 'medium.inc' $ENDIF

If the line "$DEFINE L" precedes this $IF block, the compiler includes the LARGE.INC file, otherwise the compiler includes the MEDIUM.INC file. This method provides the ability to hard code conditional changes.

To choose the version to compile from the command line, specify the /D compiler option switch to define the variable used in the $IF block. The /D option switch eliminates the need for the $DEFINE metacommand. In the previous example, to include the LARGE.INC file, use a compiler command line such as the following:

   fl /DL name.ext

Additional reference words: kbinf 5.00 5.10 1.00 4.00 KBCategory: kbprg KBSubcategory: FORTLngIss
Keywords          : kbFortranPS kbLangFortran 
Version           : 5.00 5.10 1.00 1.00a | 5.00 5.10
Platform          : MS-DOS NT OS/2 WINDOWS

Last Reviewed: May 2, 1998