Package SCons :: Module Util
[hide private]
[frames] | no frames]

Module Util

source code

SCons.Util

Various utility functions go here.



Classes [hide private]
  NodeList
This class is almost exactly like a regular list of Nodes (actually it can hold any object), with one important difference.
  DisplayEngine
  Proxy
A simple generic Proxy class, forwarding all calls to subject.
  Delegate
A Python Descriptor class that delegates attribute fetches to an underlying wrapped subject of a Proxy.
  _NoError
  RegError
  WindowsError
  CLVar
A class for command-line construction variables.
  OrderedDict
  Selector
A callable ordered dictionary that maps file suffixes to dictionary values.
  LogicalLines
  UniqueList
  Unbuffered
A proxy class that wraps a file object, flushing after every write, and delegating everything else to the wrapped object.
  Null
Null objects always and reliably "do nothing."
  NullSeq
Functions [hide private]
 
dictify(keys, values, result={}) source code
 
rightmost_separator(path, sep) source code
 
containsAny(str, set)
Check whether sequence str contains ANY of the items in set.
source code
 
containsAll(str, set)
Check whether sequence str contains ALL of the items in set.
source code
 
containsOnly(str, set)
Check whether sequence str contains ONLY items in set.
source code
 
splitext(path)
Same as os.path.splitext() but faster.
source code
 
updrive(path)
Make the drive letter (if any) upper case.
source code
 
get_environment_var(varstr)
Given a string, first determine if it looks like a reference to a single environment variable, like "$FOO" or "${FOO}".
source code
 
render_tree(root, child_func, prune=0, margin=[0], visited={})
Render a tree of nodes into an ASCII tree view.
source code
 
IDX(N) source code
 
print_tree(root, child_func, prune=0, showtags=0, margin=[0], visited={})
Print a tree of nodes.
source code
 
is_Dict(obj, isinstance=<built-in function isinstance>, DictTypes=DictTypes) source code
 
is_List(obj, isinstance=<built-in function isinstance>, ListTypes=list, UserList) source code
 
is_Sequence(obj, isinstance=<built-in function isinstance>, SequenceTypes=(<type 'list'>, <type 'tuple'>, <class UserList.UserList at 0x...) source code
 
is_Tuple(obj, isinstance=<built-in function isinstance>, tuple=<type 'tuple'>) source code
 
is_String(obj, isinstance=<built-in function isinstance>, StringTypes=(<type 'str'>, <type 'unicode'>, <class UserString.UserString ...) source code
 
is_Scalar(obj, isinstance=<built-in function isinstance>, StringTypes=(<type 'str'>, <type 'unicode'>, <class UserString.UserString ..., SequenceTypes=(<type 'list'>, <type 'tuple'>, <class UserList.UserList at 0x...) source code
 
do_flatten(sequence, result, isinstance=<built-in function isinstance>, StringTypes=(<type 'str'>, <type 'unicode'>, <class UserString.UserString ..., SequenceTypes=(<type 'list'>, <type 'tuple'>, <class UserList.UserList at 0x...) source code
 
flatten(obj, isinstance=<built-in function isinstance>, StringTypes=(<type 'str'>, <type 'unicode'>, <class UserString.UserString ..., SequenceTypes=(<type 'list'>, <type 'tuple'>, <class UserList.UserList at 0x..., do_flatten=<function do_flatten at 0x82ba534>)
Flatten a sequence to a non-nested list.
source code
 
flatten_sequence(sequence, isinstance=<built-in function isinstance>, StringTypes=(<type 'str'>, <type 'unicode'>, <class UserString.UserString ..., SequenceTypes=(<type 'list'>, <type 'tuple'>, <class UserList.UserList at 0x..., do_flatten=<function do_flatten at 0x82ba534>)
Flatten a sequence to a non-nested list.
source code
 
to_String(s, isinstance=<built-in function isinstance>, str=<type 'str'>, UserString=<class UserString.UserString at 0x829bf2c>, BaseStringTypes=(<type 'str'>, <type 'unicode'>)) source code
 
to_String_for_subst(s, isinstance=<built-in function isinstance>, str=<type 'str'>, to_String=<function to_String at 0x83b717c>, BaseStringTypes=(<type 'str'>, <type 'unicode'>), SequenceTypes=(<type 'list'>, <type 'tuple'>, <class UserList.UserList at 0x..., UserString=<class UserString.UserString at 0x829bf2c>) source code
 
to_String_for_signature(obj, to_String_for_subst=<function to_String_for_subst at 0x83b7924>, AttributeError=<type 'exceptions.AttributeError'>) source code
 
_semi_deepcopy_dict(x) source code
 
_semi_deepcopy_list(x) source code
 
_semi_deepcopy_tuple(x) source code
 
_semi_deepcopy_inst(x) source code
 
semi_deepcopy(x) source code
 
RegGetValue(root, key) source code
 
RegOpenKeyEx(root, key) source code
 
WhereIs(file, path=False, pathext=False, reject=[]) source code
 
PrependPath(oldpath, newpath, sep=':', delete_existing=1, canonicalize=False)
This prepends newpath elements to the given oldpath.
source code
 
AppendPath(oldpath, newpath, sep=':', delete_existing=1, canonicalize=False)
This appends new path elements to the given old path.
source code
 
get_native_path(path)
Transforms an absolute path into a native path for the system.
source code
 
Split(arg) source code
 
case_sensitive_suffixes(s1, s2) source code
 
adjustixes(fname, pre, suf, ensure_suffix=False) source code
 
unique(s)
Return a list of the elements in s, but without duplicates.
source code
 
uniquer(seq, idfun=False) source code
 
uniquer_hashables(seq) source code
 
make_path_relative(path)
makes an absolute path name to a relative pathname.
source code
 
AddMethod(obj, function, name=False)
Adds either a bound method to an instance or an unbound method to a class.
source code
 
RenameFunction(function, name)
Returns a function identical to the specified function, but with the specified name.
source code
 
MD5signature(s) source code
 
MD5filesignature(fname, chunksize=65536) source code
 
MD5collect(signatures)
Collects a list of signatures into an aggregate signature.
source code
 
silent_intern(x)
Perform sys.intern() on the passed argument and return the result.
source code
Variables [hide private]
  _altsep = False
  _get_env_var = re.compile(r'^\$([_a-zA-Z]\w*|\{[_a-zA-Z]\w*\})$')
  DictTypes = (<type 'dict'>, <class UserDict.UserDict at 0xb7e1...
  ListTypes = (<type 'list'>, <class UserList.UserList at 0x829b...
  SequenceTypes = (<type 'list'>, <type 'tuple'>, <class UserLis...
  StringTypes = (<type 'str'>, <type 'unicode'>, <class UserStri...
  BaseStringTypes = (<type 'str'>, <type 'unicode'>)
  d = {<type 'instance'>: <function _semi_deepcopy_inst at 0x83b...
  _semi_deepcopy_dispatch = {<type 'instance'>: <function _semi_...
  can_read_reg = 0
  hkey_mod = win32con
  RegEnumKey = win32api.RegEnumKey
  RegEnumValue = win32api.RegEnumValue
  RegQueryValueEx = win32api.RegQueryValueEx
  HKEY_CLASSES_ROOT = False
  HKEY_LOCAL_MACHINE = False
  HKEY_CURRENT_USER = False
  HKEY_USERS = False
  display = SCons.Util.display
  md5 = True
Function Details [hide private]

updrive(path)

source code 

Make the drive letter (if any) upper case.
This is useful because Windows is inconsitent on the case
of the drive letter, which can cause inconsistencies when
calculating command signatures.

get_environment_var(varstr)

source code 
Given a string, first determine if it looks like a reference
to a single environment variable, like "$FOO" or "${FOO}".
If so, return that variable with no decorations ("FOO").
If not, return None.

render_tree(root, child_func, prune=0, margin=[0], visited={})

source code 

Render a tree of nodes into an ASCII tree view.
root - the root node of the tree
child_func - the function called to get the children of a node
prune - don't visit the same node twice
margin - the format of the left margin to use for children of root.
   1 results in a pipe, and 0 results in no pipe.
visited - a dictionary of visited nodes in the current branch if not prune,
   or in the whole tree if prune.

print_tree(root, child_func, prune=0, showtags=0, margin=[0], visited={})

source code 

Print a tree of nodes.  This is like render_tree, except it prints
lines directly instead of creating a string representation in memory,
so that huge trees can be printed.

root - the root node of the tree
child_func - the function called to get the children of a node
prune - don't visit the same node twice
showtags - print status information to the left of each node line
margin - the format of the left margin to use for children of root.
   1 results in a pipe, and 0 results in no pipe.
visited - a dictionary of visited nodes in the current branch if not prune,
   or in the whole tree if prune.

flatten(obj, isinstance=<built-in function isinstance>, StringTypes=(<type 'str'>, <type 'unicode'>, <class UserString.UserString ..., SequenceTypes=(<type 'list'>, <type 'tuple'>, <class UserList.UserList at 0x..., do_flatten=<function do_flatten at 0x82ba534>)

source code 
Flatten a sequence to a non-nested list.

Flatten() converts either a single scalar or a nested sequence
to a non-nested list. Note that flatten() considers strings
to be scalars instead of sequences like Python would.

flatten_sequence(sequence, isinstance=<built-in function isinstance>, StringTypes=(<type 'str'>, <type 'unicode'>, <class UserString.UserString ..., SequenceTypes=(<type 'list'>, <type 'tuple'>, <class UserList.UserList at 0x..., do_flatten=<function do_flatten at 0x82ba534>)

source code 
Flatten a sequence to a non-nested list.

Same as flatten(), but it does not handle the single scalar
case. This is slightly more efficient when one knows that
the sequence to flatten can not be a scalar.

PrependPath(oldpath, newpath, sep=':', delete_existing=1, canonicalize=False)

source code 
This prepends newpath elements to the given oldpath.  Will only
add any particular path once (leaving the first one it encounters
and ignoring the rest, to preserve path order), and will
os.path.normpath and os.path.normcase all paths to help assure
this.  This can also handle the case where the given old path
variable is a list instead of a string, in which case a list will
be returned instead of a string.

Example:
  Old Path: "/foo/bar:/foo"
  New Path: "/biz/boom:/foo"
  Result:   "/biz/boom:/foo:/foo/bar"

If delete_existing is 0, then adding a path that exists will
not move it to the beginning; it will stay where it is in the
list.

If canonicalize is not None, it is applied to each element of 
newpath before use.

AppendPath(oldpath, newpath, sep=':', delete_existing=1, canonicalize=False)

source code 
This appends new path elements to the given old path.  Will
only add any particular path once (leaving the last one it
encounters and ignoring the rest, to preserve path order), and
will os.path.normpath and os.path.normcase all paths to help
assure this.  This can also handle the case where the given old
path variable is a list instead of a string, in which case a list
will be returned instead of a string.

Example:
  Old Path: "/foo/bar:/foo"
  New Path: "/biz/boom:/foo"
  Result:   "/foo/bar:/biz/boom:/foo"

If delete_existing is 0, then adding a path that exists
will not move it to the end; it will stay where it is in the list.

If canonicalize is not None, it is applied to each element of 
newpath before use.

get_native_path(path)

source code 
Transforms an absolute path into a native path for the system.
Non-Cygwin version, just leave the path alone.

unique(s)

source code 
Return a list of the elements in s, but without duplicates.

For example, unique([1,2,3,1,2,3]) is some permutation of [1,2,3],
unique("abcabc") some permutation of ["a", "b", "c"], and
unique(([1, 2], [2, 3], [1, 2])) some permutation of
[[2, 3], [1, 2]].

For best speed, all sequence elements should be hashable.  Then
unique() will usually work in linear time.

If not possible, the sequence elements should enjoy a total
ordering, and if list(s).sort() doesn't raise TypeError it's
assumed that they do enjoy a total ordering.  Then unique() will
usually work in O(N*log2(N)) time.

If that's not possible either, the sequence elements must support
equality-testing.  Then unique() will usually work in quadratic
time.

AddMethod(obj, function, name=False)

source code 

Adds either a bound method to an instance or an unbound method to
a class. If name is ommited the name of the specified function
is used by default.
Example:
  a = A()
  def f(self, x, y):
    self.z = x + y
  AddMethod(f, A, "add")
  a.add(2, 4)
  print a.z
  AddMethod(lambda self, i: self.l[i], a, "listIndex")
  print a.listIndex(5)

MD5collect(signatures)

source code 

Collects a list of signatures into an aggregate signature.

signatures - a list of signatures
returns - the aggregate signature

silent_intern(x)

source code 

Perform sys.intern() on the passed argument and return the result.
If the input is ineligible (e.g. a unicode string) the original argument is
returned and no exception is thrown.


Variables Details [hide private]

DictTypes

Value:
DictTypes

ListTypes

Value:
list, UserList

SequenceTypes

Value:
SequenceTypes

StringTypes

Value:
StringTypes

d

Value:
{}

_semi_deepcopy_dispatch

Value:
{}