| Index: scons-2.0.1/script/sconsign
|
| ===================================================================
|
| --- scons-2.0.1/script/sconsign (revision 0)
|
| +++ scons-2.0.1/script/sconsign (revision 0)
|
| @@ -0,0 +1,513 @@
|
| +#! /usr/bin/env python
|
| +#
|
| +# SCons - a Software Constructor
|
| +#
|
| +# Copyright (c) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 The SCons Foundation
|
| +#
|
| +# Permission is hereby granted, free of charge, to any person obtaining
|
| +# a copy of this software and associated documentation files (the
|
| +# "Software"), to deal in the Software without restriction, including
|
| +# without limitation the rights to use, copy, modify, merge, publish,
|
| +# distribute, sublicense, and/or sell copies of the Software, and to
|
| +# permit persons to whom the Software is furnished to do so, subject to
|
| +# the following conditions:
|
| +#
|
| +# The above copyright notice and this permission notice shall be included
|
| +# in all copies or substantial portions of the Software.
|
| +#
|
| +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
| +# KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
| +# WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
| +# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
| +# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
| +# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
| +# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
| +
|
| +__revision__ = "src/script/sconsign.py 5134 2010/08/16 23:02:40 bdeegan"
|
| +
|
| +__version__ = "2.0.1"
|
| +
|
| +__build__ = "r5134"
|
| +
|
| +__buildsys__ = "cooldog"
|
| +
|
| +__date__ = "2010/08/16 23:02:40"
|
| +
|
| +__developer__ = "bdeegan"
|
| +
|
| +import os
|
| +import sys
|
| +import time
|
| +
|
| +##############################################################################
|
| +# BEGIN STANDARD SCons SCRIPT HEADER
|
| +#
|
| +# This is the cut-and-paste logic so that a self-contained script can
|
| +# interoperate correctly with different SCons versions and installation
|
| +# locations for the engine. If you modify anything in this section, you
|
| +# should also change other scripts that use this same header.
|
| +##############################################################################
|
| +
|
| +# Strip the script directory from sys.path() so on case-insensitive
|
| +# (WIN32) systems Python doesn't think that the "scons" script is the
|
| +# "SCons" package. Replace it with our own library directories
|
| +# (version-specific first, in case they installed by hand there,
|
| +# followed by generic) so we pick up the right version of the build
|
| +# engine modules if they're in either directory.
|
| +
|
| +script_dir = sys.path[0]
|
| +
|
| +if script_dir in sys.path:
|
| + sys.path.remove(script_dir)
|
| +
|
| +libs = []
|
| +
|
| +if "SCONS_LIB_DIR" in os.environ:
|
| + libs.append(os.environ["SCONS_LIB_DIR"])
|
| +
|
| +local_version = 'scons-local-' + __version__
|
| +local = 'scons-local'
|
| +if script_dir:
|
| + local_version = os.path.join(script_dir, local_version)
|
| + local = os.path.join(script_dir, local)
|
| +libs.append(os.path.abspath(local_version))
|
| +libs.append(os.path.abspath(local))
|
| +
|
| +scons_version = 'scons-%s' % __version__
|
| +
|
| +prefs = []
|
| +
|
| +if sys.platform == 'win32':
|
| + # sys.prefix is (likely) C:\Python*;
|
| + # check only C:\Python*.
|
| + prefs.append(sys.prefix)
|
| + prefs.append(os.path.join(sys.prefix, 'Lib', 'site-packages'))
|
| +else:
|
| + # On other (POSIX) platforms, things are more complicated due to
|
| + # the variety of path names and library locations. Try to be smart
|
| + # about it.
|
| + if script_dir == 'bin':
|
| + # script_dir is `pwd`/bin;
|
| + # check `pwd`/lib/scons*.
|
| + prefs.append(os.getcwd())
|
| + else:
|
| + if script_dir == '.' or script_dir == '':
|
| + script_dir = os.getcwd()
|
| + head, tail = os.path.split(script_dir)
|
| + if tail == "bin":
|
| + # script_dir is /foo/bin;
|
| + # check /foo/lib/scons*.
|
| + prefs.append(head)
|
| +
|
| + head, tail = os.path.split(sys.prefix)
|
| + if tail == "usr":
|
| + # sys.prefix is /foo/usr;
|
| + # check /foo/usr/lib/scons* first,
|
| + # then /foo/usr/local/lib/scons*.
|
| + prefs.append(sys.prefix)
|
| + prefs.append(os.path.join(sys.prefix, "local"))
|
| + elif tail == "local":
|
| + h, t = os.path.split(head)
|
| + if t == "usr":
|
| + # sys.prefix is /foo/usr/local;
|
| + # check /foo/usr/local/lib/scons* first,
|
| + # then /foo/usr/lib/scons*.
|
| + prefs.append(sys.prefix)
|
| + prefs.append(head)
|
| + else:
|
| + # sys.prefix is /foo/local;
|
| + # check only /foo/local/lib/scons*.
|
| + prefs.append(sys.prefix)
|
| + else:
|
| + # sys.prefix is /foo (ends in neither /usr or /local);
|
| + # check only /foo/lib/scons*.
|
| + prefs.append(sys.prefix)
|
| +
|
| + temp = [os.path.join(x, 'lib') for x in prefs]
|
| + temp.extend([os.path.join(x,
|
| + 'lib',
|
| + 'python' + sys.version[:3],
|
| + 'site-packages') for x in prefs])
|
| + prefs = temp
|
| +
|
| + # Add the parent directory of the current python's library to the
|
| + # preferences. On SuSE-91/AMD64, for example, this is /usr/lib64,
|
| + # not /usr/lib.
|
| + try:
|
| + libpath = os.__file__
|
| + except AttributeError:
|
| + pass
|
| + else:
|
| + # Split /usr/libfoo/python*/os.py to /usr/libfoo/python*.
|
| + libpath, tail = os.path.split(libpath)
|
| + # Split /usr/libfoo/python* to /usr/libfoo
|
| + libpath, tail = os.path.split(libpath)
|
| + # Check /usr/libfoo/scons*.
|
| + prefs.append(libpath)
|
| +
|
| + try:
|
| + import pkg_resources
|
| + except ImportError:
|
| + pass
|
| + else:
|
| + # when running from an egg add the egg's directory
|
| + try:
|
| + d = pkg_resources.get_distribution('scons')
|
| + except pkg_resources.DistributionNotFound:
|
| + pass
|
| + else:
|
| + prefs.append(d.location)
|
| +
|
| +# Look first for 'scons-__version__' in all of our preference libs,
|
| +# then for 'scons'.
|
| +libs.extend([os.path.join(x, scons_version) for x in prefs])
|
| +libs.extend([os.path.join(x, 'scons') for x in prefs])
|
| +
|
| +sys.path = libs + sys.path
|
| +
|
| +##############################################################################
|
| +# END STANDARD SCons SCRIPT HEADER
|
| +##############################################################################
|
| +
|
| +import SCons.compat # so pickle will import cPickle instead
|
| +
|
| +import whichdb
|
| +import pickle
|
| +import imp
|
| +
|
| +import SCons.SConsign
|
| +
|
| +def my_whichdb(filename):
|
| + if filename[-7:] == ".dblite":
|
| + return "SCons.dblite"
|
| + try:
|
| + f = open(filename + ".dblite", "rb")
|
| + f.close()
|
| + return "SCons.dblite"
|
| + except IOError:
|
| + pass
|
| + return _orig_whichdb(filename)
|
| +
|
| +_orig_whichdb = whichdb.whichdb
|
| +whichdb.whichdb = my_whichdb
|
| +
|
| +def my_import(mname):
|
| + if '.' in mname:
|
| + i = mname.rfind('.')
|
| + parent = my_import(mname[:i])
|
| + fp, pathname, description = imp.find_module(mname[i+1:],
|
| + parent.__path__)
|
| + else:
|
| + fp, pathname, description = imp.find_module(mname)
|
| + return imp.load_module(mname, fp, pathname, description)
|
| +
|
| +class Flagger(object):
|
| + default_value = 1
|
| + def __setitem__(self, item, value):
|
| + self.__dict__[item] = value
|
| + self.default_value = 0
|
| + def __getitem__(self, item):
|
| + return self.__dict__.get(item, self.default_value)
|
| +
|
| +Do_Call = None
|
| +Print_Directories = []
|
| +Print_Entries = []
|
| +Print_Flags = Flagger()
|
| +Verbose = 0
|
| +Readable = 0
|
| +
|
| +def default_mapper(entry, name):
|
| + try:
|
| + val = eval("entry."+name)
|
| + except:
|
| + val = None
|
| + return str(val)
|
| +
|
| +def map_action(entry, name):
|
| + try:
|
| + bact = entry.bact
|
| + bactsig = entry.bactsig
|
| + except AttributeError:
|
| + return None
|
| + return '%s [%s]' % (bactsig, bact)
|
| +
|
| +def map_timestamp(entry, name):
|
| + try:
|
| + timestamp = entry.timestamp
|
| + except AttributeError:
|
| + timestamp = None
|
| + if Readable and timestamp:
|
| + return "'" + time.ctime(timestamp) + "'"
|
| + else:
|
| + return str(timestamp)
|
| +
|
| +def map_bkids(entry, name):
|
| + try:
|
| + bkids = entry.bsources + entry.bdepends + entry.bimplicit
|
| + bkidsigs = entry.bsourcesigs + entry.bdependsigs + entry.bimplicitsigs
|
| + except AttributeError:
|
| + return None
|
| + result = []
|
| + for i in range(len(bkids)):
|
| + result.append(nodeinfo_string(bkids[i], bkidsigs[i], " "))
|
| + if result == []:
|
| + return None
|
| + return "\n ".join(result)
|
| +
|
| +map_field = {
|
| + 'action' : map_action,
|
| + 'timestamp' : map_timestamp,
|
| + 'bkids' : map_bkids,
|
| +}
|
| +
|
| +map_name = {
|
| + 'implicit' : 'bkids',
|
| +}
|
| +
|
| +def field(name, entry, verbose=Verbose):
|
| + if not Print_Flags[name]:
|
| + return None
|
| + fieldname = map_name.get(name, name)
|
| + mapper = map_field.get(fieldname, default_mapper)
|
| + val = mapper(entry, name)
|
| + if verbose:
|
| + val = name + ": " + val
|
| + return val
|
| +
|
| +def nodeinfo_raw(name, ninfo, prefix=""):
|
| + # This just formats the dictionary, which we would normally use str()
|
| + # to do, except that we want the keys sorted for deterministic output.
|
| + d = ninfo.__dict__
|
| + try:
|
| + keys = ninfo.field_list + ['_version_id']
|
| + except AttributeError:
|
| + keys = sorted(d.keys())
|
| + l = []
|
| + for k in keys:
|
| + l.append('%s: %s' % (repr(k), repr(d.get(k))))
|
| + if '\n' in name:
|
| + name = repr(name)
|
| + return name + ': {' + ', '.join(l) + '}'
|
| +
|
| +def nodeinfo_cooked(name, ninfo, prefix=""):
|
| + try:
|
| + field_list = ninfo.field_list
|
| + except AttributeError:
|
| + field_list = []
|
| + if '\n' in name:
|
| + name = repr(name)
|
| + outlist = [name+':'] + [_f for _f in [field(x, ninfo, Verbose) for x in field_list] if _f]
|
| + if Verbose:
|
| + sep = '\n ' + prefix
|
| + else:
|
| + sep = ' '
|
| + return sep.join(outlist)
|
| +
|
| +nodeinfo_string = nodeinfo_cooked
|
| +
|
| +def printfield(name, entry, prefix=""):
|
| + outlist = field("implicit", entry, 0)
|
| + if outlist:
|
| + if Verbose:
|
| + print " implicit:"
|
| + print " " + outlist
|
| + outact = field("action", entry, 0)
|
| + if outact:
|
| + if Verbose:
|
| + print " action: " + outact
|
| + else:
|
| + print " " + outact
|
| +
|
| +def printentries(entries, location):
|
| + if Print_Entries:
|
| + for name in Print_Entries:
|
| + try:
|
| + entry = entries[name]
|
| + except KeyError:
|
| + sys.stderr.write("sconsign: no entry `%s' in `%s'\n" % (name, location))
|
| + else:
|
| + try:
|
| + ninfo = entry.ninfo
|
| + except AttributeError:
|
| + print name + ":"
|
| + else:
|
| + print nodeinfo_string(name, entry.ninfo)
|
| + printfield(name, entry.binfo)
|
| + else:
|
| + for name in sorted(entries.keys()):
|
| + entry = entries[name]
|
| + try:
|
| + ninfo = entry.ninfo
|
| + except AttributeError:
|
| + print name + ":"
|
| + else:
|
| + print nodeinfo_string(name, entry.ninfo)
|
| + printfield(name, entry.binfo)
|
| +
|
| +class Do_SConsignDB(object):
|
| + def __init__(self, dbm_name, dbm):
|
| + self.dbm_name = dbm_name
|
| + self.dbm = dbm
|
| +
|
| + def __call__(self, fname):
|
| + # The *dbm modules stick their own file suffixes on the names
|
| + # that are passed in. This is causes us to jump through some
|
| + # hoops here to be able to allow the user
|
| + try:
|
| + # Try opening the specified file name. Example:
|
| + # SPECIFIED OPENED BY self.dbm.open()
|
| + # --------- -------------------------
|
| + # .sconsign => .sconsign.dblite
|
| + # .sconsign.dblite => .sconsign.dblite.dblite
|
| + db = self.dbm.open(fname, "r")
|
| + except (IOError, OSError), e:
|
| + print_e = e
|
| + try:
|
| + # That didn't work, so try opening the base name,
|
| + # so that if the actually passed in 'sconsign.dblite'
|
| + # (for example), the dbm module will put the suffix back
|
| + # on for us and open it anyway.
|
| + db = self.dbm.open(os.path.splitext(fname)[0], "r")
|
| + except (IOError, OSError):
|
| + # That didn't work either. See if the file name
|
| + # they specified just exists (independent of the dbm
|
| + # suffix-mangling).
|
| + try:
|
| + open(fname, "r")
|
| + except (IOError, OSError), e:
|
| + # Nope, that file doesn't even exist, so report that
|
| + # fact back.
|
| + print_e = e
|
| + sys.stderr.write("sconsign: %s\n" % (print_e))
|
| + return
|
| + except KeyboardInterrupt:
|
| + raise
|
| + except pickle.UnpicklingError:
|
| + sys.stderr.write("sconsign: ignoring invalid `%s' file `%s'\n" % (self.dbm_name, fname))
|
| + return
|
| + except Exception, e:
|
| + sys.stderr.write("sconsign: ignoring invalid `%s' file `%s': %s\n" % (self.dbm_name, fname, e))
|
| + return
|
| +
|
| + if Print_Directories:
|
| + for dir in Print_Directories:
|
| + try:
|
| + val = db[dir]
|
| + except KeyError:
|
| + sys.stderr.write("sconsign: no dir `%s' in `%s'\n" % (dir, args[0]))
|
| + else:
|
| + self.printentries(dir, val)
|
| + else:
|
| + for dir in sorted(db.keys()):
|
| + self.printentries(dir, db[dir])
|
| +
|
| + def printentries(self, dir, val):
|
| + print '=== ' + dir + ':'
|
| + printentries(pickle.loads(val), dir)
|
| +
|
| +def Do_SConsignDir(name):
|
| + try:
|
| + fp = open(name, 'rb')
|
| + except (IOError, OSError), e:
|
| + sys.stderr.write("sconsign: %s\n" % (e))
|
| + return
|
| + try:
|
| + sconsign = SCons.SConsign.Dir(fp)
|
| + except KeyboardInterrupt:
|
| + raise
|
| + except pickle.UnpicklingError:
|
| + sys.stderr.write("sconsign: ignoring invalid .sconsign file `%s'\n" % (name))
|
| + return
|
| + except Exception, e:
|
| + sys.stderr.write("sconsign: ignoring invalid .sconsign file `%s': %s\n" % (name, e))
|
| + return
|
| + printentries(sconsign.entries, args[0])
|
| +
|
| +##############################################################################
|
| +
|
| +import getopt
|
| +
|
| +helpstr = """\
|
| +Usage: sconsign [OPTIONS] FILE [...]
|
| +Options:
|
| + -a, --act, --action Print build action information.
|
| + -c, --csig Print content signature information.
|
| + -d DIR, --dir=DIR Print only info about DIR.
|
| + -e ENTRY, --entry=ENTRY Print only info about ENTRY.
|
| + -f FORMAT, --format=FORMAT FILE is in the specified FORMAT.
|
| + -h, --help Print this message and exit.
|
| + -i, --implicit Print implicit dependency information.
|
| + -r, --readable Print timestamps in human-readable form.
|
| + --raw Print raw Python object representations.
|
| + -s, --size Print file sizes.
|
| + -t, --timestamp Print timestamp information.
|
| + -v, --verbose Verbose, describe each field.
|
| +"""
|
| +
|
| +opts, args = getopt.getopt(sys.argv[1:], "acd:e:f:hirstv",
|
| + ['act', 'action',
|
| + 'csig', 'dir=', 'entry=',
|
| + 'format=', 'help', 'implicit',
|
| + 'raw', 'readable',
|
| + 'size', 'timestamp', 'verbose'])
|
| +
|
| +
|
| +for o, a in opts:
|
| + if o in ('-a', '--act', '--action'):
|
| + Print_Flags['action'] = 1
|
| + elif o in ('-c', '--csig'):
|
| + Print_Flags['csig'] = 1
|
| + elif o in ('-d', '--dir'):
|
| + Print_Directories.append(a)
|
| + elif o in ('-e', '--entry'):
|
| + Print_Entries.append(a)
|
| + elif o in ('-f', '--format'):
|
| + Module_Map = {'dblite' : 'SCons.dblite',
|
| + 'sconsign' : None}
|
| + dbm_name = Module_Map.get(a, a)
|
| + if dbm_name:
|
| + try:
|
| + dbm = my_import(dbm_name)
|
| + except:
|
| + sys.stderr.write("sconsign: illegal file format `%s'\n" % a)
|
| + print helpstr
|
| + sys.exit(2)
|
| + Do_Call = Do_SConsignDB(a, dbm)
|
| + else:
|
| + Do_Call = Do_SConsignDir
|
| + elif o in ('-h', '--help'):
|
| + print helpstr
|
| + sys.exit(0)
|
| + elif o in ('-i', '--implicit'):
|
| + Print_Flags['implicit'] = 1
|
| + elif o in ('--raw',):
|
| + nodeinfo_string = nodeinfo_raw
|
| + elif o in ('-r', '--readable'):
|
| + Readable = 1
|
| + elif o in ('-s', '--size'):
|
| + Print_Flags['size'] = 1
|
| + elif o in ('-t', '--timestamp'):
|
| + Print_Flags['timestamp'] = 1
|
| + elif o in ('-v', '--verbose'):
|
| + Verbose = 1
|
| +
|
| +if Do_Call:
|
| + for a in args:
|
| + Do_Call(a)
|
| +else:
|
| + for a in args:
|
| + dbm_name = whichdb.whichdb(a)
|
| + if dbm_name:
|
| + Map_Module = {'SCons.dblite' : 'dblite'}
|
| + dbm = my_import(dbm_name)
|
| + Do_SConsignDB(Map_Module.get(dbm_name, dbm_name), dbm)(a)
|
| + else:
|
| + Do_SConsignDir(a)
|
| +
|
| +sys.exit(0)
|
| +
|
| +# Local Variables:
|
| +# tab-width:4
|
| +# indent-tabs-mode:nil
|
| +# End:
|
| +# vim: set expandtab tabstop=4 shiftwidth=4:
|
|
|
| Property changes on: scons-2.0.1/script/sconsign
|
| ___________________________________________________________________
|
| Added: svn:executable
|
| + *
|
|
|
|
|