diff options
-rw-r--r-- | src/CHANGES.txt | 3 | ||||
-rw-r--r-- | src/engine/SCons/Node/FS.py | 2 | ||||
-rw-r--r-- | src/engine/SCons/Node/FSTests.py | 16 |
3 files changed, 21 insertions, 0 deletions
diff --git a/src/CHANGES.txt b/src/CHANGES.txt index 4f071a2..077f60b 100644 --- a/src/CHANGES.txt +++ b/src/CHANGES.txt @@ -115,6 +115,9 @@ RELEASE 0.09 - - Make -U and Default('source') fail gracefully. + - Allow the File() and Dir() methods to take a path-name string as + the starting directory, in addition to a Dir object. + From sam th: - Dynamically check for the existence of utilities with which to diff --git a/src/engine/SCons/Node/FS.py b/src/engine/SCons/Node/FS.py index 3e50d10..d66b777 100644 --- a/src/engine/SCons/Node/FS.py +++ b/src/engine/SCons/Node/FS.py @@ -395,6 +395,8 @@ class FS: if isinstance(name, Entry): return self.__checkClass(name, klass) else: + if directory and not isinstance(directory, Dir): + directory = self.Dir(directory) name, directory = self.__transformPath(name, directory) return self.__doLookup(klass, name, directory, create) diff --git a/src/engine/SCons/Node/FSTests.py b/src/engine/SCons/Node/FSTests.py index 9e6e095..c817408 100644 --- a/src/engine/SCons/Node/FSTests.py +++ b/src/engine/SCons/Node/FSTests.py @@ -907,7 +907,22 @@ class find_fileTestCase(unittest.TestCase): assert os.path.normpath('./foo') in file_names, file_names assert os.path.normpath('./bar/baz') in file_names, file_names +class StringDirTestCase(unittest.TestCase): + def runTest(self): + """Test using a string as the second argument of + File() and Dir()""" + test = TestCmd(workdir = '') + test.subdir('sub') + fs = SCons.Node.FS.FS(test.workpath('')) + + d = fs.Dir('sub', '.') + assert str(d) == 'sub' + assert d.exists() + f = fs.File('file', 'sub') + assert str(f) == os.path.join('sub', 'file') + assert not f.exists() + if __name__ == "__main__": suite = unittest.TestSuite() @@ -915,5 +930,6 @@ if __name__ == "__main__": suite.addTest(BuildDirTestCase()) suite.addTest(RepositoryTestCase()) suite.addTest(find_fileTestCase()) + suite.addTest(StringDirTestCase()) if not unittest.TextTestRunner().run(suite).wasSuccessful(): sys.exit(1) |