summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--doc/man/scons.118
-rw-r--r--src/CHANGES.txt5
-rw-r--r--src/engine/SCons/Defaults.py4
-rw-r--r--test/LEX/LEX.py (renamed from test/LEX.py)0
-rw-r--r--test/LEX/LEXCOM.py66
-rw-r--r--test/LEX/LEXCOMSTR.py71
-rw-r--r--test/LEX/LEXFLAGS.py (renamed from test/LEXFLAGS.py)0
-rw-r--r--test/YACC/YACC.py (renamed from test/YACC.py)0
-rw-r--r--test/YACC/YACCCOM.py66
-rw-r--r--test/YACC/YACCCOMSTR.py71
-rw-r--r--test/YACC/YACCFLAGS.py (renamed from test/YACCFLAGS.py)0
11 files changed, 297 insertions, 4 deletions
diff --git a/doc/man/scons.1 b/doc/man/scons.1
index 511dbac..6c11a6e 100644
--- a/doc/man/scons.1
+++ b/doc/man/scons.1
@@ -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,
diff --git a/src/CHANGES.txt b/src/CHANGES.txt
index de6502c..d89d29c 100644
--- a/src/CHANGES.txt
+++ b/src/CHANGES.txt
@@ -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:
diff --git a/src/engine/SCons/Defaults.py b/src/engine/SCons/Defaults.py
index 45e09e6..6f90f5b 100644
--- a/src/engine/SCons/Defaults.py
+++ b/src/engine/SCons/Defaults.py
@@ -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()
diff --git a/test/LEX.py b/test/LEX/LEX.py
index 3f596fb..3f596fb 100644
--- a/test/LEX.py
+++ b/test/LEX/LEX.py
diff --git a/test/LEX/LEXCOM.py b/test/LEX/LEXCOM.py
new file mode 100644
index 0000000..ea4626d
--- /dev/null
+++ b/test/LEX/LEXCOM.py
@@ -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
index 0000000..5b01df7
--- /dev/null
+++ b/test/LEX/LEXCOMSTR.py
@@ -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()
diff --git a/test/LEXFLAGS.py b/test/LEX/LEXFLAGS.py
index ba440da..ba440da 100644
--- a/test/LEXFLAGS.py
+++ b/test/LEX/LEXFLAGS.py
diff --git a/test/YACC.py b/test/YACC/YACC.py
index 062e4bc..062e4bc 100644
--- a/test/YACC.py
+++ b/test/YACC/YACC.py
diff --git a/test/YACC/YACCCOM.py b/test/YACC/YACCCOM.py
new file mode 100644
index 0000000..5f7cd38
--- /dev/null
+++ b/test/YACC/YACCCOM.py
@@ -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
index 0000000..cfb48b7
--- /dev/null
+++ b/test/YACC/YACCCOMSTR.py
@@ -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()
diff --git a/test/YACCFLAGS.py b/test/YACC/YACCFLAGS.py
index 022b238..022b238 100644
--- a/test/YACCFLAGS.py
+++ b/test/YACC/YACCFLAGS.py