Annotation of GNUtools/cc/cpp.info-1, revision 1.1.1.1

1.1       root        1: This is Info file cpp.info, produced by Makeinfo-1.54 from the input
                      2: file cpp.texi.
                      3: 
                      4:    This file documents the GNU C Preprocessor.
                      5: 
                      6:    Copyright 1987, 1989, 1991, 1992, 1993 Free Software Foundation, Inc.
                      7: 
                      8:    Permission is granted to make and distribute verbatim copies of this
                      9: manual provided the copyright notice and this permission notice are
                     10: preserved on all copies.
                     11: 
                     12:    Permission is granted to copy and distribute modified versions of
                     13: this manual under the conditions for verbatim copying, provided also
                     14: that the entire resulting derived work is distributed under the terms
                     15: of a permission notice identical to this one.
                     16: 
                     17:    Permission is granted to copy and distribute translations of this
                     18: manual into another language, under the above conditions for modified
                     19: versions.
                     20: 
                     21: 
                     22: File: cpp.info,  Node: Top,  Next: Global Actions,  Up: (DIR)
                     23: 
                     24: The C Preprocessor
                     25: ******************
                     26: 
                     27:    The C preprocessor is a "macro processor" that is used automatically
                     28: by the C compiler to transform your program before actual compilation.
                     29: It is called a macro processor because it allows you to define "macros",
                     30: which are brief abbreviations for longer constructs.
                     31: 
                     32:    The C preprocessor provides four separate facilities that you can
                     33: use as you see fit:
                     34: 
                     35:    * Inclusion of header files.  These are files of declarations that
                     36:      can be substituted into your program.
                     37: 
                     38:    * Macro expansion.  You can define "macros", which are abbreviations
                     39:      for arbitrary fragments of C code, and then the C preprocessor will
                     40:      replace the macros with their definitions throughout the program.
                     41: 
                     42:    * Conditional compilation.  Using special preprocessor commands, you
                     43:      can include or exclude parts of the program according to various
                     44:      conditions.
                     45: 
                     46:    * Line control.  If you use a program to combine or rearrange source
                     47:      files into an intermediate file which is then compiled, you can
                     48:      use line control to inform the compiler of where each source line
                     49:      originally came from.
                     50: 
                     51:    C preprocessors vary in some details.  This manual discusses the GNU
                     52: C preprocessor, the C Compatible Compiler Preprocessor.  The GNU C
                     53: preprocessor provides a superset of the features of ANSI Standard C.
                     54: 
                     55:    ANSI Standard C requires the rejection of many harmless constructs
                     56: commonly used by today's C programs.  Such incompatibility would be
                     57: inconvenient for users, so the GNU C preprocessor is configured to
                     58: accept these constructs by default.  Strictly speaking, to get ANSI
                     59: Standard C, you must use the options `-trigraphs', `-undef' and
                     60: `-pedantic', but in practice the consequences of having strict ANSI
                     61: Standard C make it undesirable to do this.  *Note Invocation::.
                     62: 
                     63: * Menu:
                     64: 
                     65: * Global Actions::    Actions made uniformly on all input files.
                     66: * Commands::          General syntax of preprocessor commands.
                     67: * Header Files::      How and why to use header files.
                     68: * Macros::            How and why to use macros.
                     69: * Conditionals::      How and why to use conditionals.
                     70: * Combining Sources:: Use of line control when you combine source files.
                     71: * Other Commands::    Miscellaneous preprocessor commands.
                     72: * Output::            Format of output from the C preprocessor.
                     73: * Invocation::        How to invoke the preprocessor; command options.
                     74: * Concept Index::     Index of concepts and terms.
                     75: * Index::             Index of commands, predefined macros and options.
                     76: 
                     77: 
                     78: File: cpp.info,  Node: Global Actions,  Next: Commands,  Prev: Top,  Up: Top
                     79: 
                     80: Transformations Made Globally
                     81: =============================
                     82: 
                     83:    Most C preprocessor features are inactive unless you give specific
                     84: commands to request their use.  (Preprocessor commands are lines
                     85: starting with `#'; *note Commands::.).  But there are three
                     86: transformations that the preprocessor always makes on all the input it
                     87: receives, even in the absence of commands.
                     88: 
                     89:    * All C comments are replaced with single spaces.
                     90: 
                     91:    * Backslash-Newline sequences are deleted, no matter where.  This
                     92:      feature allows you to break long lines for cosmetic purposes
                     93:      without changing their meaning.
                     94: 
                     95:    * Predefined macro names are replaced with their expansions (*note
                     96:      Predefined::.).
                     97: 
                     98:    The first two transformations are done *before* nearly all other
                     99: parsing and before preprocessor commands are recognized.  Thus, for
                    100: example, you can split a line cosmetically with Backslash-Newline
                    101: anywhere (except when trigraphs are in use; see below).
                    102: 
                    103:      /*
                    104:      */ # /*
                    105:      */ defi\
                    106:      ne FO\
                    107:      O 10\
                    108:      20
                    109: 
                    110: is equivalent into `#define FOO 1020'.  You can split even an escape
                    111: sequence with Backslash-Newline.  For example, you can split `"foo\bar"'
                    112: between the `\' and the `b' to get
                    113: 
                    114:      "foo\\
                    115:      bar"
                    116: 
                    117: This behavior is unclean: in all other contexts, a Backslash can be
                    118: inserted in a string constant as an ordinary character by writing a
                    119: double Backslash, and this creates an exception.  But the ANSI C
                    120: standard requires it.  (Strict ANSI C does not allow Newlines in string
                    121: constants, so they do not consider this a problem.)
                    122: 
                    123:    But there are a few exceptions to all three transformations.
                    124: 
                    125:    * C comments and predefined macro names are not recognized inside a
                    126:      `#include' command in which the file name is delimited with `<'
                    127:      and `>'.
                    128: 
                    129:    * C comments and predefined macro names are never recognized within a
                    130:      character or string constant.  (Strictly speaking, this is the
                    131:      rule, not an exception, but it is worth noting here anyway.)
                    132: 
                    133:    * Backslash-Newline may not safely be used within an ANSI "trigraph".
                    134:      Trigraphs are converted before Backslash-Newline is deleted.  If
                    135:      you write what looks like a trigraph with a Backslash-Newline
                    136:      inside, the Backslash-Newline is deleted as usual, but it is then
                    137:      too late to recognize the trigraph.
                    138: 
                    139:      This exception is relevant only if you use the `-trigraphs' option
                    140:      to enable trigraph processing.  *Note Invocation::.
                    141: 
                    142: 
                    143: File: cpp.info,  Node: Commands,  Next: Header Files,  Prev: Global Actions,  Up: Top
                    144: 
                    145: Preprocessor Commands
                    146: =====================
                    147: 
                    148:    Most preprocessor features are active only if you use preprocessor
                    149: commands to request their use.
                    150: 
                    151:    Preprocessor commands are lines in your program that start with `#'.
                    152: The `#' is followed by an identifier that is the "command name".  For
                    153: example, `#define' is the command that defines a macro.  Whitespace is
                    154: also allowed before and after the `#'.
                    155: 
                    156:    The set of valid command names is fixed.  Programs cannot define new
                    157: preprocessor commands.
                    158: 
                    159:    Some command names require arguments; these make up the rest of the
                    160: command line and must be separated from the command name by whitespace.
                    161: For example, `#define' must be followed by a macro name and the
                    162: intended expansion of the macro.
                    163: 
                    164:    A preprocessor command cannot be more than one line in normal
                    165: circumstances.  It may be split cosmetically with Backslash-Newline,
                    166: but that has no effect on its meaning.  Comments containing Newlines
                    167: can also divide the command into multiple lines, but the comments are
                    168: changed to Spaces before the command is interpreted.  The only way a
                    169: significant Newline can occur in a preprocessor command is within a
                    170: string constant or character constant.  Note that most C compilers that
                    171: might be applied to the output from the preprocessor do not accept
                    172: string or character constants containing Newlines.
                    173: 
                    174:    The `#' and the command name cannot come from a macro expansion.  For
                    175: example, if `foo' is defined as a macro expanding to `define', that
                    176: does not make `#foo' a valid preprocessor command.
                    177: 
                    178: 
                    179: File: cpp.info,  Node: Header Files,  Next: Macros,  Prev: Commands,  Up: Top
                    180: 
                    181: Header Files
                    182: ============
                    183: 
                    184:    A header file is a file containing C declarations and macro
                    185: definitions (*note Macros::.) to be shared between several source
                    186: files.  You request the use of a header file in your program with the C
                    187: preprocessor command `#include'.
                    188: 
                    189: * Menu:
                    190: 
                    191: * Header Uses::         What header files are used for.
                    192: * Include Syntax::      How to write `#include' commands.
                    193: * Include Operation::   What `#include' does.
                    194: * Once-Only::          Preventing multiple inclusion of one header file.
                    195: * Inheritance::         Including one header file in another header file.
                    196: 
                    197: 
                    198: File: cpp.info,  Node: Header Uses,  Next: Include Syntax,  Prev: Header Files,  Up: Header Files
                    199: 
                    200: Uses of Header Files
                    201: --------------------
                    202: 
                    203:    Header files serve two kinds of purposes.
                    204: 
                    205:    * System header files declare the interfaces to parts of the
                    206:      operating system.  You include them in your program to supply the
                    207:      definitions and declarations you need to invoke system calls and
                    208:      libraries.
                    209: 
                    210:    * Your own header files contain declarations for interfaces between
                    211:      the source files of your program.  Each time you have a group of
                    212:      related declarations and macro definitions all or most of which
                    213:      are needed in several different source files, it is a good idea to
                    214:      create a header file for them.
                    215: 
                    216:    Including a header file produces the same results in C compilation as
                    217: copying the header file into each source file that needs it.  But such
                    218: copying would be time-consuming and error-prone.  With a header file,
                    219: the related declarations appear in only one place.  If they need to be
                    220: changed, they can be changed in one place, and programs that include
                    221: the header file will automatically use the new version when next
                    222: recompiled.  The header file eliminates the labor of finding and
                    223: changing all the copies as well as the risk that a failure to find one
                    224: copy will result in inconsistencies within a program.
                    225: 
                    226:    The usual convention is to give header files names that end with
                    227: `.h'.
                    228: 
                    229: 
                    230: File: cpp.info,  Node: Include Syntax,  Next: Include Operation,  Prev: Header Uses,  Up: Header Files
                    231: 
                    232: The `#include' Command
                    233: ----------------------
                    234: 
                    235:    Both user and system header files are included using the preprocessor
                    236: command `#include'.  It has three variants:
                    237: 
                    238: `#include <FILE>'
                    239:      This variant is used for system header files.  It searches for a
                    240:      file named FILE in a list of directories specified by you, then in
                    241:      a standard list of system directories.  You specify directories to
                    242:      search for header files with the command option `-I' (*note
                    243:      Invocation::.).  The option `-nostdinc' inhibits searching the
                    244:      standard system directories; in this case only the directories you
                    245:      specify are searched.
                    246: 
                    247:      The parsing of this form of `#include' is slightly special because
                    248:      comments are not recognized within the `<...>'.  Thus, in
                    249:      `#include <x/*y>' the `/*' does not start a comment and the
                    250:      command specifies inclusion of a system header file named `x/*y'.
                    251:      Of course, a header file with such a name is unlikely to exist on
                    252:      Unix, where shell wildcard features would make it hard to
                    253:      manipulate.
                    254: 
                    255:      The argument FILE may not contain a `>' character.  It may,
                    256:      however, contain a `<' character.
                    257: 
                    258: `#include "FILE"'
                    259:      This variant is used for header files of your own program.  It
                    260:      searches for a file named FILE first in the current directory,
                    261:      then in the same directories used for system header files.  The
                    262:      current directory is the directory of the current input file.  It
                    263:      is tried first because it is presumed to be the location of the
                    264:      files that the current input file refers to.  (If the `-I-' option
                    265:      is used, the special treatment of the current directory is
                    266:      inhibited.)
                    267: 
                    268:      The argument FILE may not contain `"' characters.  If backslashes
                    269:      occur within FILE, they are considered ordinary text characters,
                    270:      not escape characters.  None of the character escape sequences
                    271:      appropriate to string constants in C are processed.  Thus,
                    272:      `#include "x\n\\y"' specifies a filename containing three
                    273:      backslashes.  It is not clear why this behavior is ever useful, but
                    274:      the ANSI standard specifies it.
                    275: 
                    276: `#include ANYTHING ELSE'
                    277:      This variant is called a "computed #include".  Any `#include'
                    278:      command whose argument does not fit the above two forms is a
                    279:      computed include.  The text ANYTHING ELSE is checked for macro
                    280:      calls, which are expanded (*note Macros::.).  When this is done,
                    281:      the result must fit one of the above two variants--in particular,
                    282:      the expanded text must in the end be surrounded by either quotes
                    283:      or angle braces.
                    284: 
                    285:      This feature allows you to define a macro which controls the file
                    286:      name to be used at a later point in the program.  One application
                    287:      of this is to allow a site-configuration file for your program to
                    288:      specify the names of the system include files to be used.  This
                    289:      can help in porting the program to various operating systems in
                    290:      which the necessary system header files are found in different
                    291:      places.
                    292: 
                    293: 
                    294: File: cpp.info,  Node: Include Operation,  Next: Once-Only,  Prev: Include Syntax,  Up: Header Files
                    295: 
                    296: How `#include' Works
                    297: --------------------
                    298: 
                    299:    The `#include' command works by directing the C preprocessor to scan
                    300: the specified file as input before continuing with the rest of the
                    301: current file.  The output from the preprocessor contains the output
                    302: already generated, followed by the output resulting from the included
                    303: file, followed by the output that comes from the text after the
                    304: `#include' command.  For example, given two files as follows:
                    305: 
                    306:      /* File program.c */
                    307:      int x;
                    308:      #include "header.h"
                    309:      
                    310:      main ()
                    311:      {
                    312:        printf (test ());
                    313:      }
                    314:      
                    315:      
                    316:      /* File header.h */
                    317:      char *test ();
                    318: 
                    319: the output generated by the C preprocessor for `program.c' as input
                    320: would be
                    321: 
                    322:      int x;
                    323:      char *test ();
                    324:      
                    325:      main ()
                    326:      {
                    327:        printf (test ());
                    328:      }
                    329: 
                    330:    Included files are not limited to declarations and macro
                    331: definitions; those are merely the typical uses.  Any fragment of a C
                    332: program can be included from another file.  The include file could even
                    333: contain the beginning of a statement that is concluded in the
                    334: containing file, or the end of a statement that was started in the
                    335: including file.  However, a comment or a string or character constant
                    336: may not start in the included file and finish in the including file.
                    337: An unterminated comment, string constant or character constant in an
                    338: included file is considered to end (with an error message) at the end
                    339: of the file.
                    340: 
                    341:    The line following the `#include' command is always treated as a
                    342: separate line by the C preprocessor even if the included file lacks a
                    343: final newline.
                    344: 
                    345: 
                    346: File: cpp.info,  Node: Once-Only,  Next: Inheritance,  Prev: Include Operation,  Up: Header Files
                    347: 
                    348: Once-Only Include Files
                    349: -----------------------
                    350: 
                    351:    Very often, one header file includes another.  It can easily result
                    352: that a certain header file is included more than once.  This may lead
                    353: to errors, if the header file defines structure types or typedefs, and
                    354: is certainly wasteful.  Therefore, we often wish to prevent multiple
                    355: inclusion of a header file.
                    356: 
                    357:    The standard way to do this is to enclose the entire real contents
                    358: of the file in a conditional, like this:
                    359: 
                    360:      #ifndef __FILE_FOO_SEEN__
                    361:      #define __FILE_FOO_SEEN__
                    362:      
                    363:      THE ENTIRE FILE
                    364:      
                    365:      #endif /* __FILE_FOO_SEEN__ */
                    366: 
                    367:    The macro `__FILE_FOO_SEEN__' indicates that the file has been
                    368: included once already; its name should begin with `__' to avoid
                    369: conflicts with user programs, and it should contain the name of the file
                    370: and some additional text, to avoid conflicts with other header files.
                    371: 
                    372:    The GNU C preprocessor is programmed to notice when a header file
                    373: uses this particular construct and handle it efficiently.  If a header
                    374: file is contained entirely in a `#ifndef' conditional, then it records
                    375: that fact.  If a subsequent `#include' specifies the same file, and the
                    376: macro in the `#ifndef' is already defined, then the file is entirely
                    377: skipped, without even reading it.
                    378: 
                    379:    There is also an explicit command to tell the preprocessor that it
                    380: need not include a file more than once.  This is called `#pragma once',
                    381: and was used *in addition to* the `#ifndef' conditional around the
                    382: contents of the header file.  `#pragma once' is now obsolete and should
                    383: not be used at all.
                    384: 
                    385:    In the Objective C language, there is a variant of `#include' called
                    386: `#import' which includes a file, but does so at most once.  If you use
                    387: `#import' *instead of* `#include', then you don't need the conditionals
                    388: inside the header file to prevent multiple execution of the contents.
                    389: 
                    390:    `#import' is obsolete because it is not a well-designed feature.  It
                    391: requires the users of a header file--the applications programmers--to
                    392: know that a certain header file should only be included once.  It is
                    393: much better for the header file's implementor to write the file so that
                    394: users don't need to know this.  Using `#ifndef' accomplishes this goal.
                    395: 
                    396: 
                    397: File: cpp.info,  Node: Inheritance,  Prev: Once-Only,  Up: Header Files
                    398: 
                    399: Inheritance and Header Files
                    400: ============================
                    401: 
                    402:    "Inheritance" is what happens when one object or file derives some
                    403: of its contents by virtual copying from another object or file.  In the
                    404: case of C header files, inheritance means that one header file includes
                    405: another header file and then replaces or adds something.
                    406: 
                    407:    If the inheriting header file and the base header file have different
                    408: names, then inheritance is straightforward: simply write `#include
                    409: "BASE"' in the inheriting file.
                    410: 
                    411:    Sometimes it is necessary to give the inheriting file the same name
                    412: as the base file.  This is less straightforward.
                    413: 
                    414:    For example, suppose an application program uses the system header
                    415: file `sys/signal.h', but the version of `/usr/include/sys/signal.h' on
                    416: a particular system doesn't do what the application program expects.
                    417: It might be convenient to define a "local" version, perhaps under the
                    418: name `/usr/local/include/sys/signal.h', to override or add to the one
                    419: supplied by the system.
                    420: 
                    421:    You can do this by using the option `-I.' for compilation, and
                    422: writing a file `sys/signal.h' that does what the application program
                    423: expects.  But making this file include the standard `sys/signal.h' is
                    424: not so easy--writing `#include <sys/signal.h>' in that file doesn't
                    425: work, because it includes your own version of the file, not the
                    426: standard system version.  Used in that file itself, this leads to an
                    427: infinite recursion and a fatal error in compilation.
                    428: 
                    429:    `#include </usr/include/sys/signal.h>' would find the proper file,
                    430: but that is not clean, since it makes an assumption about where the
                    431: system header file is found.  This is bad for maintenance, since it
                    432: means that any change in where the system's header files are kept
                    433: requires a change somewhere else.
                    434: 
                    435:    The clean way to solve this problem is to use `#include_next', which
                    436: means, "Include the *next* file with this name."  This command works
                    437: like `#include' except in searching for the specified file: it starts
                    438: searching the list of header file directories *after* the directory in
                    439: which the current file was found.
                    440: 
                    441:    Suppose you specify `-I /usr/local/include', and the list of
                    442: directories to search also includes `/usr/include'; and suppose that
                    443: both directories contain a file named `sys/signal.h'.  Ordinary
                    444: `#include <sys/signal.h>' finds the file under `/usr/local/include'.
                    445: If that file contains `#include_next <sys/signal.h>', it starts
                    446: searching after that directory, and finds the file in `/usr/include'.
                    447: 
                    448: 
                    449: File: cpp.info,  Node: Macros,  Next: Conditionals,  Prev: Header Files,  Up: Top
                    450: 
                    451: Macros
                    452: ======
                    453: 
                    454:    A macro is a sort of abbreviation which you can define once and then
                    455: use later.  There are many complicated features associated with macros
                    456: in the C preprocessor.
                    457: 
                    458: * Menu:
                    459: 
                    460: * Simple Macros::    Macros that always expand the same way.
                    461: * Argument Macros::  Macros that accept arguments that are substituted
                    462:                        into the macro expansion.
                    463: * Predefined::       Predefined macros that are always available.
                    464: * Stringification::  Macro arguments converted into string constants.
                    465: * Concatenation::    Building tokens from parts taken from macro arguments.
                    466: * Undefining::       Cancelling a macro's definition.
                    467: * Redefining::       Changing a macro's definition.
                    468: * Macro Pitfalls::   Macros can confuse the unwary.  Here we explain
                    469:                        several common problems and strange features.
                    470: 
                    471: 
                    472: File: cpp.info,  Node: Simple Macros,  Next: Argument Macros,  Prev: Macros,  Up: Macros
                    473: 
                    474: Simple Macros
                    475: -------------
                    476: 
                    477:    A "simple macro" is a kind of abbreviation.  It is a name which
                    478: stands for a fragment of code.  Some people refer to these as "manifest
                    479: constants".
                    480: 
                    481:    Before you can use a macro, you must "define" it explicitly with the
                    482: `#define' command.  `#define' is followed by the name of the macro and
                    483: then the code it should be an abbreviation for.  For example,
                    484: 
                    485:      #define BUFFER_SIZE 1020
                    486: 
                    487: defines a macro named `BUFFER_SIZE' as an abbreviation for the text
                    488: `1020'.  Therefore, if somewhere after this `#define' command there
                    489: comes a C statement of the form
                    490: 
                    491:      foo = (char *) xmalloc (BUFFER_SIZE);
                    492: 
                    493: then the C preprocessor will recognize and "expand" the macro
                    494: `BUFFER_SIZE', resulting in
                    495: 
                    496:      foo = (char *) xmalloc (1020);
                    497: 
                    498: the definition must be a single line; however, it may not end in the
                    499: middle of a multi-line string constant or character constant.
                    500: 
                    501:    The use of all upper case for macro names is a standard convention.
                    502: Programs are easier to read when it is possible to tell at a glance
                    503: which names are macros.
                    504: 
                    505:    Normally, a macro definition must be a single line, like all C
                    506: preprocessor commands.  (You can split a long macro definition
                    507: cosmetically with Backslash-Newline.)  There is one exception: Newlines
                    508: can be included in the macro definition if within a string or character
                    509: constant.  By the same token, it is not possible for a macro definition
                    510: to contain an unbalanced quote character; the definition automatically
                    511: extends to include the matching quote character that ends the string or
                    512: character constant.  Comments within a macro definition may contain
                    513: Newlines, which make no difference since the comments are entirely
                    514: replaced with Spaces regardless of their contents.
                    515: 
                    516:    Aside from the above, there is no restriction on what can go in a
                    517: macro body.  Parentheses need not balance.  The body need not resemble
                    518: valid C code.  (Of course, you might get error messages from the C
                    519: compiler when you use the macro.)
                    520: 
                    521:    The C preprocessor scans your program sequentially, so macro
                    522: definitions take effect at the place you write them.  Therefore, the
                    523: following input to the C preprocessor
                    524: 
                    525:      foo = X;
                    526:      #define X 4
                    527:      bar = X;
                    528: 
                    529: produces as output
                    530: 
                    531:      foo = X;
                    532:      
                    533:      bar = 4;
                    534: 
                    535:    After the preprocessor expands a macro name, the macro's definition
                    536: body is appended to the front of the remaining input, and the check for
                    537: macro calls continues.  Therefore, the macro body can contain calls to
                    538: other macros.  For example, after
                    539: 
                    540:      #define BUFSIZE 1020
                    541:      #define TABLESIZE BUFSIZE
                    542: 
                    543: the name `TABLESIZE' when used in the program would go through two
                    544: stages of expansion, resulting ultimately in `1020'.
                    545: 
                    546:    This is not at all the same as defining `TABLESIZE' to be `1020'.
                    547: The `#define' for `TABLESIZE' uses exactly the body you specify--in
                    548: this case, `BUFSIZE'--and does not check to see whether it too is the
                    549: name of a macro.  It's only when you *use* `TABLESIZE' that the result
                    550: of its expansion is checked for more macro names.  *Note Cascaded
                    551: Macros::.
                    552: 
                    553: 
                    554: File: cpp.info,  Node: Argument Macros,  Next: Predefined,  Prev: Simple Macros,  Up: Macros
                    555: 
                    556: Macros with Arguments
                    557: ---------------------
                    558: 
                    559:    A simple macro always stands for exactly the same text, each time it
                    560: is used.  Macros can be more flexible when they accept "arguments".
                    561: Arguments are fragments of code that you supply each time the macro is
                    562: used.  These fragments are included in the expansion of the macro
                    563: according to the directions in the macro definition.
                    564: 
                    565:    To define a macro that uses arguments, you write a `#define' command
                    566: with a list of "argument names" in parentheses after the name of the
                    567: macro.  The argument names may be any valid C identifiers, separated by
                    568: commas and optionally whitespace.  The open-parenthesis must follow the
                    569: macro name immediately, with no space in between.
                    570: 
                    571:    For example, here is a macro that computes the minimum of two numeric
                    572: values, as it is defined in many C programs:
                    573: 
                    574:      #define min(X, Y)  ((X) < (Y) ? (X) : (Y))
                    575: 
                    576: (This is not the best way to define a "minimum" macro in GNU C.  *Note
                    577: Side Effects::, for more information.)
                    578: 
                    579:    To use a macro that expects arguments, you write the name of the
                    580: macro followed by a list of "actual arguments" in parentheses,
                    581: separated by commas.  The number of actual arguments you give must
                    582: match the number of arguments the macro expects.   Examples of use of
                    583: the macro `min' include `min (1, 2)' and `min (x + 28, *p)'.
                    584: 
                    585:    The expansion text of the macro depends on the arguments you use.
                    586: Each of the argument names of the macro is replaced, throughout the
                    587: macro definition, with the corresponding actual argument.  Using the
                    588: same macro `min' defined above, `min (1, 2)' expands into
                    589: 
                    590:      ((1) < (2) ? (1) : (2))
                    591: 
                    592: where `1' has been substituted for `X' and `2' for `Y'.
                    593: 
                    594:    Likewise, `min (x + 28, *p)' expands into
                    595: 
                    596:      ((x + 28) < (*p) ? (x + 28) : (*p))
                    597: 
                    598:    Parentheses in the actual arguments must balance; a comma within
                    599: parentheses does not end an argument.  However, there is no requirement
                    600: for brackets or braces to balance, and they do not prevent a comma from
                    601: separating arguments.  Thus,
                    602: 
                    603:      macro (array[x = y, x + 1])
                    604: 
                    605: passes two arguments to `macro': `array[x = y' and `x + 1]'.  If you
                    606: want to supply `array[x = y, x + 1]' as an argument, you must write it
                    607: as `array[(x = y, x + 1)]', which is equivalent C code.
                    608: 
                    609:    After the actual arguments are substituted into the macro body, the
                    610: entire result is appended to the front of the remaining input, and the
                    611: check for macro calls continues.  Therefore, the actual arguments can
                    612: contain calls to other macros, either with or without arguments, or
                    613: even to the same macro.  The macro body can also contain calls to other
                    614: macros.  For example, `min (min (a, b), c)' expands into this text:
                    615: 
                    616:      ((((a) < (b) ? (a) : (b))) < (c)
                    617:       ? (((a) < (b) ? (a) : (b)))
                    618:       : (c))
                    619: 
                    620: (Line breaks shown here for clarity would not actually be generated.)
                    621: 
                    622:    If a macro `foo' takes one argument, and you want to supply an empty
                    623: argument, you must write at least some whitespace between the
                    624: parentheses, like this: `foo ( )'.  Just `foo ()' is providing no
                    625: arguments, which is an error if `foo' expects an argument.  But `foo0
                    626: ()' is the correct way to call a macro defined to take zero arguments,
                    627: like this:
                    628: 
                    629:      #define foo0() ...
                    630: 
                    631:    If you use the macro name followed by something other than an
                    632: open-parenthesis (after ignoring any spaces, tabs and comments that
                    633: follow), it is not a call to the macro, and the preprocessor does not
                    634: change what you have written.  Therefore, it is possible for the same
                    635: name to be a variable or function in your program as well as a macro,
                    636: and you can choose in each instance whether to refer to the macro (if
                    637: an actual argument list follows) or the variable or function (if an
                    638: argument list does not follow).
                    639: 
                    640:    Such dual use of one name could be confusing and should be avoided
                    641: except when the two meanings are effectively synonymous: that is, when
                    642: the name is both a macro and a function and the two have similar
                    643: effects.  You can think of the name simply as a function; use of the
                    644: name for purposes other than calling it (such as, to take the address)
                    645: will refer to the function, while calls will expand the macro and
                    646: generate better but equivalent code.  For example, you can use a
                    647: function named `min' in the same source file that defines the macro.
                    648: If you write `&min' with no argument list, you refer to the function.
                    649: If you write `min (x, bb)', with an argument list, the macro is
                    650: expanded.  If you write `(min) (a, bb)', where the name `min' is not
                    651: followed by an open-parenthesis, the macro is not expanded, so you wind
                    652: up with a call to the function `min'.
                    653: 
                    654:    You may not define the same name as both a simple macro and a macro
                    655: with arguments.
                    656: 
                    657:    In the definition of a macro with arguments, the list of argument
                    658: names must follow the macro name immediately with no space in between.
                    659: If there is a space after the macro name, the macro is defined as
                    660: taking no arguments, and all the rest of the line is taken to be the
                    661: expansion.  The reason for this is that it is often useful to define a
                    662: macro that takes no arguments and whose definition begins with an
                    663: identifier in parentheses.  This rule about spaces makes it possible
                    664: for you to do either this:
                    665: 
                    666:      #define FOO(x) - 1 / (x)
                    667: 
                    668: (which defines `FOO' to take an argument and expand into minus the
                    669: reciprocal of that argument) or this:
                    670: 
                    671:      #define BAR (x) - 1 / (x)
                    672: 
                    673: (which defines `BAR' to take no argument and always expand into `(x) -
                    674: 1 / (x)').
                    675: 
                    676:    Note that the *uses* of a macro with arguments can have spaces before
                    677: the left parenthesis; it's the *definition* where it matters whether
                    678: there is a space.
                    679: 
                    680: 
                    681: File: cpp.info,  Node: Predefined,  Next: Stringification,  Prev: Argument Macros,  Up: Macros
                    682: 
                    683: Predefined Macros
                    684: -----------------
                    685: 
                    686:    Several simple macros are predefined.  You can use them without
                    687: giving definitions for them.  They fall into two classes: standard
                    688: macros and system-specific macros.
                    689: 
                    690: * Menu:
                    691: 
                    692: * Standard Predefined::     Standard predefined macros.
                    693: * Nonstandard Predefined::  Nonstandard predefined macros.
                    694: 
                    695: 
                    696: File: cpp.info,  Node: Standard Predefined,  Next: Nonstandard Predefined,  Prev: Predefined,  Up: Predefined
                    697: 
                    698: Standard Predefined Macros
                    699: ..........................
                    700: 
                    701:    The standard predefined macros are available with the same meanings
                    702: regardless of the machine or operating system on which you are using
                    703: GNU C.  Their names all start and end with double underscores.  Those
                    704: preceding `__GNUC__' in this table are standardized by ANSI C; the rest
                    705: are GNU C extensions.
                    706: 
                    707: `__FILE__'
                    708:      This macro expands to the name of the current input file, in the
                    709:      form of a C string constant.  The precise name returned is the one
                    710:      that was specified in `#include' or as the input file name
                    711:      argument.
                    712: 
                    713: `__LINE__'
                    714:      This macro expands to the current input line number, in the form
                    715:      of a decimal integer constant.  While we call it a predefined
                    716:      macro, it's a pretty strange macro, since its "definition" changes
                    717:      with each new line of source code.
                    718: 
                    719:      This and `__FILE__' are useful in generating an error message to
                    720:      report an inconsistency detected by the program; the message can
                    721:      state the source line at which the inconsistency was detected.
                    722:      For example,
                    723: 
                    724:           fprintf (stderr, "Internal error: "
                    725:                         "negative string length "
                    726:                            "%d at %s, line %d.",
                    727:                    length, __FILE__, __LINE__);
                    728: 
                    729:      A `#include' command changes the expansions of `__FILE__' and
                    730:      `__LINE__' to correspond to the included file.  At the end of that
                    731:      file, when processing resumes on the input file that contained the
                    732:      `#include' command, the expansions of `__FILE__' and `__LINE__'
                    733:      revert to the values they had before the `#include' (but
                    734:      `__LINE__' is then incremented by one as processing moves to the
                    735:      line after the `#include').
                    736: 
                    737:      The expansions of both `__FILE__' and `__LINE__' are altered if a
                    738:      `#line' command is used.  *Note Combining Sources::.
                    739: 
                    740: `__INCLUDE_LEVEL__'
                    741:      This macro expands to a decimal integer constant that represents
                    742:      the depth of nesting in include files.  The value of this macro is
                    743:      incremented on every `#include' command and decremented at every
                    744:      end of file.
                    745: 
                    746: `__DATE__'
                    747:      This macro expands to a string constant that describes the date on
                    748:      which the preprocessor is being run.  The string constant contains
                    749:      eleven characters and looks like `"Jan 29 1987"' or `"Apr 1 1905"'.
                    750: 
                    751: `__TIME__'
                    752:      This macro expands to a string constant that describes the time at
                    753:      which the preprocessor is being run.  The string constant contains
                    754:      eight characters and looks like `"23:59:01"'.
                    755: 
                    756: `__STDC__'
                    757:      This macro expands to the constant 1, to signify that this is ANSI
                    758:      Standard C.  (Whether that is actually true depends on what C
                    759:      compiler will operate on the output from the preprocessor.)
                    760: 
                    761: `__GNUC__'
                    762:      This macro is defined if and only if this is GNU C.  This macro is
                    763:      defined only when the entire GNU C compiler is in use; if you
                    764:      invoke the preprocessor directly, `__GNUC__' is undefined.
                    765: 
                    766: `__GNUG__'
                    767:      The GNU C compiler defines this when the compilation language is
                    768:      C++; use `__GNUG__' to distinguish between GNU C and GNU C++.
                    769: 
                    770: `__cplusplus'
                    771:      The draft ANSI standard for C++ used to require predefining this
                    772:      variable.  Though it is no longer required, GNU C++ continues to
                    773:      define it, as do other popular C++ compilers.  You can use
                    774:      `__cplusplus' to test whether a header is compiled by a C compiler
                    775:      or a C++ compiler.
                    776: 
                    777: `__STRICT_ANSI__'
                    778:      This macro is defined if and only if the `-ansi' switch was
                    779:      specified when GNU C was invoked.  Its definition is the null
                    780:      string.  This macro exists primarily to direct certain GNU header
                    781:      files not to define certain traditional Unix constructs which are
                    782:      incompatible with ANSI C.
                    783: 
                    784: `__BASE_FILE__'
                    785:      This macro expands to the name of the main input file, in the form
                    786:      of a C string constant.  This is the source file that was specified
                    787:      as an argument when the C compiler was invoked.
                    788: 
                    789: `__VERSION__'
                    790:      This macro expands to a string which describes the version number
                    791:      of GNU C.  The string is normally a sequence of decimal numbers
                    792:      separated by periods, such as `"1.18"'.  The only reasonable use
                    793:      of this macro is to incorporate it into a string constant.
                    794: 
                    795: `__OPTIMIZE__'
                    796:      This macro is defined in optimizing compilations.  It causes
                    797:      certain GNU header files to define alternative macro definitions
                    798:      for some system library functions.  It is unwise to refer to or
                    799:      test the definition of this macro unless you make very sure that
                    800:      programs will execute with the same effect regardless.
                    801: 
                    802: `__CHAR_UNSIGNED__'
                    803:      This macro is defined if and only if the data type `char' is
                    804:      unsigned on the target machine.  It exists to cause the standard
                    805:      header file `limit.h' to work correctly.  It is bad practice to
                    806:      refer to this macro yourself; instead, refer to the standard
                    807:      macros defined in `limit.h'.  The preprocessor uses this macro to
                    808:      determine whether or not to sign-extend large character constants
                    809:      written in octal; see *Note The `#if' Command: #if Command.
                    810: 
                    811: 
                    812: File: cpp.info,  Node: Nonstandard Predefined,  Prev: Standard Predefined,  Up: Predefined
                    813: 
                    814: Nonstandard Predefined Macros
                    815: .............................
                    816: 
                    817:    The C preprocessor normally has several predefined macros that vary
                    818: between machines because their purpose is to indicate what type of
                    819: system and machine is in use.  This manual, being for all systems and
                    820: machines, cannot tell you exactly what their names are; instead, we
                    821: offer a list of some typical ones.  You can use `cpp -dM' to see the
                    822: values of predefined macros; *note Invocation::..
                    823: 
                    824:    Some nonstandard predefined macros describe the operating system in
                    825: use, with more or less specificity.  For example,
                    826: 
                    827: `unix'
                    828:      `unix' is normally predefined on all Unix systems.
                    829: 
                    830: `BSD'
                    831:      `BSD' is predefined on recent versions of Berkeley Unix (perhaps
                    832:      only in version 4.3).
                    833: 
                    834:    Other nonstandard predefined macros describe the kind of CPU, with
                    835: more or less specificity.  For example,
                    836: 
                    837: `vax'
                    838:      `vax' is predefined on Vax computers.
                    839: 
                    840: `mc68000'
                    841:      `mc68000' is predefined on most computers whose CPU is a Motorola
                    842:      68000, 68010 or 68020.
                    843: 
                    844: `m68k'
                    845:      `m68k' is also predefined on most computers whose CPU is a 68000,
                    846:      68010 or 68020; however, some makers use `mc68000' and some use
                    847:      `m68k'.  Some predefine both names.  What happens in GNU C depends
                    848:      on the system you are using it on.
                    849: 
                    850: `M68020'
                    851:      `M68020' has been observed to be predefined on some systems that
                    852:      use 68020 CPUs--in addition to `mc68000' and `m68k', which are
                    853:      less specific.
                    854: 
                    855: `_AM29K'
                    856: `_AM29000'
                    857:      Both `_AM29K' and `_AM29000' are predefined for the AMD 29000 CPU
                    858:      family.
                    859: 
                    860: `ns32000'
                    861:      `ns32000' is predefined on computers which use the National
                    862:      Semiconductor 32000 series CPU.
                    863: 
                    864:    Yet other nonstandard predefined macros describe the manufacturer of
                    865: the system.  For example,
                    866: 
                    867: `sun'
                    868:      `sun' is predefined on all models of Sun computers.
                    869: 
                    870: `pyr'
                    871:      `pyr' is predefined on all models of Pyramid computers.
                    872: 
                    873: `sequent'
                    874:      `sequent' is predefined on all models of Sequent computers.
                    875: 
                    876:    These predefined symbols are not only nonstandard, they are contrary
                    877: to the ANSI standard because their names do not start with underscores.
                    878: Therefore, the option `-ansi' inhibits the definition of these symbols.
                    879: 
                    880:    This tends to make `-ansi' useless, since many programs depend on the
                    881: customary nonstandard predefined symbols.  Even system header files
                    882: check them and will generate incorrect declarations if they do not find
                    883: the names that are expected.  You might think that the header files
                    884: supplied for the Uglix computer would not need to test what machine
                    885: they are running on, because they can simply assume it is the Uglix;
                    886: but often they do, and they do so using the customary names.  As a
                    887: result, very few C programs will compile with `-ansi'.  We intend to
                    888: avoid such problems on the GNU system.
                    889: 
                    890:    What, then, should you do in an ANSI C program to test the type of
                    891: machine it will run on?
                    892: 
                    893:    GNU C offers a parallel series of symbols for this purpose, whose
                    894: names are made from the customary ones by adding `__' at the beginning
                    895: and end.  Thus, the symbol `__vax__' would be available on a Vax, and
                    896: so on.
                    897: 
                    898:    The set of nonstandard predefined names in the GNU C preprocessor is
                    899: controlled (when `cpp' is itself compiled) by the macro
                    900: `CPP_PREDEFINES', which should be a string containing `-D' options,
                    901: separated by spaces.  For example, on the Sun 3, we use the following
                    902: definition:
                    903: 
                    904:      #define CPP_PREDEFINES "-Dmc68000 -Dsun -Dunix -Dm68k"
                    905: 
                    906: This macro is usually specified in `tm.h'.
                    907: 
                    908: 
                    909: File: cpp.info,  Node: Stringification,  Next: Concatenation,  Prev: Predefined,  Up: Macros
                    910: 
                    911: Stringification
                    912: ---------------
                    913: 
                    914:    "Stringification" means turning a code fragment into a string
                    915: constant whose contents are the text for the code fragment.  For
                    916: example, stringifying `foo (z)' results in `"foo (z)"'.
                    917: 
                    918:    In the C preprocessor, stringification is an option available when
                    919: macro arguments are substituted into the macro definition.  In the body
                    920: of the definition, when an argument name appears, the character `#'
                    921: before the name specifies stringification of the corresponding actual
                    922: argument when it is substituted at that point in the definition.  The
                    923: same argument may be substituted in other places in the definition
                    924: without stringification if the argument name appears in those places
                    925: with no `#'.
                    926: 
                    927:    Here is an example of a macro definition that uses stringification:
                    928: 
                    929:      #define WARN_IF(EXP) \
                    930:      do { if (EXP) \
                    931:              fprintf (stderr, "Warning: " #EXP "\n"); } \
                    932:      while (0)
                    933: 
                    934: Here the actual argument for `EXP' is substituted once as given, into
                    935: the `if' statement, and once as stringified, into the argument to
                    936: `fprintf'.  The `do' and `while (0)' are a kludge to make it possible
                    937: to write `WARN_IF (ARG);', which the resemblance of `WARN_IF' to a
                    938: function would make C programmers want to do; *note Swallow
                    939: Semicolon::.).
                    940: 
                    941:    The stringification feature is limited to transforming one macro
                    942: argument into one string constant: there is no way to combine the
                    943: argument with other text and then stringify it all together.  But the
                    944: example above shows how an equivalent result can be obtained in ANSI
                    945: Standard C using the feature that adjacent string constants are
                    946: concatenated as one string constant.  The preprocessor stringifies the
                    947: actual value of `EXP' into a separate string constant, resulting in
                    948: text like
                    949: 
                    950:      do { if (x == 0) \
                    951:              fprintf (stderr, "Warning: " "x == 0" "\n"); } \
                    952:      while (0)
                    953: 
                    954: but the C compiler then sees three consecutive string constants and
                    955: concatenates them into one, producing effectively
                    956: 
                    957:      do { if (x == 0) \
                    958:              fprintf (stderr, "Warning: x == 0\n"); } \
                    959:      while (0)
                    960: 
                    961:    Stringification in C involves more than putting doublequote
                    962: characters around the fragment; it is necessary to put backslashes in
                    963: front of all doublequote characters, and all backslashes in string and
                    964: character constants, in order to get a valid C string constant with the
                    965: proper contents.  Thus, stringifying `p = "foo\n";' results in `"p =
                    966: \"foo\\n\";"'.  However, backslashes that are not inside of string or
                    967: character constants are not duplicated: `\n' by itself stringifies to
                    968: `"\n"'.
                    969: 
                    970:    Whitespace (including comments) in the text being stringified is
                    971: handled according to precise rules.  All leading and trailing
                    972: whitespace is ignored.  Any sequence of whitespace in the middle of the
                    973: text is converted to a single space in the stringified result.
                    974: 
                    975: 
                    976: File: cpp.info,  Node: Concatenation,  Next: Undefining,  Prev: Stringification,  Up: Macros
                    977: 
                    978: Concatenation
                    979: -------------
                    980: 
                    981:    "Concatenation" means joining two strings into one.  In the context
                    982: of macro expansion, concatenation refers to joining two lexical units
                    983: into one longer one.  Specifically, an actual argument to the macro can
                    984: be concatenated with another actual argument or with fixed text to
                    985: produce a longer name.  The longer name might be the name of a function,
                    986: variable or type, or a C keyword; it might even be the name of another
                    987: macro, in which case it will be expanded.
                    988: 
                    989:    When you define a macro, you request concatenation with the special
                    990: operator `##' in the macro body.  When the macro is called, after
                    991: actual arguments are substituted, all `##' operators are deleted, and
                    992: so is any whitespace next to them (including whitespace that was part
                    993: of an actual argument).  The result is to concatenate the syntactic
                    994: tokens on either side of the `##'.
                    995: 
                    996:    Consider a C program that interprets named commands.  There probably
                    997: needs to be a table of commands, perhaps an array of structures
                    998: declared as follows:
                    999: 
                   1000:      struct command
                   1001:      {
                   1002:        char *name;
                   1003:        void (*function) ();
                   1004:      };
                   1005:      
                   1006:      struct command commands[] =
                   1007:      {
                   1008:        { "quit", quit_command},
                   1009:        { "help", help_command},
                   1010:        ...
                   1011:      };
                   1012: 
                   1013:    It would be cleaner not to have to give each command name twice,
                   1014: once in the string constant and once in the function name.  A macro
                   1015: which takes the name of a command as an argument can make this
                   1016: unnecessary.  The string constant can be created with stringification,
                   1017: and the function name by concatenating the argument with `_command'.
                   1018: Here is how it is done:
                   1019: 
                   1020:      #define COMMAND(NAME)  { #NAME, NAME ## _command }
                   1021:      
                   1022:      struct command commands[] =
                   1023:      {
                   1024:        COMMAND (quit),
                   1025:        COMMAND (help),
                   1026:        ...
                   1027:      };
                   1028: 
                   1029:    The usual case of concatenation is concatenating two names (or a
                   1030: name and a number) into a longer name.  But this isn't the only valid
                   1031: case.  It is also possible to concatenate two numbers (or a number and
                   1032: a name, such as `1.5' and `e3') into a number.  Also, multi-character
                   1033: operators such as `+=' can be formed by concatenation.  In some cases
                   1034: it is even possible to piece together a string constant.  However, two
                   1035: pieces of text that don't together form a valid lexical unit cannot be
                   1036: concatenated.  For example, concatenation with `x' on one side and `+'
                   1037: on the other is not meaningful because those two characters can't fit
                   1038: together in any lexical unit of C.  The ANSI standard says that such
                   1039: attempts at concatenation are undefined, but in the GNU C preprocessor
                   1040: it is well defined: it puts the `x' and `+' side by side with no
                   1041: particular special results.
                   1042: 
                   1043:    Keep in mind that the C preprocessor converts comments to whitespace
                   1044: before macros are even considered.  Therefore, you cannot create a
                   1045: comment by concatenating `/' and `*': the `/*' sequence that starts a
                   1046: comment is not a lexical unit, but rather the beginning of a "long"
                   1047: space character.  Also, you can freely use comments next to a `##' in a
                   1048: macro definition, or in actual arguments that will be concatenated,
                   1049: because the comments will be converted to spaces at first sight, and
                   1050: concatenation will later discard the spaces.
                   1051: 
                   1052: 
                   1053: File: cpp.info,  Node: Undefining,  Next: Redefining,  Prev: Concatenation,  Up: Macros
                   1054: 
                   1055: Undefining Macros
                   1056: -----------------
                   1057: 
                   1058:    To "undefine" a macro means to cancel its definition.  This is done
                   1059: with the `#undef' command.  `#undef' is followed by the macro name to
                   1060: be undefined.
                   1061: 
                   1062:    Like definition, undefinition occurs at a specific point in the
                   1063: source file, and it applies starting from that point.  The name ceases
                   1064: to be a macro name, and from that point on it is treated by the
                   1065: preprocessor as if it had never been a macro name.
                   1066: 
                   1067:    For example,
                   1068: 
                   1069:      #define FOO 4
                   1070:      x = FOO;
                   1071:      #undef FOO
                   1072:      x = FOO;
                   1073: 
                   1074: expands into
                   1075: 
                   1076:      x = 4;
                   1077:      
                   1078:      x = FOO;
                   1079: 
                   1080: In this example, `FOO' had better be a variable or function as well as
                   1081: (temporarily) a macro, in order for the result of the expansion to be
                   1082: valid C code.
                   1083: 
                   1084:    The same form of `#undef' command will cancel definitions with
                   1085: arguments or definitions that don't expect arguments.  The `#undef'
                   1086: command has no effect when used on a name not currently defined as a
                   1087: macro.
                   1088: 
                   1089: 
                   1090: File: cpp.info,  Node: Redefining,  Next: Macro Pitfalls,  Prev: Undefining,  Up: Macros
                   1091: 
                   1092: Redefining Macros
                   1093: -----------------
                   1094: 
                   1095:    "Redefining" a macro means defining (with `#define') a name that is
                   1096: already defined as a macro.
                   1097: 
                   1098:    A redefinition is trivial if the new definition is transparently
                   1099: identical to the old one.  You probably wouldn't deliberately write a
                   1100: trivial redefinition, but they can happen automatically when a header
                   1101: file is included more than once (*note Header Files::.), so they are
                   1102: accepted silently and without effect.
                   1103: 
                   1104:    Nontrivial redefinition is considered likely to be an error, so it
                   1105: provokes a warning message from the preprocessor.  However, sometimes it
                   1106: is useful to change the definition of a macro in mid-compilation.  You
                   1107: can inhibit the warning by undefining the macro with `#undef' before the
                   1108: second definition.
                   1109: 
                   1110:    In order for a redefinition to be trivial, the new definition must
                   1111: exactly match the one already in effect, with two possible exceptions:
                   1112: 
                   1113:    * Whitespace may be added or deleted at the beginning or the end.
                   1114: 
                   1115:    * Whitespace may be changed in the middle (but not inside strings).
                   1116:      However, it may not be eliminated entirely, and it may not be added
                   1117:      where there was no whitespace at all.
                   1118: 
                   1119:    Recall that a comment counts as whitespace.
                   1120: 
                   1121: 
                   1122: File: cpp.info,  Node: Macro Pitfalls,  Prev: Redefining,  Up: Macros
                   1123: 
                   1124: Pitfalls and Subtleties of Macros
                   1125: ---------------------------------
                   1126: 
                   1127:    In this section we describe some special rules that apply to macros
                   1128: and macro expansion, and point out certain cases in which the rules have
                   1129: counterintuitive consequences that you must watch out for.
                   1130: 
                   1131: * Menu:
                   1132: 
                   1133: * Misnesting::        Macros can contain unmatched parentheses.
                   1134: * Macro Parentheses:: Why apparently superfluous parentheses
                   1135:                          may be necessary to avoid incorrect grouping.
                   1136: * Swallow Semicolon:: Macros that look like functions
                   1137:                          but expand into compound statements.
                   1138: * Side Effects::      Unsafe macros that cause trouble when
                   1139:                          arguments contain side effects.
                   1140: * Self-Reference::    Macros whose definitions use the macros' own names.
                   1141: * Argument Prescan::  Actual arguments are checked for macro calls
                   1142:                          before they are substituted.
                   1143: * Cascaded Macros::   Macros whose definitions use other macros.
                   1144: * Newlines in Args::  Sometimes line numbers get confused.
                   1145: 
                   1146: 
                   1147: File: cpp.info,  Node: Misnesting,  Next: Macro Parentheses,  Prev: Macro Pitfalls,  Up: Macro Pitfalls
                   1148: 
                   1149: Improperly Nested Constructs
                   1150: ............................
                   1151: 
                   1152:    Recall that when a macro is called with arguments, the arguments are
                   1153: substituted into the macro body and the result is checked, together with
                   1154: the rest of the input file, for more macro calls.
                   1155: 
                   1156:    It is possible to piece together a macro call coming partially from
                   1157: the macro body and partially from the actual arguments.  For example,
                   1158: 
                   1159:      #define double(x) (2*(x))
                   1160:      #define call_with_1(x) x(1)
                   1161: 
                   1162: would expand `call_with_1 (double)' into `(2*(1))'.
                   1163: 
                   1164:    Macro definitions do not have to have balanced parentheses.  By
                   1165: writing an unbalanced open parenthesis in a macro body, it is possible
                   1166: to create a macro call that begins inside the macro body but ends
                   1167: outside of it.  For example,
                   1168: 
                   1169:      #define strange(file) fprintf (file, "%s %d",
                   1170:      ...
                   1171:      strange(stderr) p, 35)
                   1172: 
                   1173: This bizarre example expands to `fprintf (stderr, "%s %d", p, 35)'!
                   1174: 
                   1175: 
                   1176: File: cpp.info,  Node: Macro Parentheses,  Next: Swallow Semicolon,  Prev: Misnesting,  Up: Macro Pitfalls
                   1177: 
                   1178: Unintended Grouping of Arithmetic
                   1179: .................................
                   1180: 
                   1181:    You may have noticed that in most of the macro definition examples
                   1182: shown above, each occurrence of a macro argument name had parentheses
                   1183: around it.  In addition, another pair of parentheses usually surround
                   1184: the entire macro definition.  Here is why it is best to write macros
                   1185: that way.
                   1186: 
                   1187:    Suppose you define a macro as follows,
                   1188: 
                   1189:      #define ceil_div(x, y) (x + y - 1) / y
                   1190: 
                   1191: whose purpose is to divide, rounding up.  (One use for this operation is
                   1192: to compute how many `int' objects are needed to hold a certain number
                   1193: of `char' objects.)  Then suppose it is used as follows:
                   1194: 
                   1195:      a = ceil_div (b & c, sizeof (int));
                   1196: 
                   1197: This expands into
                   1198: 
                   1199:      a = (b & c + sizeof (int) - 1) / sizeof (int);
                   1200: 
                   1201: which does not do what is intended.  The operator-precedence rules of C
                   1202: make it equivalent to this:
                   1203: 
                   1204:      a = (b & (c + sizeof (int) - 1)) / sizeof (int);
                   1205: 
                   1206: But what we want is this:
                   1207: 
                   1208:      a = ((b & c) + sizeof (int) - 1)) / sizeof (int);
                   1209: 
                   1210: Defining the macro as
                   1211: 
                   1212:      #define ceil_div(x, y) ((x) + (y) - 1) / (y)
                   1213: 
                   1214: provides the desired result.
                   1215: 
                   1216:    However, unintended grouping can result in another way.  Consider
                   1217: `sizeof ceil_div(1, 2)'.  That has the appearance of a C expression
                   1218: that would compute the size of the type of `ceil_div (1, 2)', but in
                   1219: fact it means something very different.  Here is what it expands to:
                   1220: 
                   1221:      sizeof ((1) + (2) - 1) / (2)
                   1222: 
                   1223: This would take the size of an integer and divide it by two.  The
                   1224: precedence rules have put the division outside the `sizeof' when it was
                   1225: intended to be inside.
                   1226: 
                   1227:    Parentheses around the entire macro definition can prevent such
                   1228: problems.  Here, then, is the recommended way to define `ceil_div':
                   1229: 
                   1230:      #define ceil_div(x, y) (((x) + (y) - 1) / (y))
                   1231: 

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.