From: stevenknight Date: Tue, 11 Sep 2001 13:15:57 +0000 (+0000) Subject: Refactor the Builder binding so the calling Environment gets passed in. X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=0566a038e0616fa9514de0973a030a8ec9ae2260;p=scons.git Refactor the Builder binding so the calling Environment gets passed in. git-svn-id: http://scons.tigris.org/svn/scons/trunk@39 fdb21ef1-2011-0410-befe-b5e4ea1792b1 --- diff --git a/src/scons/Builder.py b/src/scons/Builder.py index ba489ec2..c11c9f38 100644 --- a/src/scons/Builder.py +++ b/src/scons/Builder.py @@ -37,9 +37,10 @@ class Builder: def __cmp__(self, other): return cmp(self.__dict__, other.__dict__) - def __call__(self, target = None, source = None): + def __call__(self, env, target = None, source = None): node = lookup(self.node_class, target) node.builder_set(self) + node.env_set(self) node.sources = source # XXX REACHING INTO ANOTHER OBJECT return node diff --git a/src/scons/Environment.py b/src/scons/Environment.py index da71ba17..9b050d16 100644 --- a/src/scons/Environment.py +++ b/src/scons/Environment.py @@ -62,8 +62,25 @@ class Environment: import scons.Defaults kw['BUILDERS'] = scons.Defaults.Builders[:] self.Dictionary.update(copy.deepcopy(kw)) + + class BuilderWrapper: + """Wrapper class that allows an environment to + be associated with a Builder at instantiation. + """ + def __init__(self, env, builder): + self.env = env + self.builder = builder + + def __call__(self, target = None, source = None): + return self.builder(self.env, target, source) + + def execute(self, **kw): + apply(self.builder.execute, (), kw) + for b in kw['BUILDERS']: - setattr(self, b.name, b) + setattr(self, b.name, BuilderWrapper(self, b)) + + def __cmp__(self, other): return cmp(self.Dictionary, other.Dictionary) diff --git a/src/scons/Node/__init__.py b/src/scons/Node/__init__.py index 767f2972..e4eb45a0 100644 --- a/src/scons/Node/__init__.py +++ b/src/scons/Node/__init__.py @@ -17,3 +17,6 @@ class Node: def builder_set(self, builder): self.builder = builder + + def env_set(self, env): + self.env = env