SCons / src / scons /

The default branch has multiple heads




__revision__ = " __REVISION__ __DATE__ __DEVELOPER__"

import copy
import re
import types

def Command():
    pass	# XXX

def Install():
    pass	# XXX

def InstallAs():
    pass	# XXX

_cv = re.compile(r'%([_a-zA-Z]\w*|{[_a-zA-Z]\w*})')
_self = None

def _deepcopy_atomic(x, memo):
	return x
copy._deepcopy_dispatch[types.ModuleType] = _deepcopy_atomic
copy._deepcopy_dispatch[types.ClassType] = _deepcopy_atomic
copy._deepcopy_dispatch[types.FunctionType] = _deepcopy_atomic
copy._deepcopy_dispatch[types.MethodType] = _deepcopy_atomic
copy._deepcopy_dispatch[types.TracebackType] = _deepcopy_atomic
copy._deepcopy_dispatch[types.FrameType] = _deepcopy_atomic
copy._deepcopy_dispatch[types.FileType] = _deepcopy_atomic

class Environment:
    """Base class for construction Environments.  These are
    the primary objects used to communicate dependency and
    construction information to the build engine.

    Keyword arguments supplied when the construction Environment
    is created are construction variables used to initialize the

    def __init__(self, **kw):
	self.Dictionary = {}
	if kw.has_key('BUILDERS'):
	    builders = kw['BUILDERS']
	    if not type(builders) is types.ListType:
		kw['BUILDERS'] = [builders]
	    import scons.Defaults
	    kw['BUILDERS'] = scons.Defaults.Builders[:]
	for b in kw['BUILDERS']:
	    setattr(self,, b)

    def __cmp__(self, other):
	return cmp(self.Dictionary, other.Dictionary)

    def Builders(self):
	pass	# XXX

    def Copy(self, **kw):
	"""Return a copy of a construction Environment.  The
	copy is like a Python "deep copy"--that is, independent
	copies are made recursively of each objects--except that
	a reference is copied when an object is not deep-copyable
	(like a function).  There are no references to any mutable
	objects in the original Environment.
	return copy.deepcopy(self)

    def Scanners(self):
	pass	# XXX

    def	Update(self, **kw):
	"""Update an existing construction Environment with new
	construction variables and/or values.

    def subst(self, string):
	"""Recursively interpolates construction variables from the
	Environment into the specified string, returning the expanded
	result.  Construction variables are specified by a % prefix
	in the string and begin with an initial underscore or
	alphabetic character followed by any number of underscores
	or alphanumeric characters.  The construction variable names
	may be surrounded by curly braces to separate the name from
	trailing characters.
	global _self
	def repl(m):
	    key =
	    if key[:1] == '{' and key[-1:] == '}':
		key = key[1:-1]
	    if _self.Dictionary.has_key(key): return _self.Dictionary[key]
	    else: return ''
	n = 1
	while n != 0:
	    string, n = _cv.subn(repl, string)
	return string
Tip: Filter by directory path e.g. /media app.js to search for public/media/app.js.
Tip: Use camelCasing e.g. ProjME to search for
Tip: Filter by extension type e.g. /repo .js to search for all .js files in the /repo directory.
Tip: Separate your search with spaces e.g. /ssh pom.xml to search for src/ssh/pom.xml.
Tip: Use ↑ and ↓ arrow keys to navigate and return to view the file.
Tip: You can also navigate files with Ctrl+j (next) and Ctrl+k (previous) and view the file with Ctrl+o.
Tip: You can also navigate files with Alt+j (next) and Alt+k (previous) and view the file with Alt+o.