summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDirk Baechle <dl9obn@darc.de>2014-09-27 18:23:41 +0200
committerDirk Baechle <dl9obn@darc.de>2014-09-27 18:23:41 +0200
commit8cfb5d1b3c9ec0497d018f435c7238b22cbb644d (patch)
treef337d53b5bb0551974489b2b5ae5842161d8e2f1
parentc589e32384fe5d8879515b9728d147968fa5b0c0 (diff)
downloadscons-8cfb5d1b3c9ec0497d018f435c7238b22cbb644d.tar.gz
- fix for issue #2971 (Interactive build doesn't work anymore)
-rw-r--r--src/CHANGES.txt6
-rw-r--r--src/engine/SCons/Script/Main.py9
-rw-r--r--test/Interactive/configure.py106
3 files changed, 117 insertions, 4 deletions
diff --git a/src/CHANGES.txt b/src/CHANGES.txt
index d5161315..58071ab2 100644
--- a/src/CHANGES.txt
+++ b/src/CHANGES.txt
@@ -6,9 +6,9 @@
RELEASE VERSION/DATE TO BE FILLED IN LATER
- From John Doe:
-
- - Whatever John Doe did.
+ From Bernhard Walle and Dirk Baechle:
+ - Fixed the interactive mode, in connection with
+ Configure contexts (#2971).
RELEASE 2.3.3 - Sun, 24 Aug 2014 21:08:33 -0400
diff --git a/src/engine/SCons/Script/Main.py b/src/engine/SCons/Script/Main.py
index 439b8698..c7a9d27f 100644
--- a/src/engine/SCons/Script/Main.py
+++ b/src/engine/SCons/Script/Main.py
@@ -953,6 +953,14 @@ def _main(parser):
if options.include_dir:
sys.path = options.include_dir + sys.path
+ # If we're about to start SCons in the interactive mode,
+ # inform the FS about this right here. Else, the release_target_info
+ # method could get called on some nodes, like the used "gcc" compiler,
+ # when using the Configure methods within the SConscripts.
+ # This would then cause subtle bugs, as already happened in #2971.
+ if options.interactive:
+ SCons.Node.interactive = True
+
# That should cover (most of) the options. Next, set up the variables
# that hold command-line arguments, so the SConscript files that we
# read and execute have access to them.
@@ -1082,7 +1090,6 @@ def _main(parser):
platform = SCons.Platform.platform_module()
if options.interactive:
- SCons.Node.interactive = True
SCons.Script.Interactive.interact(fs, OptionsParser, options,
targets, target_top)
diff --git a/test/Interactive/configure.py b/test/Interactive/configure.py
new file mode 100644
index 00000000..ceb1aea2
--- /dev/null
+++ b/test/Interactive/configure.py
@@ -0,0 +1,106 @@
+#!/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__"
+
+"""
+Verify basic operation of the --interactive command line option to build
+a target, while using a Configure context within the environment.
+
+Also tests that "b" can be used as a synonym for "build".
+"""
+
+import TestSCons
+
+test = TestSCons.TestSCons()
+
+test.write('SConstruct', """\
+import sys
+
+env = Environment()
+
+conf = Configure(env)
+if not conf.CheckCXX():
+ sys.exit(1)
+conf.Finish()
+
+env.Program('foo','foo.cpp')
+""")
+
+test.write('foo.cpp', """\
+#include <stdio.h>
+
+int main (int argc, char *argv[])
+{
+ printf("Hello, World!");
+ return 0;
+}
+""")
+
+
+scons = test.start(arguments = '-Q --interactive')
+# Initial build
+scons.send("build foo\n")
+
+test.wait_for(test.workpath('foo'))
+# Update without any changes -> no action
+scons.send("build foo\n")
+# Changing the source file
+test.write('foo.cpp', """\
+#include <stdio.h>
+
+void foo()
+{
+ ;
+}
+
+int main (int argc, char *argv[])
+{
+ printf("Hello, World!");
+ return 0;
+}
+""")
+
+# Verify that "b" can be used as a synonym for the "build" command.
+scons.send("b foo\n")
+
+scons.send("build foo\n")
+
+expect_stdout = r"""scons>>> .*foo\.cpp.*
+.*foo.*
+scons>>> .*foo\.cpp.*
+.*foo.*
+scons>>> scons: `foo' is up to date.
+scons>>> scons: `foo' is up to date.
+scons>>>\s*
+"""
+
+test.finish(scons, stdout = expect_stdout, match=TestSCons.match_re)
+
+test.pass_test()
+
+# Local Variables:
+# tab-width:4
+# indent-tabs-mode:nil
+# End:
+# vim: set expandtab tabstop=4 shiftwidth=4: