Add more command-line customizability: and .
authorstevenknight <stevenknight@fdb21ef1-2011-0410-befe-b5e4ea1792b1>
Mon, 15 Nov 2004 16:52:55 +0000 (16:52 +0000)
committerstevenknight <stevenknight@fdb21ef1-2011-0410-befe-b5e4ea1792b1>
Mon, 15 Nov 2004 16:52:55 +0000 (16:52 +0000)
git-svn-id: http://scons.tigris.org/svn/scons/trunk@1165 fdb21ef1-2011-0410-befe-b5e4ea1792b1

doc/man/scons.1
src/CHANGES.txt
src/engine/SCons/Defaults.py
test/LEX/LEX.py [moved from test/LEX.py with 100% similarity]
test/LEX/LEXCOM.py [new file with mode: 0644]
test/LEX/LEXCOMSTR.py [new file with mode: 0644]
test/LEX/LEXFLAGS.py [moved from test/LEXFLAGS.py with 100% similarity]
test/YACC/YACC.py [moved from test/YACC.py with 100% similarity]
test/YACC/YACCCOM.py [new file with mode: 0644]
test/YACC/YACCCOMSTR.py [new file with mode: 0644]
test/YACC/YACCFLAGS.py [moved from test/YACCFLAGS.py with 100% similarity]

index 511dbac00978865de42140a9827fb26e14fa7157..6c11a6e29f4bcb8aa7112840621b6c90558a9267 100644 (file)
@@ -5500,6 +5500,15 @@ General options passed to the lexical analyzer generator.
 The command line used to call the lexical analyzer generator
 to generate a source file.
 
+.IP LEXCOMSTR
+The string displayed when generating a source file
+using the lexical analyzer generator.
+If this is not set, then $LEXCOM (the command line) is displayed.
+
+.ES
+env = Environment(LEXCOMSTR = "Lex'ing $TARGET from $SOURCES")
+.EE
+
 .IP _LIBDIRFLAGS
 An automatically-generated construction variable
 containing the linker command-line options
@@ -6622,6 +6631,15 @@ The parser generator.
 The command line used to call the parser generator
 to generate a source file.
 
+.IP YACCCOMSTR
+The string displayed when generating a source file
+using the parser generator.
+If this is not set, then $YACCCOM (the command line) is displayed.
+
+.ES
+env = Environment(YACCCOMSTR = "Yacc'ing $TARGET from $SOURCES")
+.EE
+
 .IP YACCFLAGS
 General options passed to the parser generator.
 If $YACCFLAGS contains a \-d option,
index de6502cfcc48b754dd09c80a8fb1803b9406519b..d89d29cac02f38a6b8ab28d75b67c575b8c56acf 100644 (file)
@@ -131,8 +131,9 @@ RELEASE 0.97 - XXX
     source file names.
 
   - Support easier configurability of what's displayed by various default
-    actions through new construction variables:  $ASCOMSTR, $CCCOMSTR,
-    $CXXCOMSTR, $LINKCOMSTR, $SHCCCOMSTR and $SHCXXCOMSTR, $SHLINKCOMSTR.
+    actions by adding new construction variables:  $ASCOMSTR, $CCCOMSTR,
+    $CXXCOMSTR, $LEXCOMSTR, $LINKCOMSTR, $SHCCCOMSTR, $SHCXXCOMSTR,
+    $SHLINKCOMSTR and $YACCCOMSTR.
 
   From Wayne Lee:
 
index 45e09e65adf9a585be567aa62caace376132d031..6f90f5b3b7518571aea07305c773f2bf9507c925 100644 (file)
@@ -134,8 +134,8 @@ ShLinkAction = SCons.Action.Action("$SHLINKCOM", "$SHLINKCOMSTR")
 
 ArAction = SCons.Action.Action("$ARCOM")
 
-LexAction = SCons.Action.Action("$LEXCOM")
-YaccAction = SCons.Action.Action("$YACCCOM")
+LexAction = SCons.Action.Action("$LEXCOM", "$LEXCOMSTR")
+YaccAction = SCons.Action.Action("$YACCCOM", "$YACCCOMSTR")
 
 ProgScan = SCons.Scanner.Prog.ProgScan()
 
similarity index 100%
rename from test/LEX.py
rename to test/LEX/LEX.py
diff --git a/test/LEX/LEXCOM.py b/test/LEX/LEXCOM.py
new file mode 100644 (file)
index 0000000..ea4626d
--- /dev/null
@@ -0,0 +1,66 @@
+#!/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 the ability to configure the $LEXCOM construction variable.
+"""
+
+import TestSCons
+
+python = TestSCons.python
+
+test = TestSCons.TestSCons()
+
+
+
+test.write('mylex.py', """
+import sys
+outfile = open(sys.argv[1], 'wb')
+for f in sys.argv[2:]:
+    infile = open(f, 'rb')
+    for l in filter(lambda l: l != '/*lex*/\\n', infile.readlines()):
+        outfile.write(l)
+sys.exit(0)
+""")
+
+test.write('SConstruct', """
+env = Environment(tools=['default', 'lex'],
+                  LEXCOM = r'%s mylex.py $TARGET $SOURCES')
+env.CFile(target = 'aaa', source = 'aaa.l')
+env.CFile(target = 'bbb', source = 'bbb.lex')
+""" % python)
+
+test.write('aaa.l', "aaa.l\n/*lex*/\n")
+test.write('bbb.lex', "bbb.lex\n/*lex*/\n")
+
+test.run(arguments = '.')
+
+test.must_match('aaa.c', "aaa.l\n")
+test.must_match('bbb.c', "bbb.lex\n")
+
+
+
+test.pass_test()
diff --git a/test/LEX/LEXCOMSTR.py b/test/LEX/LEXCOMSTR.py
new file mode 100644 (file)
index 0000000..5b01df7
--- /dev/null
@@ -0,0 +1,71 @@
+#!/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 that the $LEXCOMSTR construction variable allows you to customize
+the displayed string when lex is called.
+"""
+
+import TestSCons
+
+python = TestSCons.python
+
+test = TestSCons.TestSCons()
+
+
+
+test.write('mylex.py', """
+import sys
+outfile = open(sys.argv[1], 'wb')
+for f in sys.argv[2:]:
+    infile = open(f, 'rb')
+    for l in filter(lambda l: l != '/*lex*/\\n', infile.readlines()):
+        outfile.write(l)
+sys.exit(0)
+""")
+
+test.write('SConstruct', """
+env = Environment(tools=['default', 'lex'],
+                  LEXCOM = r'%s mylex.py $TARGET $SOURCES',
+                  LEXCOMSTR = 'Lexing $TARGET from $SOURCE')
+env.CFile(target = 'aaa', source = 'aaa.l')
+env.CFile(target = 'bbb', source = 'bbb.lex')
+""" % python)
+
+test.write('aaa.l', "aaa.l\n/*lex*/\n")
+test.write('bbb.lex', "bbb.lex\n/*lex*/\n")
+
+test.run(stdout = test.wrap_stdout("""\
+Lexing aaa.c from aaa.l
+Lexing bbb.c from bbb.lex
+"""))
+
+test.must_match('aaa.c', "aaa.l\n")
+test.must_match('bbb.c', "bbb.lex\n")
+
+
+
+test.pass_test()
similarity index 100%
rename from test/LEXFLAGS.py
rename to test/LEX/LEXFLAGS.py
similarity index 100%
rename from test/YACC.py
rename to test/YACC/YACC.py
diff --git a/test/YACC/YACCCOM.py b/test/YACC/YACCCOM.py
new file mode 100644 (file)
index 0000000..5f7cd38
--- /dev/null
@@ -0,0 +1,66 @@
+#!/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 the ability to configure the $YACCCOM construction variable.
+"""
+
+import TestSCons
+
+python = TestSCons.python
+
+test = TestSCons.TestSCons()
+
+
+
+test.write('myyacc.py', """
+import sys
+outfile = open(sys.argv[1], 'wb')
+for f in sys.argv[2:]:
+    infile = open(f, 'rb')
+    for l in filter(lambda l: l != '/*yacc*/\\n', infile.readlines()):
+        outfile.write(l)
+sys.exit(0)
+""")
+
+test.write('SConstruct', """
+env = Environment(tools=['default', 'yacc'],
+                  YACCCOM = r'%s myyacc.py $TARGET $SOURCES')
+env.CFile(target = 'aaa', source = 'aaa.y')
+env.CFile(target = 'bbb', source = 'bbb.yacc')
+""" % python)
+
+test.write('aaa.y', "aaa.y\n/*yacc*/\n")
+test.write('bbb.yacc', "bbb.yacc\n/*yacc*/\n")
+
+test.run(arguments = '.')
+
+test.must_match('aaa.c', "aaa.y\n")
+test.must_match('bbb.c', "bbb.yacc\n")
+
+
+
+test.pass_test()
diff --git a/test/YACC/YACCCOMSTR.py b/test/YACC/YACCCOMSTR.py
new file mode 100644 (file)
index 0000000..cfb48b7
--- /dev/null
@@ -0,0 +1,71 @@
+#!/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 that the $YACCCOMSTR construction variable allows you to customize
+the displayed string when yacc is called.
+"""
+
+import TestSCons
+
+python = TestSCons.python
+
+test = TestSCons.TestSCons()
+
+
+
+test.write('myyacc.py', """
+import sys
+outfile = open(sys.argv[1], 'wb')
+for f in sys.argv[2:]:
+    infile = open(f, 'rb')
+    for l in filter(lambda l: l != '/*yacc*/\\n', infile.readlines()):
+        outfile.write(l)
+sys.exit(0)
+""")
+
+test.write('SConstruct', """
+env = Environment(tools=['default', 'yacc'],
+                  YACCCOM = r'%s myyacc.py $TARGET $SOURCES',
+                  YACCCOMSTR = 'Yaccing $TARGET from $SOURCE')
+env.CFile(target = 'aaa', source = 'aaa.y')
+env.CFile(target = 'bbb', source = 'bbb.yacc')
+""" % python)
+
+test.write('aaa.y', "aaa.y\n/*yacc*/\n")
+test.write('bbb.yacc', "bbb.yacc\n/*yacc*/\n")
+
+test.run(stdout = test.wrap_stdout("""\
+Yaccing aaa.c from aaa.y
+Yaccing bbb.c from bbb.yacc
+"""))
+
+test.must_match('aaa.c', "aaa.y\n")
+test.must_match('bbb.c', "bbb.yacc\n")
+
+
+
+test.pass_test()
similarity index 100%
rename from test/YACCFLAGS.py
rename to test/YACC/YACCFLAGS.py