summaryrefslogtreecommitdiffstats
path: root/src/engine
diff options
context:
space:
mode:
authorWilliam Deegan <bill@baddogconsulting.com>2017-10-22 00:30:45 (GMT)
committerGitHub <noreply@github.com>2017-10-22 00:30:45 (GMT)
commita583f043aec89e58bf4ab0ab20cc039299eff1df (patch)
treedc4a8131e6e80288f723531c670dc4166d0a457c /src/engine
parent45d8610e424ab53faa519e39d04592dcbcb93b09 (diff)
parent6ed44024b2941de36c0b583fe9b29b7bea3bdbda (diff)
downloadSCons-a583f043aec89e58bf4ab0ab20cc039299eff1df.zip
SCons-a583f043aec89e58bf4ab0ab20cc039299eff1df.tar.gz
SCons-a583f043aec89e58bf4ab0ab20cc039299eff1df.tar.bz2
Merge pull request #9 from ztessler/repeattarget
Fix incorrect warning of different environments
Diffstat (limited to 'src/engine')
-rw-r--r--src/engine/SCons/Builder.py9
1 files changed, 8 insertions, 1 deletions
diff --git a/src/engine/SCons/Builder.py b/src/engine/SCons/Builder.py
index afc2cf0..b5f1a92 100644
--- a/src/engine/SCons/Builder.py
+++ b/src/engine/SCons/Builder.py
@@ -291,7 +291,14 @@ def _node_errors(builder, env, tlist, slist):
if t.side_effect:
raise UserError("Multiple ways to build the same target were specified for: %s" % t)
if t.has_explicit_builder():
- if not t.env is None and not t.env is env:
+ # Check for errors when the environments are different
+ # No error if environments are the same Environment instance
+ if (not t.env is None and not t.env is env and
+ # Check OverrideEnvironment case - no error if wrapped Environments
+ # are the same instance, and overrides lists match
+ not (getattr(t.env, '__subject', 0) is getattr(env, '__subject', 1) and
+ getattr(t.env, 'overrides', 0) == getattr(env, 'overrides', 1) and
+ not builder.multi)):
action = t.builder.action
t_contents = t.builder.action.get_contents(tlist, slist, t.env)
contents = builder.action.get_contents(tlist, slist, env)