assert node.implicit[3] == [two, three]
assert node.implicit[4] == [three, four, one]
+ def test_add_ignore(self):
+ """Test adding files whose dependencies should be ignored.
+ """
+ node = SCons.Node.Node()
+ assert node.ignore == []
+
+ zero = SCons.Node.Node()
+ try:
+ node.add_ignore(zero)
+ except TypeError:
+ pass
+ else:
+ assert 0
+
+ one = SCons.Node.Node()
+ two = SCons.Node.Node()
+ three = SCons.Node.Node()
+ four = SCons.Node.Node()
+
+ node.add_ignore([one])
+ assert node.ignore == [one]
+ node.add_ignore([two, three])
+ assert node.ignore == [one, two, three]
+ node.add_ignore([three, four, one])
+ assert node.ignore == [one, two, three, four]
+
+ assert zero.get_parents() == []
+ assert one.get_parents() == [node]
+ assert two.get_parents() == [node]
+ assert three.get_parents() == [node]
+ assert four.get_parents() == [node]
+
def test_scan(self):
"""Test Scanner functionality"""
class DummyScanner:
self.sources = [] # source files used to build node
self.depends = [] # explicit dependencies (from Depends)
self.implicit = {} # implicit (scanned) dependencies
+ self.ignore = [] # dependencies to ignore
self.parents = []
self.wkids = None # Kids yet to walk, when it's an array
self.builder = None
"""Adds dependencies. The depend argument must be a list."""
self._add_child(self.depends, depend)
+ def add_ignore(self, depend):
+ """Adds dependencies to ignore. The depend argument must be a list."""
+ self._add_child(self.ignore, depend)
+
def add_source(self, source):
"""Adds sources. The source argument must be a list."""
self._add_child(self.sources, source)
def children(self):
#XXX Need to remove duplicates from this
- return self.sources \
- + self.depends \
- + reduce(lambda x, y: x + y, self.implicit.values(), [])
+ return filter(lambda x, i=self.ignore: x not in i,
+ self.sources \
+ + self.depends \
+ + reduce(lambda x, y: x + y, self.implicit.values(), []))
def get_parents(self):
return self.parents
--- /dev/null
+#!/usr/bin/env python
+#
+# Copyright (c) 2001 Steven Knight
+#
+# Permission is hereby granted, free of charge, to any person obtaining
+# a copy of this software and associated documentation files (the
+# "Software"), to deal in the Software without restriction, including
+# without limitation the rights to use, copy, modify, merge, publish,
+# distribute, sublicense, and/or sell copies of the Software, and to
+# permit persons to whom the Software is furnished to do so, subject to
+# the following conditions:
+#
+# The above copyright notice and this permission notice shall be included
+# in all copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
+# KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
+# WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+#
+
+__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
+
+import sys
+import TestSCons
+
+python = sys.executable
+
+test = TestSCons.TestSCons()
+
+test.subdir('subdir')
+
+test.write('build.py', r"""
+import sys
+contents = open(sys.argv[2], 'rb').read() + open(sys.argv[3], 'rb').read()
+file = open(sys.argv[1], 'wb')
+for arg in sys.argv[2:]:
+ file.write(open(arg, 'rb').read())
+file.close()
+""")
+
+test.write('SConstruct', """
+Foo = Builder(name = "Foo",
+ action = r"%s build.py $TARGET $SOURCES")
+Bar = Builder(name = "Bar",
+ action = r"%s build.py $TARGET $SOURCES")
+env = Environment(BUILDERS = [Foo, Bar])
+env.Foo(target = 'f1.out', source = ['f1a.in', 'f1b.in'])
+env.Ignore(target = 'f1.out', dependency = 'f1b.in')
+SConscript('subdir/SConscript', "env")
+""" % (python, python))
+
+test.write(['subdir', 'SConscript'], """
+Import("env")
+env.Bar(target = 'f2.out', source = ['f2a.in', 'f2b.in'])
+env.Ignore('f2.out', 'f2a.in')
+""")
+
+test.write('f1a.in', "f1a.in\n")
+test.write('f1b.in', "f1b.in\n")
+
+test.write(['subdir', 'f2a.in'], "subdir/f2a.in\n")
+test.write(['subdir', 'f2b.in'], "subdir/f2b.in\n")
+
+test.run(arguments = '.')
+
+test.fail_test(test.read('f1.out') != "f1a.in\nf1b.in\n")
+test.fail_test(test.read(['subdir', 'f2.out']) !=
+ "subdir/f2a.in\nsubdir/f2b.in\n")
+
+test.up_to_date(arguments = '.')
+
+test.write('f1b.in', "f1b.in 2\n")
+test.write(['subdir', 'f2a.in'], "subdir/f2a.in 2\n")
+
+test.up_to_date(arguments = '.')
+
+test.fail_test(test.read('f1.out') != "f1a.in\nf1b.in\n")
+test.fail_test(test.read(['subdir', 'f2.out']) !=
+ "subdir/f2a.in\nsubdir/f2b.in\n")
+
+test.write('f1a.in', "f1a.in 2\n")
+test.write(['subdir', 'f2b.in'], "subdir/f2b.in 2\n")
+
+test.run(arguments = '.')
+
+test.fail_test(test.read('f1.out') != "f1a.in 2\nf1b.in 2\n")
+test.fail_test(test.read(['subdir', 'f2.out']) !=
+ "subdir/f2a.in 2\nsubdir/f2b.in 2\n")
+
+test.up_to_date(arguments = '.')
+
+test.pass_test()