which use the environment that was
used to call the Builder for the target file.)
-.IP overrides
-A dictionary of construction variables
-that will be set in the executing
-construction environment when this
-Builder is invoked.
+Any additional keyword arguments supplied
+when a Builder object is created
+(that is, when the Builder() function is called)
+will be set in the executing construction
+environment when the Builder object is called.
The canonical example here would be
to set a construction variable to
the repository of a source code system.
Any additional keyword arguments supplied
-when a Builder object is called
-will be associated with the target
+when a Builder
+.I object
+is called
+will only be associated with the target
+created by that particular Builder call
(and any other files built as a
result of the call).
--debug=count and --debug=objects only print anything when run
under Python 2.1 or later.
+ - Deprecate the "overrides" keyword argument to Builder() creation
+ in favor of using keyword argument values directly (like we do
+ for builder execution and the like).
+
+ - Always use the Builder overrides in substitutions, not just if
+ there isn't a target-specific environment.
+
From Vincent Risi:
- Add support for the bcc32, ilink32 and tlib Borland tools.
into the SCons internals and calling either of the SCons.Util
functions directly.)
+ - The "overrides" keyword argument to calls to the Builder() function
+ used to create new Builder objects has been deprecated and will
+ be removed in a future release. The items in an "overrides"
+ dictionary should now be specified as keyword arguments:
+
+ # Old way, "overrides" is a dictionary:
+ Builder(action = 'cp $TDIR/$TARGET $SDIR/$SOURCE',
+ overrides = {'TDIR' : dir1, 'SDIR' : dir2})
+
+ # New way, items are specified as keyword arguments:
+ Builder(action = 'cp $TDIR/$TARGET $SDIR/$SOURCE',
+ TDIR = dir1, SDIR = dir2)
+
SCons is developed with an extensive regression test suite, and a
rigorous development methodology for continually improving that suite.
Because of this, SCons is of sufficient quality that you can use it
emitter = None,
multi = 0,
env = None,
- overrides = {}):
+ **overrides):
if __debug__: logInstanceCreation(self, 'BuilderBase')
self.action = SCons.Action.Action(action)
self.multi = multi
suffix = CallableSelector(suffix)
self.suffix = suffix
self.env = env
+ if overrides.has_key('overrides'):
+ SCons.Warnings.warn(SCons.Warnings.DeprecatedWarning,
+ "The \"overrides\" keyword to Builder() creation has been deprecated;\n" +\
+ "\tspecify the items as keyword arguments to the Builder() call instead.")
+ overrides.update(overrides['overrides'])
+ del overrides['overrides']
self.overrides = overrides
self.set_src_suffix(src_suffix)
class BuilderTestCase(unittest.TestCase):
+ def test__init__(self):
+ """Test simple Builder creation
+ """
+ builder = SCons.Builder.Builder(action="foo")
+ assert not builder is None, builder
+ builder = SCons.Builder.Builder(action="foo", OVERRIDE='x')
+ x = builder.overrides['OVERRIDE']
+ assert x == 'x', x
+
def test__nonzero__(self):
"""Test a builder raising an exception when __nonzero__ is called
"""
# So use the environment associated with the Builder
# itself.
env = self.builder.env
- overrides = self.builder.overrides
else:
# The normal case: use the Environment that was
# used to specify how these targets will be built.
env = self.env
- overrides = self.overrides
+ overrides = {}
+ overrides.update(self.builder.overrides)
+ overrides.update(self.overrides)
self.build_env = env.Override(overrides)
return self.build_env
def test_get_build_env(self):
"""Test fetching and generating a build environment"""
- x = SCons.Executor.Executor('b', 'e', 'o', 't', ['s1', 's2'])
+ x = SCons.Executor.Executor(MyBuilder('e', {}),
+ 'e',
+ {},
+ 't',
+ ['s1', 's2'])
x.build_env = 'eee'
be = x.get_build_env()
assert be == 'eee', be
- x = SCons.Executor.Executor('b',
+ x = SCons.Executor.Executor(MyBuilder('e', {}),
MyEnvironment(X='xxx'),
- {'O':'ooo'},
+ {'O':'o2'},
't',
['s1', 's2'])
be = x.get_build_env()
- assert be == {'O':'ooo', 'X':'xxx'}, be
+ assert be == {'O':'o2', 'X':'xxx'}, be
env = MyEnvironment(Y='yyy')
- over = {'O':'ooo'}
- x = SCons.Executor.Executor(MyBuilder(env, over), None, {}, 't', 's')
+ x = SCons.Executor.Executor(MyBuilder(env, {'O':'ob3'}),
+ None,
+ {'O':'oo3'},
+ 't',
+ 's')
+ be = x.get_build_env()
+ assert be == {'O':'oo3', 'Y':'yyy'}, be
+ x = SCons.Executor.Executor(MyBuilder(env, {'O':'ob3'}),
+ None,
+ {},
+ 't',
+ 's')
be = x.get_build_env()
- assert be == {'O':'ooo', 'Y':'yyy'}, be
+ assert be == {'O':'ob3', 'Y':'yyy'}, be
def test_get_action_list(self):
"""Test fetching and generating an action list"""
env['CVSCOM'] = '$CVS $CVSFLAGS co $CVSCOFLAGS -d ${TARGET.dir} $CVSMODULE${TARGET.posix}'
return SCons.Builder.Builder(action = '$CVSCOM',
env = env,
- overrides = {'CVSREPOSITORY':repos,
- 'CVSMODULE':module})
+ CVSREPOSITORY = repos,
+ CVSMODULE = module)
setattr(env, 'CVS', CVSFactory)
module = os.path.join(module, '')
return SCons.Builder.Builder(action = '$SVNCOM',
env = env,
- overrides = {'SVNREPOSITORY':repos,
- 'SVNMODULE':module})
+ SVNREPOSITORY = repos,
+ SVNMODULE = module)
setattr(env, 'Subversion', SubversionFactory)
test.write('SConstruct', """
env = Environment(LIBS=['a'])
def build(target, source, env):
- assert env['CC'] == 'mycc'
- assert env['LIBS'] == ['a','b']
-builder = Builder(action=build)
+ print "env['CC'] =", env['CC']
+ print "env['LIBS'] =", env['LIBS']
+builder = Builder(action=build, CC='buildcc', LIBS='buildlibs')
env['BUILDERS']['Build'] = builder
-Default(env.Build('foo', 'bar', CC='mycc', LIBS = env['LIBS']+['b']))
+foo = env.Build('foo.out', 'foo.in', CC='mycc', LIBS = env['LIBS']+['b'])
+bar = env.Build('bar.out', 'bar.in')
+Default([foo, bar])
+""")
+
+test.write('foo.in', "foo.in\n")
+test.write('bar.in', "bar.in\n")
+
+test.run(arguments = "-Q", stdout = """\
+build("foo.out", "foo.in")
+env['CC'] = mycc
+env['LIBS'] = ['a', 'b']
+build("bar.out", "bar.in")
+env['CC'] = buildcc
+env['LIBS'] = buildlibs
""")
-test.write('bar', "bar\n")
-test.run()
test.write('SConstruct', """
env = Environment()
test.up_to_date(arguments='hello.not_exe')
test.pass_test()
-
-