- Fix use of VariantDir when the -n option is used and doesn't,
therefore, actually create the variant directory.
+ - Fix a stack trace from the --debug=includes option when passed a
+ static or shared library as an argument.
+
RELEASE 1.1.0 - Thu, 09 Oct 2008 08:33:47 -0700
env = self.get_build_env()
for s in self.sources:
scanner = self.get_source_scanner(s)
- path = self.get_build_scanner_path(scanner)
+ if scanner:
+ path = self.get_build_scanner_path(scanner)
+ else:
+ path = None
def f(node, env=env, scanner=scanner, path=path):
return node.get_found_includes(env, scanner, path)
return SCons.Util.render_tree(s, f, 1)
test = TestSCons.TestSCons()
test.write('SConstruct', """
-env = Environment(OBJSUFFIX = '.ooo', PROGSUFFIX = '.xxx')
-env.Program('foo', Split('foo.c bar.c'))
+env = Environment(OBJSUFFIX = '.obj',
+ SHOBJSUFFIX = '.shobj',
+ LIBPREFIX = '',
+ LIBSUFFIX = '.lib',
+ SHLIBPREFIX = '',
+ SHLIBSUFFIX = '.shlib',
+ )
+env.Program('foo.exe', ['foo.c', 'bar.c'])
+env.StaticLibrary('foo', ['foo.c', 'bar.c'])
+env.SharedLibrary('foo', ['foo.c', 'bar.c'])
""")
test.write('foo.c', r"""
+-foo.h
+-bar.h
"""
-test.run(arguments = "--debug=includes foo.ooo")
+test.run(arguments = "--debug=includes foo.obj")
if string.find(test.stdout(), includes) == -1:
print "Did not find expected string in standard output."
print test.stdout()
test.fail_test()
+
+
# In an ideal world, --debug=includes would also work when there's a build
# failure, but this would require even more complicated logic to scan
# all of the intermediate nodes that get skipped when the build failure
#THIS SHOULD CAUSE A BUILD FAILURE
#""")
-#test.run(arguments = "--debug=includes foo.xxx",
+#test.run(arguments = "--debug=includes foo.exe",
# status = 2,
# stderr = None)
#test.fail_test(string.find(test.stdout(), includes) == -1)
+
+
# These shouldn't print out anything in particular, but
# they shouldn't crash either:
test.run(arguments = "--debug=includes .")
test.run(arguments = "--debug=includes foo.c")
+test.run(arguments = "--debug=includes foo.lib")
+test.run(arguments = "--debug=includes foo.shlib")
+
+
test.pass_test()