summaryrefslogtreecommitdiffstats
path: root/test/CC/CC.py
diff options
context:
space:
mode:
Diffstat (limited to 'test/CC/CC.py')
-rw-r--r--test/CC/CC.py117
1 files changed, 22 insertions, 95 deletions
diff --git a/test/CC/CC.py b/test/CC/CC.py
index 6363273..a548421 100644
--- a/test/CC/CC.py
+++ b/test/CC/CC.py
@@ -1,6 +1,8 @@
#!/usr/bin/env python
#
-# __COPYRIGHT__
+# MIT License
+#
+# Copyright The SCons Foundation
#
# Permission is hereby granted, free of charge, to any person obtaining
# a copy of this software and associated documentation files (the
@@ -20,106 +22,29 @@
# 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 os
import sys
import TestSCons
_python_ = TestSCons._python_
-_exe = TestSCons._exe
+_exe = TestSCons._exe
test = TestSCons.TestSCons()
test.dir_fixture('CC-fixture')
-
-if sys.platform == 'win32':
-
- test.write('mylink.py', r"""
-import sys
-args = sys.argv[1:]
-while args:
- a = args[0]
- if a == '-o':
- out = args[1]
- args = args[2:]
- continue
- if not a[0] in '/-':
- break
- args = args[1:]
- if a[:5].lower() == '/out:': out = a[5:]
-infile = open(args[0], 'rb')
-outfile = open(out, 'wb')
-for l in infile.readlines():
- if l[:8] != b'/*link*/':
- outfile.write(l)
-sys.exit(0)
-""")
-
- test.write('mycc.py', r"""
-import sys
-args = sys.argv[1:]
-inf = None
-while args:
- a = args[0]
- if a == '-o':
- out = args[1]
- args = args[2:]
- continue
- args = args[1:]
- if not a[0] in '-/':
- if not inf:
- inf = a
- continue
- if a[:3] == '/Fo': out = a[3:]
-infile = open(inf, 'rb')
-outfile = open(out, 'wb')
-for l in infile.readlines():
- if l[:6] != b'/*cc*/':
- outfile.write(l)
-sys.exit(0)
-""")
-
-else:
-
- test.write('mylink.py', r"""
-import getopt
-import sys
-opts, args = getopt.getopt(sys.argv[1:], 'o:')
-for opt, arg in opts:
- if opt == '-o': out = arg
-infile = open(args[0], 'rb')
-outfile = open(out, 'wb')
-for l in infile.readlines():
- if l[:8] != b'/*link*/':
- outfile.write(l)
-sys.exit(0)
-""")
-
- test.write('mycc.py', r"""
-import getopt
-import sys
-opts, args = getopt.getopt(sys.argv[1:], 'co:')
-for opt, arg in opts:
- if opt == '-o': out = arg
-infile = open(args[0], 'rb')
-outfile = open(out, 'wb')
-for l in infile.readlines():
- if l[:6] != b'/*cc*/':
- outfile.write(l)
-sys.exit(0)
-""")
+test.file_fixture('mylink.py')
test.write('SConstruct', """
cc = Environment().Dictionary('CC')
-env = Environment(LINK = r'%(_python_)s mylink.py',
- LINKFLAGS = [],
- CC = r'%(_python_)s mycc.py',
- CXX = cc,
- CXXFLAGS = [])
-env.Program(target = 'test1', source = 'test1.c')
+env = Environment(
+ LINK=r'%(_python_)s mylink.py',
+ LINKFLAGS=[],
+ CC=r'%(_python_)s mycc.py',
+ CXX=cc,
+ CXXFLAGS=[],
+)
+env.Program(target='test1', source='test1.c')
""" % locals())
test.run(arguments = '.', stderr = None)
@@ -130,10 +55,12 @@ if os.path.normcase('.c') == os.path.normcase('.C'):
test.write('SConstruct', """
cc = Environment().Dictionary('CC')
-env = Environment(LINK = r'%(_python_)s mylink.py',
- CC = r'%(_python_)s mycc.py',
- CXX = cc)
-env.Program(target = 'test2', source = 'test2.C')
+env = Environment(
+ LINK=r'%(_python_)s mylink.py',
+ CC=r'%(_python_)s mycc.py',
+ CXX=cc,
+)
+env.Program(target='test2', source='test2.C')
""" % locals())
test.run(arguments = '.', stderr = None)
@@ -144,9 +71,9 @@ test.file_fixture('wrapper.py')
test.write('SConstruct', """
foo = Environment()
cc = foo.Dictionary('CC')
-bar = Environment(CC = r'%(_python_)s wrapper.py ' + cc)
-foo.Program(target = 'foo', source = 'foo.c')
-bar.Program(target = 'bar', source = 'bar.c')
+bar = Environment(CC=r'%(_python_)s wrapper.py ' + cc)
+foo.Program(target='foo', source='foo.c')
+bar.Program(target='bar', source='bar.c')
""" % locals())
test.run(arguments = 'foo' + _exe)