- Add descriptions to the -H help text for -D, -u and -U so
people can tell them apart.
+ - Remove the old feature of automatically splitting strings
+ of file names on white space.
+
From Jeff Petkau:
- Fix --implicit-cache if the scanner returns an empty list.
"""Create and return lists of target and source nodes.
"""
def adjustixes(files, pre, suf):
+ if not files:
+ return []
ret = []
- # FOR RELEASE 0.08:
- #if not SCons.Util.is_List(files):
- # files = [files]
- files = SCons.Util.argmunge(files)
+ if not SCons.Util.is_List(files):
+ files = [files]
for f in files:
if SCons.Util.is_String(f):
assert target.name == 'n3'
assert target.sources[0].name == 'n4'
- targets = builder(env, target = 'n4 n5', source = ['n6 n7'])
- assert targets[0].name == 'n4'
- assert targets[0].sources[0].name == 'n6 n7'
- assert targets[1].name == 'n5'
- assert targets[1].sources[0].name == 'n6 n7'
+ target = builder(env, target = 'n4 n5', source = ['n6 n7'])
+ assert target.name == 'n4 n5'
+ assert target.sources[0].name == 'n6 n7'
target = builder(env, target = ['n8 n9'], source = 'n10 n11')
assert target.name == 'n8 n9'
- assert target.sources[0].name == 'n10'
- assert target.sources[1].name == 'n11'
+ assert target.sources[0].name == 'n10 n11'
if not hasattr(types, 'UnicodeType'):
uni = str
else:
uni = unicode
- targets = builder(env, target = uni('n12 n13'),
+ target = builder(env, target = uni('n12 n13'),
source = [uni('n14 n15')])
- assert targets[0].name == uni('n12')
- assert targets[0].sources[0].name == uni('n14 n15')
- assert targets[1].name == uni('n13')
- assert targets[1].sources[0].name == uni('n14 n15')
+ assert target.name == uni('n12 n13')
+ assert target.sources[0].name == uni('n14 n15')
target = builder(env, target = [uni('n16 n17')],
source = uni('n18 n19'))
assert target.name == uni('n16 n17')
- assert target.sources[0].name == uni('n18')
- assert target.sources[1].name == uni('n19')
+ assert target.sources[0].name == uni('n18 n19')
def test_noname(self):
"""Test deprecated warning for Builder name.
tgt = builder(env, target = 'tgt1', source = 'src1')
assert tgt.path == 'libtgt1', \
"Target has unexpected name: %s" % tgt.path
- tgts = builder(env, target = 'tgt2a tgt2b', source = 'src2')
- assert tgts[0].path == 'libtgt2a', \
- "Target has unexpected name: %s" % tgts[0].path
- assert tgts[1].path == 'libtgt2b', \
- "Target has unexpected name: %s" % tgts[1].path
+ tgt = builder(env, target = 'tgt2a tgt2b', source = 'src2')
+ assert tgt.path == 'libtgt2a tgt2b', \
+ "Target has unexpected name: %s" % tgt.path
def test_src_suffix(self):
"""Test Builder creation with a specified source file suffix
"Source has unexpected name: %s" % tgt.sources[0].path
tgt = b1(env, target = 'tgt3', source = 'src3a src3b')
- assert tgt.sources[0].path == 'src3a.c', \
+ assert len(tgt.sources) == 1
+ assert tgt.sources[0].path == 'src3a src3b.c', \
"Unexpected tgt.sources[0] name: %s" % tgt.sources[0].path
- assert tgt.sources[1].path == 'src3b.c', \
- "Unexpected tgt.sources[1] name: %s" % tgt.sources[1].path
b2 = SCons.Builder.Builder(name = "b2",
src_suffix = '.2',
assert builder.get_suffix(env,{}) == '.o', builder.get_suffix(env,{})
tgt = builder(env, target = 'tgt3', source = 'src3')
assert tgt.path == 'tgt3.o', \
- "Target has unexpected name: %s" % tgt[0].path
- tgts = builder(env, target = 'tgt4a tgt4b', source = 'src4')
- assert tgts[0].path == 'tgt4a.o', \
- "Target has unexpected name: %s" % tgts[0].path
- tgts = builder(env, target = 'tgt4a tgt4b', source = 'src4')
- assert tgts[1].path == 'tgt4b.o', \
- "Target has unexpected name: %s" % tgts[1].path
+ "Target has unexpected name: %s" % tgt.path
+ tgt = builder(env, target = 'tgt4a tgt4b', source = 'src4')
+ assert tgt.path == 'tgt4a tgt4b.o', \
+ "Target has unexpected name: %s" % tgt.path
def test_ListBuilder(self):
"""Testing ListBuilder class."""
action='bar',
src_builder = builder1,
src_suffix = '.foo')
- tgt = builder2(env, target='baz', source='test.bar test2.foo test3.txt')
+ tgt = builder2(env, target='baz', source=['test.bar', 'test2.foo', 'test3.txt'])
assert str(tgt.sources[0]) == 'test.foo', str(tgt.sources[0])
assert str(tgt.sources[0].sources[0]) == 'test.bar', \
str(tgt.sources[0].sources[0])
assert isinstance(tgt.builder, SCons.Builder.BuilderBase)
assert isinstance(tgt.builder.action.generator, SCons.Builder.DictCmdGenerator)
flag = 0
- tgt = builder(env, target='test2', source='test2.bar test1.foo')
+ tgt = builder(env, target='test2', source=['test2.bar', 'test1.foo'])
try:
tgt.build()
except SCons.Errors.BuildError, e:
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
+import string
import sys
import unittest
for tnode in tgt:
assert tnode.builder == InstallBuilder
- tgt = env.InstallAs(target='foo1 foo2', source='bar1 bar2')
+ tgt = env.InstallAs(target=string.split('foo1 foo2'),
+ source=string.split('bar1 bar2'))
assert len(tgt) == 2, len(tgt)
paths = map(lambda x: str(x.sources[0]), tgt)
paths.sort()
return dict[name]
nodes = SCons.Node.arg2nodes("Util.py UtilTests.py", Factory)
- assert len(nodes) == 2, nodes
+ assert len(nodes) == 1, nodes
assert isinstance(nodes[0], X)
- assert isinstance(nodes[1], X)
- assert nodes[0].name == "Util.py"
- assert nodes[1].name == "UtilTests.py"
+ assert nodes[0].name == "Util.py UtilTests.py"
if hasattr(types, 'UnicodeType'):
code = """if 1:
nodes = SCons.Node.arg2nodes(u"Util.py UtilTests.py", Factory)
- assert len(nodes) == 2, nodes
+ assert len(nodes) == 1, nodes
assert isinstance(nodes[0], X)
- assert isinstance(nodes[1], X)
- assert nodes[0].name == u"Util.py"
- assert nodes[1].name == u"UtilTests.py"
+ assert nodes[0].name == u"Util.py UtilTests.py"
\n"""
exec code in globals(), locals()
arg2nodes_lookups = []
-
-def arg2nodes(arg, node_factory=None):
- # FOR RELEASE 0.08:
- #"""This function converts a string or list into a list of Node
- #instances."""
- """This function converts a string or list into a list of Node instances.
- It follows the rules outlined in the SCons design document by accepting
- any of the following inputs:
- - A single string containing names separated by spaces. These will be
- split apart at the spaces.
+def arg2nodes(args, node_factory=None):
+ """This function converts a string or list into a list of Node
+ instances. It accepts the following inputs:
+ - A single string,
- A single Node instance,
- - A list containingg either strings or Node instances. Any strings
- in the list are not split at spaces.
- In all cases, the function returns a list of Node instances."""
+ - A list containing either strings or Node instances.
+ In all cases, strings are converted to Node instances, and the
+ function returns a list of Node instances."""
- # FOR RELEASE 0.08:
- #if not SCons.Util.is_List(arg):
- # arg = [arg]
- narg = SCons.Util.argmunge(arg)
+ if not args:
+ return []
+ if not SCons.Util.is_List(args):
+ args = [args]
nodes = []
- for v in narg:
+ for v in args:
if SCons.Util.is_String(v):
n = None
for l in arg2nodes_lookups:
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
import os.path
+import string
import sys
import types
import unittest
class ProgScanTestCase3(unittest.TestCase):
def runTest(self):
- env = DummyEnvironment(LIBPATH=test.workpath("d1/d2") + ' ' +\
- test.workpath("d1"),
- LIBS='l2 l3')
+ env = DummyEnvironment(LIBPATH=[test.workpath("d1/d2"),
+ test.workpath("d1")],
+ LIBS=string.split('l2 l3'))
s = SCons.Scanner.Prog.ProgScan()
deps = s.scan('dummy', env, DummyTarget())
assert deps_match(deps, ['d1/l2.lib', 'd1/d2/l3.lib']), map(str, deps)
code = """if 1:
class ProgScanTestCase4(unittest.TestCase):
def runTest(self):
- env = DummyEnvironment(LIBPATH=test.workpath("d1/d2") + ' ' +\
- test.workpath("d1"),
- LIBS=u'l2 l3')
+ env = DummyEnvironment(LIBPATH=[test.workpath("d1/d2"),
+ test.workpath("d1")],
+ LIBS=string.split(u'l2 l3'))
s = SCons.Scanner.Prog.ProgScan()
deps = s.scan('dummy', env, DummyTarget())
assert deps_match(deps, ['d1/l2.lib', 'd1/d2/l3.lib']), map(str, deps)
CC = r'%s mygcc.py cc',
CXX = r'%s mygcc.py c++',
F77 = r'%s mygcc.py g77')
-env.Program(target = 'foo', source = 'test1.c test2.cpp test3.F')
+env.Program(target = 'foo', source = Split('test1.c test2.cpp test3.F'))
""" % (python, python, python, python))
test.write('test1.c', r"""test1.c
# Change CPPPATH and make sure we don't rebuild because of it.
test.write('SConstruct', """
-env = Environment(CPPPATH = 'inc2 include')
+env = Environment(CPPPATH = Split('inc2 include'))
obj = env.Object(target='foobar/prog', source='subdir/prog.c')
env.Program(target='prog', source=obj)
SConscript('subdir/SConscript', "env")
env = Environment(BUILDERS = { 'B' : B })
env.B(target = 'foo.out', source = 'foo.in')
env.B(target = 'bar.out', source = 'bar.in')
-Default('foo.out bar.out')
+Default(Split('foo.out bar.out'))
""" % python)
test.write(['four', 'SConstruct'], """
env1.Library(target = './lib1/foo1', source = f1)
env2 = Environment(LIBS = 'foo2',
- LIBPATH = '. ./lib2')
+ LIBPATH = Split('. ./lib2'))
env2.Program(target = 'prog2', source = prog)
env2.Library(target = 'foo2', source = f1)
""")
test.write(['sub1', 'SConscript'], r"""
Import('env')
-lib = env.Library(target='bar', source='bar.c baz.c')
+lib = env.Library(target='bar', source=Split('bar.c baz.c'))
env.Install('..', lib)
""")
env = Environment(LIBS = [ 'foo1', 'foo2' ],
LIBPATH = [ '.' ])
env.Library(target = 'foo1', source = 'f1.c')
-env.Library(target = 'foo2', source = 'f2a.c f2b.c f2c.c')
+env.Library(target = 'foo2', source = Split('f2a.c f2b.c f2c.c'))
libtgt=env.Library(target = 'foo3', source = ['f3a.c', 'f3b.c', 'f3c.c'])
env.Program(target = 'prog', source = [ 'prog.c', libtgt ])
""")
f1 = env.Object(target = 'f1', source = 'f1.c')
f2 = env.Object(target = 'f2', source = 'f2.cpp')
f3 = env.Object(target = 'f3', source = 'f3.c')
-env.Program(target = 'prog1', source = 'f1%s f2%s f3%s prog.cpp')
+env.Program(target = 'prog1', source = Split('f1%s f2%s f3%s prog.cpp'))
env.Program(target = 'prog2', source = [f1, f2, f3, 'prog.cpp'])
env.Program(target = 'prog3', source = ['f1%s', f2, 'f3%s', 'prog.cpp'])
""" % (_obj, _obj, _obj, _obj, _obj))
test.write('SConstruct', """
env = Environment()
env.Program(target = 'foo1', source = 'f1.c')
-env.Program(target = 'foo2', source = 'f2a.c f2b.c f2c.c')
+env.Program(target = 'foo2', source = Split('f2a.c f2b.c f2c.c'))
env.Program(target = 'foo3', source = ['f3a.c', 'f3b.c', 'f3c.c'])
""")
env2 = Environment(LIBS = [ 'foo1', 'foo2', 'foo3' ],
LIBPATH = [ '.' ])
env.Library(target = 'foo1', source = 'f1.c', shared=1)
-env.Library(target = 'foo2', source = 'f2a.c f2b.c f2c.c', shared=1)
+env.Library(target = 'foo2', source = Split('f2a.c f2b.c f2c.c'), shared=1)
env.Library(target = 'foo3', source = ['f3a.c', 'f3b.c', 'f3c.c'], shared=1)
env2.Program(target = 'prog', source = 'prog.c')
""")
test.write('SConstruct', """
env = Environment(OBJSUFFIX = '.ooo', PROGSUFFIX = '.xxx')
-env.Program('foo', 'foo.c bar.c')
+env.Program('foo', Split('foo.c bar.c'))
""")
test.write('foo.c', r"""
test.subdir('include', 'subdir', ['subdir', 'include'], 'inc2')
test.write('SConstruct', """
-env = Environment(CPPPATH = 'inc2 include')
+env = Environment(CPPPATH = Split('inc2 include'))
obj = env.Object(target='prog', source='subdir/prog.c')
env.Program(target='prog', source=obj)
SConscript('subdir/SConscript', "env")