summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSteven Knight <knight@baldmt.com>2005-05-15 02:04:41 (GMT)
committerSteven Knight <knight@baldmt.com>2005-05-15 02:04:41 (GMT)
commit63e62617c607f64bd79c4f7d0a903a550b14c067 (patch)
tree1fbb4eb0084c99d0c8abba25d6cbbcbcec9d42e5
parent29aa03f7d41976f71cbe16090abf42b1364bb0c8 (diff)
downloadSCons-63e62617c607f64bd79c4f7d0a903a550b14c067.zip
SCons-63e62617c607f64bd79c4f7d0a903a550b14c067.tar.gz
SCons-63e62617c607f64bd79c4f7d0a903a550b14c067.tar.bz2
Get rid of the requirement that a source directory must be under the SConstruct directory.
-rw-r--r--src/CHANGES.txt3
-rw-r--r--src/engine/SCons/Node/FS.py2
-rw-r--r--src/engine/SCons/Node/FSTests.py11
-rw-r--r--test/BuildDir/under.py94
4 files changed, 101 insertions, 9 deletions
diff --git a/src/CHANGES.txt b/src/CHANGES.txt
index 5edaafb..f8f09fd 100644
--- a/src/CHANGES.txt
+++ b/src/CHANGES.txt
@@ -282,6 +282,9 @@ RELEASE 0.97 - XXX
- Fix AddPreAction() and AddPostAction() when an action has more than
one target file: attach the actions to the Executor, not the Node.
+ - Allow the source directory of a BuildDir / build_dir to be outside
+ of the top-level SConstruct directory tree.
+
From Wayne Lee:
- Avoid "maximum recursion limit" errors when removing $(-$) pairs
diff --git a/src/engine/SCons/Node/FS.py b/src/engine/SCons/Node/FS.py
index 5ae14fc..9203e18 100644
--- a/src/engine/SCons/Node/FS.py
+++ b/src/engine/SCons/Node/FS.py
@@ -973,8 +973,6 @@ class FS(LocalFS):
src_dir = self.Dir(src_dir)
if not isinstance(build_dir, SCons.Node.Node):
build_dir = self.Dir(build_dir)
- if not src_dir.is_under(self.Top):
- raise SCons.Errors.UserError, "Source directory must be under top of build tree."
if src_dir.is_under(build_dir):
raise SCons.Errors.UserError, "Source directory cannot be under build directory."
if build_dir.srcdir:
diff --git a/src/engine/SCons/Node/FSTests.py b/src/engine/SCons/Node/FSTests.py
index 6978a03..1b31009 100644
--- a/src/engine/SCons/Node/FSTests.py
+++ b/src/engine/SCons/Node/FSTests.py
@@ -380,13 +380,10 @@ class BuildDirTestCase(unittest.TestCase):
assert (stat.S_IMODE(st[stat.ST_MODE]) & stat.S_IWRITE), \
stat.S_IMODE(st[stat.ST_MODE])
- exc_caught = 0
- try:
- fs = SCons.Node.FS.FS()
- fs.BuildDir('build', '/test/foo')
- except SCons.Errors.UserError:
- exc_caught = 1
- assert exc_caught, "Should have caught a UserError."
+ # This used to generate a UserError when we forbid the source
+ # directory from being outside the top-level SConstruct dir.
+ fs = SCons.Node.FS.FS()
+ fs.BuildDir('build', '/test/foo')
exc_caught = 0
try:
diff --git a/test/BuildDir/under.py b/test/BuildDir/under.py
new file mode 100644
index 0000000..9a3d561
--- /dev/null
+++ b/test/BuildDir/under.py
@@ -0,0 +1,94 @@
+#!/usr/bin/env python
+#
+# __COPYRIGHT__
+#
+# 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__"
+
+"""
+Test various combinations of build_dir when the source directory is,
+or is not, underneath the SConstruct directory.
+"""
+
+import TestSCons
+
+test = TestSCons.TestSCons()
+
+test.subdir('work', ['work', 'sub'], 'other')
+
+test.write(['work', 'SConscript'], """\
+f = Command("file.out", "file.in", Copy("$TARGET", "$SOURCE"))
+Default(f)
+""")
+
+test.write(['work', 'file.in'], "work/file.in\n")
+
+
+
+test.write(['work', 'sub', 'SConstruct'], """\
+SConscript('../SConscript', build_dir='build1')
+""")
+
+test.run(chdir='work/sub')
+
+test.must_match(['work', 'sub', 'build1', 'file.out'], "work/file.in\n")
+
+
+
+test.write(['work', 'sub', 'SConstruct'], """
+SConscript('../SConscript', build_dir='../build2')
+""")
+
+test.run(chdir='work/sub')
+
+test.must_match(['work', 'build2', 'file.out'], "work/file.in\n")
+
+
+
+test.write(['work', 'sub', 'SConstruct'], """
+SConscript('../SConscript', build_dir='../../build3')
+""")
+
+test.run(chdir='work/sub')
+
+test.must_match(['build3', 'file.out'], "work/file.in\n")
+
+
+
+test.write(['work', 'SConstruct'], """
+SConscript('../other/SConscript', build_dir='build4')
+""")
+
+test.write(['other', 'SConscript'], """\
+f = Command("file.out", "file.in", Copy("$TARGET", "$SOURCE"))
+Default(f)
+""")
+
+test.write(['other', 'file.in'], "other/file.in\n")
+
+test.run(chdir='work')
+
+test.must_match(['work', 'build4', 'file.out'], "other/file.in\n")
+
+
+
+test.pass_test()