| Index: scons-2.0.1/engine/SCons/Platform/__init__.py
|
| ===================================================================
|
| --- scons-2.0.1/engine/SCons/Platform/__init__.py (revision 0)
|
| +++ scons-2.0.1/engine/SCons/Platform/__init__.py (revision 0)
|
| @@ -0,0 +1,241 @@
|
| +"""SCons.Platform
|
| +
|
| +SCons platform selection.
|
| +
|
| +This looks for modules that define a callable object that can modify a
|
| +construction environment as appropriate for a given platform.
|
| +
|
| +Note that we take a more simplistic view of "platform" than Python does.
|
| +We're looking for a single string that determines a set of
|
| +tool-independent variables with which to initialize a construction
|
| +environment. Consequently, we'll examine both sys.platform and os.name
|
| +(and anything else that might come in to play) in order to return some
|
| +specification which is unique enough for our purposes.
|
| +
|
| +Note that because this subsysem just *selects* a callable that can
|
| +modify a construction environment, it's possible for people to define
|
| +their own "platform specification" in an arbitrary callable function.
|
| +No one needs to use or tie in to this subsystem in order to roll
|
| +their own platform definition.
|
| +"""
|
| +
|
| +#
|
| +# 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/engine/SCons/Platform/__init__.py 5134 2010/08/16 23:02:40 bdeegan"
|
| +
|
| +import SCons.compat
|
| +
|
| +import imp
|
| +import os
|
| +import sys
|
| +import tempfile
|
| +
|
| +import SCons.Errors
|
| +import SCons.Subst
|
| +import SCons.Tool
|
| +
|
| +def platform_default():
|
| + """Return the platform string for our execution environment.
|
| +
|
| + The returned value should map to one of the SCons/Platform/*.py
|
| + files. Since we're architecture independent, though, we don't
|
| + care about the machine architecture.
|
| + """
|
| + osname = os.name
|
| + if osname == 'java':
|
| + osname = os._osType
|
| + if osname == 'posix':
|
| + if sys.platform == 'cygwin':
|
| + return 'cygwin'
|
| + elif sys.platform.find('irix') != -1:
|
| + return 'irix'
|
| + elif sys.platform.find('sunos') != -1:
|
| + return 'sunos'
|
| + elif sys.platform.find('hp-ux') != -1:
|
| + return 'hpux'
|
| + elif sys.platform.find('aix') != -1:
|
| + return 'aix'
|
| + elif sys.platform.find('darwin') != -1:
|
| + return 'darwin'
|
| + else:
|
| + return 'posix'
|
| + elif os.name == 'os2':
|
| + return 'os2'
|
| + else:
|
| + return sys.platform
|
| +
|
| +def platform_module(name = platform_default()):
|
| + """Return the imported module for the platform.
|
| +
|
| + This looks for a module name that matches the specified argument.
|
| + If the name is unspecified, we fetch the appropriate default for
|
| + our execution environment.
|
| + """
|
| + full_name = 'SCons.Platform.' + name
|
| + if full_name not in sys.modules:
|
| + if os.name == 'java':
|
| + eval(full_name)
|
| + else:
|
| + try:
|
| + file, path, desc = imp.find_module(name,
|
| + sys.modules['SCons.Platform'].__path__)
|
| + try:
|
| + mod = imp.load_module(full_name, file, path, desc)
|
| + finally:
|
| + if file:
|
| + file.close()
|
| + except ImportError:
|
| + try:
|
| + import zipimport
|
| + importer = zipimport.zipimporter( sys.modules['SCons.Platform'].__path__[0] )
|
| + mod = importer.load_module(full_name)
|
| + except ImportError:
|
| + raise SCons.Errors.UserError("No platform named '%s'" % name)
|
| + setattr(SCons.Platform, name, mod)
|
| + return sys.modules[full_name]
|
| +
|
| +def DefaultToolList(platform, env):
|
| + """Select a default tool list for the specified platform.
|
| + """
|
| + return SCons.Tool.tool_list(platform, env)
|
| +
|
| +class PlatformSpec(object):
|
| + def __init__(self, name, generate):
|
| + self.name = name
|
| + self.generate = generate
|
| +
|
| + def __call__(self, *args, **kw):
|
| + return self.generate(*args, **kw)
|
| +
|
| + def __str__(self):
|
| + return self.name
|
| +
|
| +class TempFileMunge(object):
|
| + """A callable class. You can set an Environment variable to this,
|
| + then call it with a string argument, then it will perform temporary
|
| + file substitution on it. This is used to circumvent the long command
|
| + line limitation.
|
| +
|
| + Example usage:
|
| + env["TEMPFILE"] = TempFileMunge
|
| + env["LINKCOM"] = "${TEMPFILE('$LINK $TARGET $SOURCES')}"
|
| +
|
| + By default, the name of the temporary file used begins with a
|
| + prefix of '@'. This may be configred for other tool chains by
|
| + setting '$TEMPFILEPREFIX'.
|
| +
|
| + env["TEMPFILEPREFIX"] = '-@' # diab compiler
|
| + env["TEMPFILEPREFIX"] = '-via' # arm tool chain
|
| + """
|
| + def __init__(self, cmd):
|
| + self.cmd = cmd
|
| +
|
| + def __call__(self, target, source, env, for_signature):
|
| + if for_signature:
|
| + # If we're being called for signature calculation, it's
|
| + # because we're being called by the string expansion in
|
| + # Subst.py, which has the logic to strip any $( $) that
|
| + # may be in the command line we squirreled away. So we
|
| + # just return the raw command line and let the upper
|
| + # string substitution layers do their thing.
|
| + return self.cmd
|
| +
|
| + # Now we're actually being called because someone is actually
|
| + # going to try to execute the command, so we have to do our
|
| + # own expansion.
|
| + cmd = env.subst_list(self.cmd, SCons.Subst.SUBST_CMD, target, source)[0]
|
| + try:
|
| + maxline = int(env.subst('$MAXLINELENGTH'))
|
| + except ValueError:
|
| + maxline = 2048
|
| +
|
| + length = 0
|
| + for c in cmd:
|
| + length += len(c)
|
| + if length <= maxline:
|
| + return self.cmd
|
| +
|
| + # We do a normpath because mktemp() has what appears to be
|
| + # a bug in Windows that will use a forward slash as a path
|
| + # delimiter. Windows's link mistakes that for a command line
|
| + # switch and barfs.
|
| + #
|
| + # We use the .lnk suffix for the benefit of the Phar Lap
|
| + # linkloc linker, which likes to append an .lnk suffix if
|
| + # none is given.
|
| + (fd, tmp) = tempfile.mkstemp('.lnk', text=True)
|
| + native_tmp = SCons.Util.get_native_path(os.path.normpath(tmp))
|
| +
|
| + if env['SHELL'] and env['SHELL'] == 'sh':
|
| + # The sh shell will try to escape the backslashes in the
|
| + # path, so unescape them.
|
| + native_tmp = native_tmp.replace('\\', r'\\\\')
|
| + # In Cygwin, we want to use rm to delete the temporary
|
| + # file, because del does not exist in the sh shell.
|
| + rm = env.Detect('rm') or 'del'
|
| + else:
|
| + # Don't use 'rm' if the shell is not sh, because rm won't
|
| + # work with the Windows shells (cmd.exe or command.com) or
|
| + # Windows path names.
|
| + rm = 'del'
|
| +
|
| + prefix = env.subst('$TEMPFILEPREFIX')
|
| + if not prefix:
|
| + prefix = '@'
|
| +
|
| + args = list(map(SCons.Subst.quote_spaces, cmd[1:]))
|
| + os.write(fd, " ".join(args) + "\n")
|
| + os.close(fd)
|
| + # XXX Using the SCons.Action.print_actions value directly
|
| + # like this is bogus, but expedient. This class should
|
| + # really be rewritten as an Action that defines the
|
| + # __call__() and strfunction() methods and lets the
|
| + # normal action-execution logic handle whether or not to
|
| + # print/execute the action. The problem, though, is all
|
| + # of that is decided before we execute this method as
|
| + # part of expanding the $TEMPFILE construction variable.
|
| + # Consequently, refactoring this will have to wait until
|
| + # we get more flexible with allowing Actions to exist
|
| + # independently and get strung together arbitrarily like
|
| + # Ant tasks. In the meantime, it's going to be more
|
| + # user-friendly to not let obsession with architectural
|
| + # purity get in the way of just being helpful, so we'll
|
| + # reach into SCons.Action directly.
|
| + if SCons.Action.print_actions:
|
| + print("Using tempfile "+native_tmp+" for command line:\n"+
|
| + str(cmd[0]) + " " + " ".join(args))
|
| + return [ cmd[0], prefix + native_tmp + '\n' + rm, native_tmp ]
|
| +
|
| +def Platform(name = platform_default()):
|
| + """Select a canned Platform specification.
|
| + """
|
| + module = platform_module(name)
|
| + spec = PlatformSpec(name, module.generate)
|
| + return spec
|
| +
|
| +# Local Variables:
|
| +# tab-width:4
|
| +# indent-tabs-mode:nil
|
| +# End:
|
| +# vim: set expandtab tabstop=4 shiftwidth=4:
|
|
|
| Property changes on: scons-2.0.1/engine/SCons/Platform/__init__.py
|
| ___________________________________________________________________
|
| Added: svn:eol-style
|
| + LF
|
|
|
|
|