hdrstop pragma

Gives you more control over precompilation file names, and over the location at which the compilation state is saved.

Syntax

#pragma hdrstop [ ( "filename" ) ]

Remarks

The filename is the name of the precompiled header file to use or create (depending on whether /Yu or /Yc is specified). If filename doesn't contain a path specification, the precompiled header file is assumed to be in the same directory as the source file.

If a C or C++ file contains a hdrstop pragma when compiled with /Yc, the compiler saves the state of the compilation up to the location of the pragma. The compiled state of any code that follows the pragma isn't saved.

Use filename to name the precompiled header file in which the compiled state is saved. A space between hdrstop and filename is optional. The file name specified in the hdrstop pragma is a string, and is subject to the constraints of any C or C++ string. In particular, you must enclose it in quotation marks and use the escape character (backslash, \) to specify directory names. For example:

#pragma hdrstop( "c:\\projects\\include\\myinc.pch" )

The name of the precompiled header file is determined according to the following rules, in order of precedence:

  1. The argument to the /Fp compiler option

  2. The filename argument to #pragma hdrstop

  3. The base name of the source file with a PCH extension

If none of the /Yc and /Yu options or the hdrstop pragma specifies a file name, the base name of the source file is used as the base name of the precompiled header file.

You can also use preprocessing commands to perform macro replacement as follows:

#define INCLUDE_PATH "c:\\progra~1\\devstsu~1\\vc\\include\\"
#define PCH_FNAME "PROG.PCH"
.
.
.
#pragma hdrstop( INCLUDE_PATH PCH_FNAME )

The following rules govern where the hdrstop pragma can be placed:

  • It must appear outside any data or function declaration or definition.

  • It must be specified in the source file, not within a header file.

Example

#include <windows.h>                 // Include several files
#include "myhdr.h"

__inline Disp( char *szToDisplay )   // Define an inline function
{
    // ...                           // Some code to display string
}
#pragma hdrstop

In this example, the hdrstop pragma appears after two files have been included and an inline function has been defined. This location might, at first, seem to be an odd placement for the pragma. Consider, however, that using the manual precompilation options, /Yc and /Yu, with the hdrstop pragma makes it possible for you to precompile entire source files, or even inline code. The Microsoft compiler doesn't limit you to precompiling only data declarations.

See also

Pragma directives and the __pragma and _Pragma keywords