.\"
.\" __FILE__ __REVISION__ __DATE__ __DEVELOPER__
.\"
+.\" ES - Example Start - indents and turns off line fill
+.de ES
+.RS
+.nf
+..
+.\" EE - Example End - ends intend and turns line fill back on
+.de EE
+.RE
+.fi
+..
.TH SCONS 1 "December 2001"
.SH NAME
scons \- software constructor
file, specifying the target or targets to be built as
command-line arguments. The command
-.IP
-.nf
+.ES
scons .
-.PP
-.fi
+.EE
will build all target files in or below the current directory
.RI ( . ")."
-.IP
-.nf
+.ES
scons /
-.PP
-.fi
+.EE
will build all target files in or below the root directory (i.e.,
all files). Specific targets may be supplied:
-.IP
-.nf
+.ES
scons foo bar
-.PP
-.fi
+.EE
Targets may be omitted from the command line,
in which case the targets specified
.B Default
targets will be built:
-.IP
-.nf
+.ES
scons
-.PP
-.fi
+.EE
Specifying "cleanup" targets in configuration files is not
necessary. The
.B -c
flag removes all files
necessary to build the specified target:
-.IP
-.nf
+
+.ES
scons -c .
-.PP
-.fi
+.EE
+
to remove all target files, or:
-.IP
-.nf
+
+.ES
scons -c build export
-.PP
-.fi
+.EE
+
to remove target files under build and export.
A subset of a hierarchical tree may be built by
file lives) and specifying the subdirectory as the target to be
built:
-.IP
-.nf
+.ES
scons src/subdir
-.PP
-.fi
+.EE
.\" or changing directory and invoking scons with the
.\" .B -u
.\" file, and then builds
.\" targets relatively to the current subdirectory:
.\"
-.\" .RS
+.\" .ES
.\" cd src/subdir
-.\" .RE
-.\" .RS
.\" scons -u .
-.\" .RE
+.\" .EE
.B scons
supports building multiple targets in parallel via a
option that takes, as its argument, the number
of simultaneous tasks that may be spawned:
-.IP
-.nf
+.ES
scons -j 4
-.PP
-.fi
+.EE
builds four targets in parallel, for example.
.\" Values of variables to be passed to the configuration file(s)
.\" may be specified on the command line:
.\"
-.\" .IP
-.\" .nf
+.\" .ES
.\" scons debug=1 .
-.\" .PP
-.\" .fi
+.\" .EE
.\"
.\" These variables can be used in the configuration file(s) to modify
.\" the build in any way.
and many of those supported by
.BR cons .
-.IP -b
+.TP
+-b
Ignored for compatibility with non-GNU versions of
.BR make.
-.IP "-c, --clean, --remove"
+.TP
+-c, --clean, --remove
Clean up by removing all target files for which a construction
command is specified.
-.\" ".IP --cache-disable, --no-cache"
+.\" .TP
+.\" --cache-disable, --no-cache
.\" Disable caching. Will neither retrieve files from cache nor flush
.\" files to cache. Has no effect if use of caching is not specified
.\" in a configuration file.
-.\"
-.\" .IP "--cache-force, --cache-populate"
+.\"
+.\" .TP
+.\" --cache-force, --cache-populate
.\" Populate a cache by forcing any already-existing up-to-date
.\" target files to the cache, in addition to files built by this
.\" invocation. This is useful to populate a new cache with
.\" any target files recently built with caching disabled via the
.\" .B --cache-disable
.\" option.
-.\"
-.\" .IP --cache-show
+.\"
+.\" .TP
+.\" --cache-show
.\" When retrieving a target file from a cache, show the command
.\" that would have been executed to build the file. This produces
.\" consistent output for build logs, regardless of whether a target
.I sconstruct
in the specified directory.)
-.\" .IP -d
+.\" .TP
+.\" -d
.\" Display dependencies while building target files. Useful for
.\" figuring out why a specific file is being rebuilt, as well as
.\" general debugging of the build process.
which causes the dependency tree to be printed after each top-level
target is built.
-.IP "-e, --environment-overrides"
+.TP
+-e, --environment-overrides
Variables from the execution environment override construction
variables from the configuration files.
.B scons
will change to that directory before building targets.
-.IP "-h, --help"
+.TP
+-h, --help
Print a local help message for this build, if one is defined in
the configuration file(s), plus a line that describes the
.B -H
is defined, prints the standard help message about command-line
options. Exits after displaying the appropriate message.
-.IP "-H, --help-options"
+.TP
+-H, --help-options
Print the standard help message about command-line options and
exit.
-.IP "-i, --ignore-errors"
+.TP
+-i, --ignore-errors
Ignore all errors from commands executed to rebuild files.
.TP
If there is more than one
.B -j
option, the last one is effective.
-
.\" ??? If the
.\" .B -j
.\" option
.\" will not limit the number of
.\" simultaneous jobs.
-.IP "-k, --keep-going"
+.TP
+-k, --keep-going
Continue as much as possible after an error. The target that
failed and those that depend on it will not be remade, but other
targets specified on the command line will still be processed.
.\" average is at least
.\" .I N
.\" (a floating-point number).
-.\"
-.\" .IP --list-derived
+.\"
+.\" .TP
+.\" --list-derived
.\" List derived files (targets, dependencies) that would be built,
.\" but do not build them.
.\" [XXX This can probably go away with the right
.\" combination of other options. Revisit this issue.]
-.\"
-.\" .IP --list-actions
+.\"
+.\" .TP
+.\" --list-actions
.\" List derived files that would be built, with the actions
.\" (commands) that build them. Does not build the files.
.\" [XXX This can probably go away with the right
.\" combination of other options. Revisit this issue.]
-.\"
-.\" .IP --list-where
+.\"
+.\" .TP
+.\" --list-where
.\" List derived files that would be built, plus where the file is
.\" defined (file name and line number). Does not build the files.
.\" [XXX This can probably go away with the right
.\" combination of other options. Revisit this issue.]
-.IP -m
+.TP
+-m
Ignored for compatibility with non-GNU versions of
.BR make .
-.IP "-n, --just-print, --dry-run, --recon"
+.TP
+-n, --just-print, --dry-run, --recon
No execute. Print the commands that would be executed to build
any out-of-date target files, but do not execute the commands.
.\" and do
.\" not rebuild anything due to changes in the contents of
.\" .IR file .
-.\"
.\" .TP
.\" .RI --override " file"
.\" Read values to override specific build environment variables
.\" from the specified
.\" .IR file .
-.\"
-.\" .IP -p
+.\" .TP
+.\" -p
.\" Print the data base (construction environments,
.\" Builder and Scanner objects) that are defined
.\" after reading the configuration files.
.\" option.
.\"
.\" To print the database without performing a build do:
-.\" .IP
-.\" .nf
+.\"
+.\" .ES
.\" scons -p -q
-.\" .PP
-.\" .fi
+.\" .EE
.\"
-.\" .IP "-q, --question"
+.\" .TP
+.\" -q, --question
.\" Do not run any commands, or print anything. Just return an exit
.\" status that is zero if the specified targets are already up to
.\" date, nonzero otherwise.
.\"
-.\" .IP "-r, -R, --no-builtin-rules, --no-builtin-variables"
+.\" .TP
+.\" -r, -R, --no-builtin-rules, --no-builtin-variables
.\" Clear the default construction variables. Construction
.\" environments that are created will be completely empty.
.\"
-.\" .IP --random
+.\" .TP
+.\" --random
.\" Build dependencies in a random order. This is useful when
.\" building multiple trees simultaneously with caching enabled as a
.\" way to prevent multiple builds from simultaneously trying to build
.\" or retrieve the same target files.
-.IP "-s, --silent, --quiet"
+.TP
+-s, --silent, --quiet
Silent. Do not print commands that are executed to rebuild
target files.
-.IP "-S, --no-keep-going, --stop"
+.TP
+-S, --no-keep-going, --stop
Ignored for compatibility with GNU
.BR make .
-.IP "-t, --touch"
+.TP
+-t, --touch
Ignored for compatibility with GNU
.BR make .
(Touching a file to make it
appear up-to-date is unnecessary when using
.BR scons .)
-.\" .IP -u
+.\" .TP
+.\" -u
.\" Traverse up directories until an
.\" .I SConstruct
.\" or
.\" as the top of the directory tree. Only targets at or below the
.\" current directory will be built.
-.IP "-v, --version"
+.TP
+-v, --version
Print the
.B scons
version, copyright information,
list of authors, and any other relevant information.
Then exit.
-.IP "-w, --print-directory"
+.TP
+-w, --print-directory
Print a message containing the working directory before and
after other processing.
-.IP --no-print-directory
+.TP
+--no-print-directory
Turn off -w, even if it was turned on implicitly.
.\" .TP
.\" .B -n
.\" ... what? XXX
.\"
-.\" .IP --warn-undefined-variables
+.\" .TP
+.\" --warn-undefined-variables
.\" Warn when an undefined variable is referenced.
.\"
.\" .TP
.B Environment
function:
-.IP
-.nf
+.ES
env = Environment()
-.PP
-.fi
+.EE
Build rules are specified by calling builder methods on a construction
environment. The arguments to the builder methods are target (a list of
interprets it as a space delimited list
of files. The following are examples of calling a builder:
-.IP
-.nf
+.ES
env.Program(target = 'bar', source = 'bar.c foo.c')
env.Program('bar', 'bar.c foo.c')
env.Program('bar', ['bar.c', 'foo.c'])
-.PP
-.fi
+.EE
.B scons
provides the following builders:
must have one of the following extensions: .c, .C, .cc, .cpp, .cxx, .c++, .C++.
The target object file prefix and suffix (if any) are automatically
added. Example:
-.IP
-.nf
+
+.ES
env.Object(target = 'bar', source = 'bar.c')
-.PP
-.fi
+.EE
.IP Program
Builds an executable given one or more object files or C/C++ source
files. If any C/C++ source files are given, then they will be automatically
compiled to object files. The executable prefix and suffix (if any) are
automatically added to the target. Example:
-.IP
-.nf
+
+.ES
env.Program(target = 'bar', source = 'bar.c foo.o')
-.PP
-.fi
+.EE
.IP Library
Builds a library given one or more object files or C/C++ source
files. If any C/C++ source files are given, then they will be automatically
compiled to object files. The library prefix and suffix (if any) are
automatically added to the target. Example:
-.IP
-.nf
+
+.ES
env.Library(target = 'bar', source = 'bar.c foo.o')
-.PP
-.fi
+.EE
.IP CFile
Builds a C source file given a lex (.l) or yacc (.y) input file.
The hard-coded suffix .c is
automatically added to the target
if it is not already present. Example:
-.IP
-.nf
+
+.ES
env.CFile(target = 'foo.c', source = 'foo.l') # builds foo.c
env.CFile(target = 'bar', source = 'bar.y') # builds bar.c
-.PP
-.fi
-
+.EE
.LP
-
C/C++ source files are automatically scanned for dependencies by
.B scons
so the dependencies do not need to be provided. In addition, all builder
targets automatically depend on their sources. An explicit dependency can
be specified using the
.B Depends
-method of a construction environment:
+method of a construction environment (see below).
-.IP
-.nf
-env.Depends('foo.c', 'foo.h')
-.PP
-.fi
+Additional Environment methods include:
+
+.TP
+.RI Command( target ", " source ", " commands )
+Executes a specific command
+(or list of commands)
+to build a target file or files.
+This is more convenient
+than defining a separate Builder object
+for a single special-case build.
+
+.ES
+env.Command('foo.out', 'foo.in',
+ "$FOO_BUILD < $SOURCES > $TARGET")
+env.Command('bar.out', 'bar.in',
+ ["rm -f $TARGET",
+ "$BAR_BUILD < $SOURCES > $TARGET"])
+.EE
+
+.TP
+.RI Copy([ key = val ", ...])"
+Return a separate copy of a construction environment.
+If there are any keyword arguments specified,
+they are added to the returned copy,
+overwriting any existing values
+for the keywords.
+
+.ES
+env2 = env.Copy()
+env3 = env.Copy(CCFLAGS = '-g')
+.EE
-Additional methods include:
+.TP
+.RI Depends( target ", " dependency )
+Specifies an explicit dependency;
+the target file(s) will be rebuilt
+whenever the dependency file(s) has changed.
+This should only be necessary
+for cases where the dependency
+is not caught by a Scanner
+for the file.
+
+.ES
+env.Depends('foo', 'other-input-file-for-foo')
+.EE
+
+.TP
+.RI Dictionary([ vars ])
+Returns a dictionary object
+containing copies of all of the
+construction variables in the environment.
+If there are any variable names specified,
+only the specified construction
+variables are returned in the dictionary.
+
+.ES
+dict = env.Dictionary()
+cc_dict = env.Dictionary('CC', 'CCFLAGS', 'CCCOM')
+.EE
-.IP Install
+.TP
+.RI Install( dir ", " source )
Installs one or more files in a destination directory.
The file names remain the same.
-.IP
-.nf
+
+.ES
env.Install(dir = '/usr/local/bin', source = 'foo bar')
-.PP
-.fi
+.EE
-.IP InstallAs
-Installs one or more files as specific file names.
-This allows changing a file name as part of the
-installation:
-.IP
-.nf
-env.Install(dir = '/usr/local/bin/foo', source = 'foo_debug')
-env.Install(target = '../lib/libfoo.a ../lib/libbar.a',
- source = 'libFOO.a libBAR.a')
-.PP
-.fi
+.TP
+.RI InstallAs( target ", " source )
+Installs one or more files as specific file names,
+allowing changing a file name as part of the
+installation.
It is an error if the target and source
list different numbers of files.
+.ES
+env.InstallAs(target = '/usr/local/bin/foo',
+ source = 'foo_debug')
+env.InstallAs(target = '../lib/libfoo.a ../lib/libbar.a',
+ source = 'libFOO.a libBAR.a')
+.EE
+
+.TP
+.RI Update( key = val ", [...])"
+Updates the contents of an environment
+with the specified keyword arguments.
+
+.ES
+env.Update(CCFLAGS = '-g', FOO = 'foo.xxx')
+.EE
+
.SS Construction Variables
A construction environment has an associated dictionary of construction
by the user. The following is a list of the automatically defined construction
variables:
+.IP AR
+The static library command.
+
+.IP ARFLAGS
+General options passed to the static library command.
+
+.IP ARCOM
+The command line used to generate a static library from object files.
+
+.IP BUILDERS
+A list of the available builders.
+[CFile, Object, Program, Library] by default.
+
.IP CC
The C compiler.
.IP CCFLAGS
General options that are passed to the C compiler.
-.IP CCOM
+.IP CCCOM
The command line used to compile a C source file to an object file.
-.IP CXX
-The C++ compiler.
-
-.IP CXXFLAGS
-General options that are passed to the C++ compiler.
-
-.IP CXXCOM
-The command line used to compile a C++ source file to an object file.
-
.IP CPPPATH
The list of directories that the C preprocessor will search for include
directories. The C/C++ implicit dependency scanner will search these
directory when they are used in a command. To force
.B scons
to look-up a directory relative to the root of the source tree use #:
-.IP
-.nf
-env.Environment(CPPPATH='#/include')
-.PP
-.fi
-.RS
+
+.ES
+env = Environment(CPPPATH='#/include')
+.EE
+
The directory look-up can also be forced using the
.BR Dir ()
function:
-.RE
-.IP
-.nf
-include = Dir('include')
-env.Environment(CPPPATH=include)
-.PP
-.fi
-.RE
-
-.IP LINK
-The linker.
-
-.IP LINKFLAGS
-General options passed to the linker.
-
-.IP LINKCOM
-The command line used to link object files into an executable.
-
-.IP AR
-The static library command.
-
-.IP ARFLAGS
-General options passed to the static library command.
-
-.IP ARCOM
-The command line used to generate a static library from object files.
-
-.IP LEX
-The lexical analyzer generator.
-
-.IP LEXFLAGS
-General options passed to the lexical analyzer generator.
-
-.IP LEXCOM
-The command line used to call the lexical analyzer generator
-to generate a source file.
-
-.IP YACC
-The parser generator.
-
-.IP YACCFLAGS
-General options passed to the parser generator.
-
-.IP YACCCOM
-The command line used to call the parser generator
-to generate a source file.
-
-.IP BUILDERS
-A list of the available builders.
-[CFile, Object, Program, Library] by default.
-
-.IP SCANNERS
-A list of the available implicit dependency scanners. [CScan] by default.
-
-.IP OBJPREFIX
-The prefix used for object file names.
-
-.IP OBJSUFFIX
-The suffix used for object file names.
-
-.IP PROGPREFIX
-The prefix used for executable file names.
-
-.IP PROGSUFFIX
-The suffix used for executable file names.
-
-.IP LIBPREFIX
-The prefix used for library file names.
-
-.IP LIBSUFFIX
-The suffix used for library file names.
-
-.IP LIBDIRPREFIX
-The prefix used to specify a library directory on the linker command line.
-
-.IP LIBDIRASUFFIX
-The suffix used to specify a library directory on the linker command line.
-.IP LIBLINKPREFIX
-The prefix used to specify a library to link on the linker command line.
+.ES
+include = Dir('include')
+env = Environment(CPPPATH=include)
+.EE
-.IP LIBLINKSUFFIX
-The suffix used to specify a library to link on the linker command line.
+.IP CXX
+The C++ compiler.
-.IP INCPREFIX
-The prefix used to specify an include directory on the C compiler command
-line.
+.IP CXXFLAGS
+General options that are passed to the C++ compiler.
-.IP INCSUFFIX
-The suffix used to specify an include directory on the C compiler command
-line.
+.IP CXXCOM
+The command line used to compile a C++ source file to an object file.
.IP ENV
A dictionary of environment variables
to build target files,
you must do so explictly:
-.IP
-.nf
+.ES
import os
env = Environment(ENV = os.environ)
-.PP
-.fi
+.EE
+.RS
Note that you can choose only to propogate
certain environment variables.
A common example is
the system
.B PATH
-environment variable
-to force
+environment variable,
+so that
.B scons
-to use the same utilities
+uses the same utilities
as the invoking shell (or other process):
+.RE
-.IP
-.nf
+.ES
import os
env = Environment(ENV = {'PATH' : os.environ['PATH']})
-.PP
-.fi
+.EE
-.LP
+.IP INCPREFIX
+The prefix used to specify an include directory on the C compiler command
+line.
-Construction variables can be retrieved and set using the
-.B Dictionary
-method of the construction environment:
+.IP INCSUFFIX
+The suffix used to specify an include directory on the C compiler command
+line.
-.IP
-.nf
+.IP LEX
+The lexical analyzer generator.
+
+.IP LEXFLAGS
+General options passed to the lexical analyzer generator.
+
+.IP LEXCOM
+The command line used to call the lexical analyzer generator
+to generate a source file.
+
+.IP LIBDIRPREFIX
+The prefix used to specify a library directory on the linker command line.
+
+.IP LIBDIRASUFFIX
+The suffix used to specify a library directory on the linker command line.
+
+.IP LIBLINKPREFIX
+The prefix used to specify a library to link on the linker command line.
+
+.IP LIBLINKSUFFIX
+The suffix used to specify a library to link on the linker command line.
+
+.IP LIBPREFIX
+The prefix used for library file names.
+
+.IP LIBSUFFIX
+The suffix used for library file names.
+
+.IP LINK
+The linker.
+
+.IP LINKFLAGS
+General options passed to the linker.
+
+.IP LINKCOM
+The command line used to link object files into an executable.
+
+.IP OBJPREFIX
+The prefix used for object file names.
+
+.IP OBJSUFFIX
+The suffix used for object file names.
+
+.IP PROGPREFIX
+The prefix used for executable file names.
+
+.IP PROGSUFFIX
+The suffix used for executable file names.
+
+.IP SCANNERS
+A list of the available implicit dependency scanners. [CScan] by default.
+
+.IP YACC
+The parser generator.
+
+.IP YACCFLAGS
+General options passed to the parser generator.
+
+.IP YACCCOM
+The command line used to call the parser generator
+to generate a source file.
+
+.LP
+Construction variables can be retrieved and set using the
+.B Dictionary
+method of the construction environment:
+
+.ES
dict = env.Dictionary()
dict["CC"] = "cc"
-.PP
-.fi
+.EE
Construction variables can also be passed to the construction environment
constructor:
-.IP
-.nf
+.ES
env = Environment(CC="cc")
-.PP
-.fi
+.EE
or when copying a construction environment using the
.B Copy
method:
-.IP
-.nf
+.ES
env2 = env.Copy(CC="cl.exe")
-.PP
-.fi
+.EE
.SS Other Functions
.B scons
-also provides various function not associated with a construction
-environment that configuration files can use to affect the build:
+also provides various additional functions,
+not associated with a construction environment,
+that configuration files can use:
.TP
-.RI SConscript( script ", [" exports ])
-This tells
+.RI BuildDir( build_dir ", " src_dir ", [" duplicate ])
+This specifies a build directory to use for all derived files.
+.I build_dir
+specifies the build directory to be used for all derived files that would
+normally be built under
+.IR src_dir .
+Multiple build directories can be set up for multiple build variants, for
+example.
.B scons
-to execute .I script
-as a configuration file. The optional
-.I exports
-argument provides a list of variable names to export to
-.IR script ". " exports
-can also be a space delimited string of variables names.
-.I script
-must use the
-.BR Import ()
-function to import the variables. Any variables returned by
-.I script
-using
-.BR Return ()
-will be returned by the call to
-.BR SConscript ().
-Examples:
+will link or copy (depending on the platform) all the source files into the
+build directory if
+.I duplicate
+is set to 1 (the default). If
+.I duplicate
+is set to 0, then
+.B scons
+will not copy or link any source files, which may cause build problems in
+certain situations (e.g. C source files that are generated by the
+build).
+.IR duplicate =0
+is usually safe, and is always more efficient than
+.IR duplicate =1.
-.IP
-.nf
-SConscript('dir/SConscript')
-foo = SConscript('subdir/SConscript', "env")
-.PP
-.fi
+.TP
+.RI Default( targets )
+This specifies a list of default targets. Default targets will be built by
+.B scons
+if no explicit targets are given on the comamnd line. Multiple targets can
+be specified either as a space delimited string of target file names or as
+seperate arguments.
+Target names with white space may be be enclosed in an
+array to prevent the string from being split into
+separate file names.
+.BR Default ()
+will also accept the return value of any of the ccnstruction environment
+builder methods.
+Example:
+
+.ES
+Default('foo', 'bar', 'baz', ['file with whitespace'])
+.EE
+
+.TP
+.RI Dir( name ", [" directory ])
+This returns an object that represents a given directory
+.IR name .
+.I name
+can be a relative or absolute path.
+.I directory
+is an optional directory that will be used as the parent directory.
.TP
.RI Export( vars )
.BR Export ()
in a space delimited string or as seperate arguments. Example:
-.IP
-.nf
+.ES
Export("env")
-.PP
-.fi
+.EE
+
+.TP
+.RI File( name ", [" directory ])
+This returns an object that represents a given file
+.IR name .
+.I name
+can be a relative or absolute path.
+.I directory
+is an optional directory that will be used as the parent directory.
+
+.TP
+.RI Help( text )
+This specifies help text to be printed if the
+.B -h
+argument is given to
+.BR scons .
+.B scons
+will exit after printing out the help text.
.TP
.RI Import( vars )
.BR Import ()
in a space delimited string or as seperate arguments. Example:
-.IP
-.nf
+.ES
Import("env")
-.PP
-.fi
+.EE
.TP
.RI Return( vars )
.BR Return ()
in a space delimited string or as seperate arguments. Example:
-.IP
-.nf
+.ES
Return("foo")
-.PP
-.fi
-
-.TP
-.RI Default( targets )
-This specifies a list of default targets. Default targets will be built by
-.B scons
-if no explicit targets are given on the comamnd line. Multiple targets can
-be specified either as a space delimited string of target file names or as
-seperate arguments.
-Target names with white space may be be enclosed in an
-array to prevent the string from being split into
-separate file names.
-.BR Default ()
-will also accept the return value of any of the ccnstruction environment
-builder methods.
-Example:
-
-.IP
-.nf
-Default('foo', 'bar', 'baz', ['file with whitespace'])
-.PP
-.fi
-
-.TP
-.RI Help( text )
-This specifies help text to be printed if the
-.B -h
-argument is given to
-.BR scons .
-.B scons
-will exit after printing out the help text.
+.EE
.TP
-.RI BuildDir( build_dir ", " src_dir ", [" duplicate ])
-This specifies a build directory to use for all derived files.
-.I build_dir
-specifies the build directory to be used for all derived files that would
-normally be built under
-.IR src_dir .
-Multiple build directories can be set up for multiple build variants, for
-example.
+.RI SConscript( script ", [" exports ])
+This tells
.B scons
-will link or copy (depending on the platform) all the source files into the
-build directory if
-.I duplicate
-is set to 1 (the default). If
-.I duplicate
-is set to 0, then
-.B scons
-will not copy or link any source files, which may cause build problems in
-certain situations (e.g. C source files that are generated by the
-build).
-.IR duplicate =0
-is usually safe, and is always more efficient than
-.IR duplicate =1.
-
-.TP
-.RI Dir( name ", [" directory ])
-This returns an object that represents a given directory
-.IR name .
-.I name
-can be a relative or absolute path.
-.I directory
-is an optional directory that will be used as the parent directory.
-
-
-.TP
-.RI File( name ", [" directory ])
-This returns an object that represents a given file
-.IR name .
-.I name
-can be a relative or absolute path.
-.I directory
-is an optional directory that will be used as the parent directory.
+to execute
+.I script
+as a configuration file. The optional
+.I exports
+argument provides a list of variable names to export to
+.IR script ". " exports
+can also be a space delimited string of variables names.
+.I script
+must use the
+.BR Import ()
+function to import the variables. Any variables returned by
+.I script
+using
+.BR Return ()
+will be returned by the call to
+.BR SConscript ().
+Examples:
+.ES
+SConscript('dir/SConscript')
+foo = SConscript('subdir/SConscript', "env")
+.EE
.TP
.RI SetCommandHandler( function )
for interpreting and executing command-line strings.
The function must expect three arguments:
-.IP
-.nf
+.ES
def commandhandler(cmd, args, env):
-.PP
-.fi
+.EE
.I cmd
is the path to the command to be executed.
is a dictionary of the environment variables
in which the command should be executed.
-
.SH EXTENDING SCONS
.SS Builder Objects
.B scons
.IP Action
If the argument is already an Action object,
the object is simply returned.
+
.IP String
If the argument is a string,
a command-line Action is returned.
+
.IP Function
If the argument is a Python function,
a function Action is returned.
+
.IP List
If the argument is a list,
then a list of Action objects is returned.
prefix.
Besides construction variables, scons provides the following
variables for each command execution:
+
.IP TARGET
The file name of the target being built, or the file name of the first
target if multiple targets are being built.
+
.IP TARGETS
The file names of all targets being built.
+
.IP SOURCES
The file names of the sources of the build command.
.LP
For example, given the construction variable CC='cc', targets=['foo'], and
sources=['foo.c', 'bar.c']:
-.IP
-.nf
+.ES
action='$CC -c -o $TARGET $SOURCES'
-.PP
-.fi
+.EE
would produce the command line:
-.IP
-.nf
+.ES
cc -c -o foo foo.c bar.c
-.PP
-.fi
+.EE
Variable names may be surrounded by curly braces ({})
to separate the name from the trailing characters.
Within the curly braces, a variable name may have
a Python slice subscript appended to select one
or more items from a list.
In the previous example, the string:
-.IP
-.nf
+.ES
${SOURCES[1]}
-.PP
-.fi
+.EE
would produce:
-.IP
-.nf
+.ES
bar.c
-.PP
-.fi
+.EE
Additionally, a variable name may
have the following special
modifiers appended within the enclosing curly braces
Just the file suffix.
.LP
-
For example, the specified target will
expand as follows for the corresponding modifiers:
-.IP
-.nf
+.ES
$TARGET => sub/dir/file.x
${TARGET.base} => sub/dir/file
${TARGET.dir} => sub/dir
${TARGET.file} => file.x
${TARGET.filebase} => file
${TARGET.suffix} => .x
-.PP
-.fi
+.EE
.\" XXX document how to add user defined scanners.
.SS Basic Compilation From a Single Source File
-.RS
-.nf
+.ES
env = Environment()
env.Program(target = 'foo', source = 'foo.c')
-.RE
-.fi
+.EE
.SS Basic Compilation From Multiple Source Files
-.RS
-.nf
+.ES
env = Environment()
env.Program(target = 'foo', source = 'f1.c f2.c f3.c')
-.RE
-.fi
+.EE
.SS Setting a Compilation Flag
-.RS
-.nf
+.ES
env = Environment(CCFLAGS = '-g')
env.Program(target = 'foo', source = 'foo.c')
-.RE
-.fi
+.EE
.SS Search The Local Directory For .h Files
need to specify -I options by hand.
SCons will construct the right -I options from CPPPATH.
-.RS
-.nf
+.ES
env = Environment(CPPPATH = ['.'])
env.Program(target = 'foo', source = 'foo.c')
-.RE
-.fi
+.EE
.SS Search Multiple Directories For .h Files
-.RS
-.nf
+.ES
env = Environment(CPPPATH = ['include1', 'include2'])
env.Program(target = 'foo', source = 'foo.c')
-.RE
-.fi
+.EE
.SS Defining Your Own Builder Object
Notice also that you can leave off the suffixes,
and the builder will add them automatically.
-.RS
-.nf
+.ES
bld = Builder(name = 'PDFBuilder',
action = 'pdftex < $SOURCES > $TARGET'
suffix = '.pdf',
# The following creates "bar.pdf" from "bar.text"
env.PDFBuilder(target = 'bar', source = 'bar')
-.RE
-.fi
+.EE
.SS Creating a Hierarchical Build
Notice that the file names specified in a subdirectory
are relative to that subdirectory.
-.RS
-.nf
+.ES
SConstruct:
env = Environment()
env = Environment()
# Builds sub/dir/foo from sub/dir/foo.c
env.Program(target = 'foo', source = 'foo.c')
-.RE
-.fi
+.EE
.SS Sharing Variables Between SConscript Files
You must explicitly Export() and Import() variables that
you want to share between SConscript files.
-.RS
-.nf
+.ES
SConstruct:
env = Environment()
Import("env")
env.Program(target = 'foo', source = 'foo.c')
-.RE
-.fi
+.EE
.SS Building Multiple Variants From the Same Source
to specify the SConscript files
in the build directories:
-.RS
-.nf
+.ES
SConstruct:
Export("ccflags")
Import("ccflags")
env = Environment(CCFLAGS = ccflags)
env.Program(target = 'src', source = 'src.c')
-.RE
-.fi
+.EE
Note the use of the Export() method
to set the "ccflags" variable to a different
.SH AUTHORS
Steven Knight <knight@baldmt.com>
-.RS
-.RE
+.br
Anthony Roach <aroach@electriceyeball.com>