diff options
author | William Deegan <bill@baddogconsulting.com> | 2017-10-22 00:30:45 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-10-22 00:30:45 (GMT) |
commit | a583f043aec89e58bf4ab0ab20cc039299eff1df (patch) | |
tree | dc4a8131e6e80288f723531c670dc4166d0a457c /src/engine | |
parent | 45d8610e424ab53faa519e39d04592dcbcb93b09 (diff) | |
parent | 6ed44024b2941de36c0b583fe9b29b7bea3bdbda (diff) | |
download | SCons-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.py | 9 |
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) |