SCons User Guide 0.92 | ||
---|---|---|
<<< Previous | Dependencies | Next >>> |
Now suppose that our "Hello, World!" program actually has a #include line to include the hello.h file in the compilation:
#include "hello.h" int main() { printf("Hello, %s!\n", string); } |
And, for completeness, the hello.h file looks like this:
#define string "world" |
In this case, we want SCons to recognize that, if the contents of the hello.h file change, the hello program must be recompiled. To do this, we need to modify the SConstruct file like so:
env = Environment(CPPPATH = '.') hello = env.Program('hello.c') |
The CPPPATH assignment in the Environment call tells SCons to look in the current directory ('.') for any files included by C source files (.c or .h files). With this assignment in the SConstruct file:
% scons hello
cc -I. -c hello.c -o hello.o
cc -o hello hello.o
% scons hello
scons: `hello' is up to date.
% edit hello.h
[CHANGE THE CONTENTS OF hello.h]
% scons hello
cc -I. -c hello.c -o hello.o
cc -o hello hello.o
%
First, notice that SCons added the -I. argument from the CPPPATH variable so that the compilation would find the hello.h file in the local directory.
Second, realize that SCons knows that the hello program must be rebuilt because it scans the contents of the hello.c file for the #include lines that indicate another file is being included in the compilation. SCons records these as implicit dependencies of the target file, Consequently, when the hello.h file changes, SCons realizes that the hello.c file includes it, and rebuilds the resulting hello program that depends on both the hello.c and hello.h files.
Like the LIBPATH variable, the CPPPATH variable may be a list of directories, or a string separated by the system-specific path separate character (':' on POSIX/Linux, ';' on Windows). Either way, SCons creates the right command-line options so that the followin example:
env = Environment(CPPPATH = ['include', '/home/project/inc']) hello = env.Program('hello.c') |
Will look like this on POSIX or Linux:
% scons hello
cc -Iinclude -I/home/project/inc -c hello.c -o hello.o
cc -o hello hello.o
And like this on Windows:
% scons hello
cl /Iinclude /I\home\project\inc /Fohello.obj hello.c
link /OUT:hello.exe hello.obj
<<< Previous | Home | Next >>> |
Target File Signatures | Up | Caching Implicit Dependencies |