Annotation of GNUtools/cc/cpp.info-1, revision 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.