diff options
author | Gary Oberbrunner <garyo@oberbrunner.com> | 2012-08-01 00:10:43 (GMT) |
---|---|---|
committer | Gary Oberbrunner <garyo@oberbrunner.com> | 2012-08-01 00:10:43 (GMT) |
commit | 8d65f50e5b18d8840ba962f0e6bf7917262fb3bc (patch) | |
tree | b2fd6dd1ca922bd611dadc19b328d3794b459375 /src | |
parent | e5ed166538a2e12893346f9778cba8037f2dd847 (diff) | |
parent | b77f223a89efcd86ecf181b0a01c05302e008d86 (diff) | |
download | SCons-8d65f50e5b18d8840ba962f0e6bf7917262fb3bc.zip SCons-8d65f50e5b18d8840ba962f0e6bf7917262fb3bc.tar.gz SCons-8d65f50e5b18d8840ba962f0e6bf7917262fb3bc.tar.bz2 |
Merged in gward/scons (pull request #29: javac/pathopt)
Diffstat (limited to 'src')
-rw-r--r-- | src/engine/SCons/Tool/javac.py | 10 | ||||
-rw-r--r-- | src/engine/SCons/Tool/javacTests.py | 102 |
2 files changed, 108 insertions, 4 deletions
diff --git a/src/engine/SCons/Tool/javac.py b/src/engine/SCons/Tool/javac.py index fb6cc41..5d0e32a 100644 --- a/src/engine/SCons/Tool/javac.py +++ b/src/engine/SCons/Tool/javac.py @@ -150,13 +150,15 @@ class pathopt(object): if path and not SCons.Util.is_List(path): path = [path] if self.default: - path = path + [ env[self.default] ] + default = env[self.default] + if default: + if not SCons.Util.is_List(default): + default = [default] + path = path + default if path: - return [self.opt, os.pathsep.join(path)] - #return self.opt + " " + os.pathsep.join(path) + return [self.opt, os.pathsep.join(map(str, path))] else: return [] - #return "" def Java(env, target, source, *args, **kw): """ diff --git a/src/engine/SCons/Tool/javacTests.py b/src/engine/SCons/Tool/javacTests.py new file mode 100644 index 0000000..fc7f271 --- /dev/null +++ b/src/engine/SCons/Tool/javacTests.py @@ -0,0 +1,102 @@ +# +# __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. +# + +import os +import unittest + +import SCons.Tool.javac + +class DummyNode(object): + def __init__(self, val): + self.val = val + + def __str__(self): + return str(self.val) + +class pathoptTestCase(unittest.TestCase): + def assert_pathopt(self, expect, path): + popt = SCons.Tool.javac.pathopt('-foopath', 'FOOPATH') + env = {'FOOPATH': path} + actual = popt(None, None, env, None) + self.assertEquals(expect, actual) + + def assert_pathopt_default(self, expect, path, default): + popt = SCons.Tool.javac.pathopt('-foopath', 'FOOPATH', default='DPATH') + env = {'FOOPATH': path, + 'DPATH': default} + actual = popt(None, None, env, None) + self.assertEquals(expect, actual) + + def test_unset(self): + self.assert_pathopt([], None) + self.assert_pathopt([], '') + + def test_str(self): + self.assert_pathopt(['-foopath', '/foo/bar'], + '/foo/bar') + + def test_list_str(self): + self.assert_pathopt(['-foopath', '/foo%s/bar' % os.pathsep], + ['/foo', '/bar']) + + def test_uses_pathsep(self): + save = os.pathsep + try: + os.pathsep = '!' + self.assert_pathopt(['-foopath', 'foo!bar'], + ['foo', 'bar']) + finally: + os.pathsep = save + + def test_node(self): + self.assert_pathopt(['-foopath', '/foo'], + DummyNode('/foo')) + + def test_list_node(self): + self.assert_pathopt(['-foopath', '/foo:/bar'], + ['/foo', DummyNode('/bar')]) + + def test_default_str(self): + self.assert_pathopt_default( + ['-foopath', '/foo:/bar:/baz'], + ['/foo', '/bar'], + '/baz') + + def test_default_list(self): + self.assert_pathopt_default( + ['-foopath', '/foo:/bar:/baz'], + ['/foo', '/bar'], + ['/baz']) + + def test_default_unset(self): + self.assert_pathopt_default( + ['-foopath', '/foo'], + '/foo', + None) + self.assert_pathopt_default( + ['-foopath', '/foo'], + '/foo', + '') + +if __name__ == "__main__": + unittest.main() |