Index: scons-2.0.1/engine/SCons/Tool/__init__.py |
=================================================================== |
--- scons-2.0.1/engine/SCons/Tool/__init__.py (revision 0) |
+++ scons-2.0.1/engine/SCons/Tool/__init__.py (revision 0) |
@@ -0,0 +1,681 @@ |
+"""SCons.Tool |
+ |
+SCons tool selection. |
+ |
+This looks for modules that define a callable object that can modify |
+a construction environment as appropriate for a given tool (or tool |
+chain). |
+ |
+Note that because this subsystem just *selects* a callable that can |
+modify a construction environment, it's possible for people to define |
+their own "tool specification" in an arbitrary callable function. No |
+one needs to use or tie in to this subsystem in order to roll their own |
+tool 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/Tool/__init__.py 5134 2010/08/16 23:02:40 bdeegan" |
+ |
+import imp |
+import sys |
+ |
+import SCons.Builder |
+import SCons.Errors |
+import SCons.Node.FS |
+import SCons.Scanner |
+import SCons.Scanner.C |
+import SCons.Scanner.D |
+import SCons.Scanner.LaTeX |
+import SCons.Scanner.Prog |
+ |
+DefaultToolpath=[] |
+ |
+CScanner = SCons.Scanner.C.CScanner() |
+DScanner = SCons.Scanner.D.DScanner() |
+LaTeXScanner = SCons.Scanner.LaTeX.LaTeXScanner() |
+PDFLaTeXScanner = SCons.Scanner.LaTeX.PDFLaTeXScanner() |
+ProgramScanner = SCons.Scanner.Prog.ProgramScanner() |
+SourceFileScanner = SCons.Scanner.Base({}, name='SourceFileScanner') |
+ |
+CSuffixes = [".c", ".C", ".cxx", ".cpp", ".c++", ".cc", |
+ ".h", ".H", ".hxx", ".hpp", ".hh", |
+ ".F", ".fpp", ".FPP", |
+ ".m", ".mm", |
+ ".S", ".spp", ".SPP"] |
+ |
+DSuffixes = ['.d'] |
+ |
+IDLSuffixes = [".idl", ".IDL"] |
+ |
+LaTeXSuffixes = [".tex", ".ltx", ".latex"] |
+ |
+for suffix in CSuffixes: |
+ SourceFileScanner.add_scanner(suffix, CScanner) |
+ |
+for suffix in DSuffixes: |
+ SourceFileScanner.add_scanner(suffix, DScanner) |
+ |
+# FIXME: what should be done here? Two scanners scan the same extensions, |
+# but look for different files, e.g., "picture.eps" vs. "picture.pdf". |
+# The builders for DVI and PDF explicitly reference their scanners |
+# I think that means this is not needed??? |
+for suffix in LaTeXSuffixes: |
+ SourceFileScanner.add_scanner(suffix, LaTeXScanner) |
+ SourceFileScanner.add_scanner(suffix, PDFLaTeXScanner) |
+ |
+class Tool(object): |
+ def __init__(self, name, toolpath=[], **kw): |
+ self.name = name |
+ self.toolpath = toolpath + DefaultToolpath |
+ # remember these so we can merge them into the call |
+ self.init_kw = kw |
+ |
+ module = self._tool_module() |
+ self.generate = module.generate |
+ self.exists = module.exists |
+ if hasattr(module, 'options'): |
+ self.options = module.options |
+ |
+ def _tool_module(self): |
+ # TODO: Interchange zipimport with normal initilization for better error reporting |
+ oldpythonpath = sys.path |
+ sys.path = self.toolpath + sys.path |
+ |
+ try: |
+ try: |
+ file, path, desc = imp.find_module(self.name, self.toolpath) |
+ try: |
+ return imp.load_module(self.name, file, path, desc) |
+ finally: |
+ if file: |
+ file.close() |
+ except ImportError, e: |
+ if str(e)!="No module named %s"%self.name: |
+ raise SCons.Errors.EnvironmentError(e) |
+ try: |
+ import zipimport |
+ except ImportError: |
+ pass |
+ else: |
+ for aPath in self.toolpath: |
+ try: |
+ importer = zipimport.zipimporter(aPath) |
+ return importer.load_module(self.name) |
+ except ImportError, e: |
+ pass |
+ finally: |
+ sys.path = oldpythonpath |
+ |
+ full_name = 'SCons.Tool.' + self.name |
+ try: |
+ return sys.modules[full_name] |
+ except KeyError: |
+ try: |
+ smpath = sys.modules['SCons.Tool'].__path__ |
+ try: |
+ file, path, desc = imp.find_module(self.name, smpath) |
+ module = imp.load_module(full_name, file, path, desc) |
+ setattr(SCons.Tool, self.name, module) |
+ if file: |
+ file.close() |
+ return module |
+ except ImportError, e: |
+ if str(e)!="No module named %s"%self.name: |
+ raise SCons.Errors.EnvironmentError(e) |
+ try: |
+ import zipimport |
+ importer = zipimport.zipimporter( sys.modules['SCons.Tool'].__path__[0] ) |
+ module = importer.load_module(full_name) |
+ setattr(SCons.Tool, self.name, module) |
+ return module |
+ except ImportError, e: |
+ m = "No tool named '%s': %s" % (self.name, e) |
+ raise SCons.Errors.EnvironmentError(m) |
+ except ImportError, e: |
+ m = "No tool named '%s': %s" % (self.name, e) |
+ raise SCons.Errors.EnvironmentError(m) |
+ |
+ def __call__(self, env, *args, **kw): |
+ if self.init_kw is not None: |
+ # Merge call kws into init kws; |
+ # but don't bash self.init_kw. |
+ if kw is not None: |
+ call_kw = kw |
+ kw = self.init_kw.copy() |
+ kw.update(call_kw) |
+ else: |
+ kw = self.init_kw |
+ env.Append(TOOLS = [ self.name ]) |
+ if hasattr(self, 'options'): |
+ import SCons.Variables |
+ if 'options' not in env: |
+ from SCons.Script import ARGUMENTS |
+ env['options']=SCons.Variables.Variables(args=ARGUMENTS) |
+ opts=env['options'] |
+ |
+ self.options(opts) |
+ opts.Update(env) |
+ |
+ self.generate(env, *args, **kw) |
+ |
+ def __str__(self): |
+ return self.name |
+ |
+########################################################################## |
+# Create common executable program / library / object builders |
+ |
+def createProgBuilder(env): |
+ """This is a utility function that creates the Program |
+ Builder in an Environment if it is not there already. |
+ |
+ If it is already there, we return the existing one. |
+ """ |
+ |
+ try: |
+ program = env['BUILDERS']['Program'] |
+ except KeyError: |
+ import SCons.Defaults |
+ program = SCons.Builder.Builder(action = SCons.Defaults.LinkAction, |
+ emitter = '$PROGEMITTER', |
+ prefix = '$PROGPREFIX', |
+ suffix = '$PROGSUFFIX', |
+ src_suffix = '$OBJSUFFIX', |
+ src_builder = 'Object', |
+ target_scanner = ProgramScanner) |
+ env['BUILDERS']['Program'] = program |
+ |
+ return program |
+ |
+def createStaticLibBuilder(env): |
+ """This is a utility function that creates the StaticLibrary |
+ Builder in an Environment if it is not there already. |
+ |
+ If it is already there, we return the existing one. |
+ """ |
+ |
+ try: |
+ static_lib = env['BUILDERS']['StaticLibrary'] |
+ except KeyError: |
+ action_list = [ SCons.Action.Action("$ARCOM", "$ARCOMSTR") ] |
+ if env.Detect('ranlib'): |
+ ranlib_action = SCons.Action.Action("$RANLIBCOM", "$RANLIBCOMSTR") |
+ action_list.append(ranlib_action) |
+ |
+ static_lib = SCons.Builder.Builder(action = action_list, |
+ emitter = '$LIBEMITTER', |
+ prefix = '$LIBPREFIX', |
+ suffix = '$LIBSUFFIX', |
+ src_suffix = '$OBJSUFFIX', |
+ src_builder = 'StaticObject') |
+ env['BUILDERS']['StaticLibrary'] = static_lib |
+ env['BUILDERS']['Library'] = static_lib |
+ |
+ return static_lib |
+ |
+def createSharedLibBuilder(env): |
+ """This is a utility function that creates the SharedLibrary |
+ Builder in an Environment if it is not there already. |
+ |
+ If it is already there, we return the existing one. |
+ """ |
+ |
+ try: |
+ shared_lib = env['BUILDERS']['SharedLibrary'] |
+ except KeyError: |
+ import SCons.Defaults |
+ action_list = [ SCons.Defaults.SharedCheck, |
+ SCons.Defaults.ShLinkAction ] |
+ shared_lib = SCons.Builder.Builder(action = action_list, |
+ emitter = "$SHLIBEMITTER", |
+ prefix = '$SHLIBPREFIX', |
+ suffix = '$SHLIBSUFFIX', |
+ target_scanner = ProgramScanner, |
+ src_suffix = '$SHOBJSUFFIX', |
+ src_builder = 'SharedObject') |
+ env['BUILDERS']['SharedLibrary'] = shared_lib |
+ |
+ return shared_lib |
+ |
+def createLoadableModuleBuilder(env): |
+ """This is a utility function that creates the LoadableModule |
+ Builder in an Environment if it is not there already. |
+ |
+ If it is already there, we return the existing one. |
+ """ |
+ |
+ try: |
+ ld_module = env['BUILDERS']['LoadableModule'] |
+ except KeyError: |
+ import SCons.Defaults |
+ action_list = [ SCons.Defaults.SharedCheck, |
+ SCons.Defaults.LdModuleLinkAction ] |
+ ld_module = SCons.Builder.Builder(action = action_list, |
+ emitter = "$LDMODULEEMITTER", |
+ prefix = '$LDMODULEPREFIX', |
+ suffix = '$LDMODULESUFFIX', |
+ target_scanner = ProgramScanner, |
+ src_suffix = '$SHOBJSUFFIX', |
+ src_builder = 'SharedObject') |
+ env['BUILDERS']['LoadableModule'] = ld_module |
+ |
+ return ld_module |
+ |
+def createObjBuilders(env): |
+ """This is a utility function that creates the StaticObject |
+ and SharedObject Builders in an Environment if they |
+ are not there already. |
+ |
+ If they are there already, we return the existing ones. |
+ |
+ This is a separate function because soooo many Tools |
+ use this functionality. |
+ |
+ The return is a 2-tuple of (StaticObject, SharedObject) |
+ """ |
+ |
+ |
+ try: |
+ static_obj = env['BUILDERS']['StaticObject'] |
+ except KeyError: |
+ static_obj = SCons.Builder.Builder(action = {}, |
+ emitter = {}, |
+ prefix = '$OBJPREFIX', |
+ suffix = '$OBJSUFFIX', |
+ src_builder = ['CFile', 'CXXFile'], |
+ source_scanner = SourceFileScanner, |
+ single_source = 1) |
+ env['BUILDERS']['StaticObject'] = static_obj |
+ env['BUILDERS']['Object'] = static_obj |
+ |
+ try: |
+ shared_obj = env['BUILDERS']['SharedObject'] |
+ except KeyError: |
+ shared_obj = SCons.Builder.Builder(action = {}, |
+ emitter = {}, |
+ prefix = '$SHOBJPREFIX', |
+ suffix = '$SHOBJSUFFIX', |
+ src_builder = ['CFile', 'CXXFile'], |
+ source_scanner = SourceFileScanner, |
+ single_source = 1) |
+ env['BUILDERS']['SharedObject'] = shared_obj |
+ |
+ return (static_obj, shared_obj) |
+ |
+def createCFileBuilders(env): |
+ """This is a utility function that creates the CFile/CXXFile |
+ Builders in an Environment if they |
+ are not there already. |
+ |
+ If they are there already, we return the existing ones. |
+ |
+ This is a separate function because soooo many Tools |
+ use this functionality. |
+ |
+ The return is a 2-tuple of (CFile, CXXFile) |
+ """ |
+ |
+ try: |
+ c_file = env['BUILDERS']['CFile'] |
+ except KeyError: |
+ c_file = SCons.Builder.Builder(action = {}, |
+ emitter = {}, |
+ suffix = {None:'$CFILESUFFIX'}) |
+ env['BUILDERS']['CFile'] = c_file |
+ |
+ env.SetDefault(CFILESUFFIX = '.c') |
+ |
+ try: |
+ cxx_file = env['BUILDERS']['CXXFile'] |
+ except KeyError: |
+ cxx_file = SCons.Builder.Builder(action = {}, |
+ emitter = {}, |
+ suffix = {None:'$CXXFILESUFFIX'}) |
+ env['BUILDERS']['CXXFile'] = cxx_file |
+ env.SetDefault(CXXFILESUFFIX = '.cc') |
+ |
+ return (c_file, cxx_file) |
+ |
+########################################################################## |
+# Create common Java builders |
+ |
+def CreateJarBuilder(env): |
+ try: |
+ java_jar = env['BUILDERS']['Jar'] |
+ except KeyError: |
+ fs = SCons.Node.FS.get_default_fs() |
+ jar_com = SCons.Action.Action('$JARCOM', '$JARCOMSTR') |
+ java_jar = SCons.Builder.Builder(action = jar_com, |
+ suffix = '$JARSUFFIX', |
+ src_suffix = '$JAVACLASSSUFIX', |
+ src_builder = 'JavaClassFile', |
+ source_factory = fs.Entry) |
+ env['BUILDERS']['Jar'] = java_jar |
+ return java_jar |
+ |
+def CreateJavaHBuilder(env): |
+ try: |
+ java_javah = env['BUILDERS']['JavaH'] |
+ except KeyError: |
+ fs = SCons.Node.FS.get_default_fs() |
+ java_javah_com = SCons.Action.Action('$JAVAHCOM', '$JAVAHCOMSTR') |
+ java_javah = SCons.Builder.Builder(action = java_javah_com, |
+ src_suffix = '$JAVACLASSSUFFIX', |
+ target_factory = fs.Entry, |
+ source_factory = fs.File, |
+ src_builder = 'JavaClassFile') |
+ env['BUILDERS']['JavaH'] = java_javah |
+ return java_javah |
+ |
+def CreateJavaClassFileBuilder(env): |
+ try: |
+ java_class_file = env['BUILDERS']['JavaClassFile'] |
+ except KeyError: |
+ fs = SCons.Node.FS.get_default_fs() |
+ javac_com = SCons.Action.Action('$JAVACCOM', '$JAVACCOMSTR') |
+ java_class_file = SCons.Builder.Builder(action = javac_com, |
+ emitter = {}, |
+ #suffix = '$JAVACLASSSUFFIX', |
+ src_suffix = '$JAVASUFFIX', |
+ src_builder = ['JavaFile'], |
+ target_factory = fs.Entry, |
+ source_factory = fs.File) |
+ env['BUILDERS']['JavaClassFile'] = java_class_file |
+ return java_class_file |
+ |
+def CreateJavaClassDirBuilder(env): |
+ try: |
+ java_class_dir = env['BUILDERS']['JavaClassDir'] |
+ except KeyError: |
+ fs = SCons.Node.FS.get_default_fs() |
+ javac_com = SCons.Action.Action('$JAVACCOM', '$JAVACCOMSTR') |
+ java_class_dir = SCons.Builder.Builder(action = javac_com, |
+ emitter = {}, |
+ target_factory = fs.Dir, |
+ source_factory = fs.Dir) |
+ env['BUILDERS']['JavaClassDir'] = java_class_dir |
+ return java_class_dir |
+ |
+def CreateJavaFileBuilder(env): |
+ try: |
+ java_file = env['BUILDERS']['JavaFile'] |
+ except KeyError: |
+ java_file = SCons.Builder.Builder(action = {}, |
+ emitter = {}, |
+ suffix = {None:'$JAVASUFFIX'}) |
+ env['BUILDERS']['JavaFile'] = java_file |
+ env['JAVASUFFIX'] = '.java' |
+ return java_file |
+ |
+class ToolInitializerMethod(object): |
+ """ |
+ This is added to a construction environment in place of a |
+ method(s) normally called for a Builder (env.Object, env.StaticObject, |
+ etc.). When called, it has its associated ToolInitializer |
+ object search the specified list of tools and apply the first |
+ one that exists to the construction environment. It then calls |
+ whatever builder was (presumably) added to the construction |
+ environment in place of this particular instance. |
+ """ |
+ def __init__(self, name, initializer): |
+ """ |
+ Note: we store the tool name as __name__ so it can be used by |
+ the class that attaches this to a construction environment. |
+ """ |
+ self.__name__ = name |
+ self.initializer = initializer |
+ |
+ def get_builder(self, env): |
+ """ |
+ Returns the appropriate real Builder for this method name |
+ after having the associated ToolInitializer object apply |
+ the appropriate Tool module. |
+ """ |
+ builder = getattr(env, self.__name__) |
+ |
+ self.initializer.apply_tools(env) |
+ |
+ builder = getattr(env, self.__name__) |
+ if builder is self: |
+ # There was no Builder added, which means no valid Tool |
+ # for this name was found (or possibly there's a mismatch |
+ # between the name we were called by and the Builder name |
+ # added by the Tool module). |
+ return None |
+ |
+ self.initializer.remove_methods(env) |
+ |
+ return builder |
+ |
+ def __call__(self, env, *args, **kw): |
+ """ |
+ """ |
+ builder = self.get_builder(env) |
+ if builder is None: |
+ return [], [] |
+ return builder(*args, **kw) |
+ |
+class ToolInitializer(object): |
+ """ |
+ A class for delayed initialization of Tools modules. |
+ |
+ Instances of this class associate a list of Tool modules with |
+ a list of Builder method names that will be added by those Tool |
+ modules. As part of instantiating this object for a particular |
+ construction environment, we also add the appropriate |
+ ToolInitializerMethod objects for the various Builder methods |
+ that we want to use to delay Tool searches until necessary. |
+ """ |
+ def __init__(self, env, tools, names): |
+ if not SCons.Util.is_List(tools): |
+ tools = [tools] |
+ if not SCons.Util.is_List(names): |
+ names = [names] |
+ self.env = env |
+ self.tools = tools |
+ self.names = names |
+ self.methods = {} |
+ for name in names: |
+ method = ToolInitializerMethod(name, self) |
+ self.methods[name] = method |
+ env.AddMethod(method) |
+ |
+ def remove_methods(self, env): |
+ """ |
+ Removes the methods that were added by the tool initialization |
+ so we no longer copy and re-bind them when the construction |
+ environment gets cloned. |
+ """ |
+ for method in self.methods.values(): |
+ env.RemoveMethod(method) |
+ |
+ def apply_tools(self, env): |
+ """ |
+ Searches the list of associated Tool modules for one that |
+ exists, and applies that to the construction environment. |
+ """ |
+ for t in self.tools: |
+ tool = SCons.Tool.Tool(t) |
+ if tool.exists(env): |
+ env.Tool(tool) |
+ return |
+ |
+ # If we fall through here, there was no tool module found. |
+ # This is where we can put an informative error message |
+ # about the inability to find the tool. We'll start doing |
+ # this as we cut over more pre-defined Builder+Tools to use |
+ # the ToolInitializer class. |
+ |
+def Initializers(env): |
+ ToolInitializer(env, ['install'], ['_InternalInstall', '_InternalInstallAs']) |
+ def Install(self, *args, **kw): |
+ return self._InternalInstall(*args, **kw) |
+ def InstallAs(self, *args, **kw): |
+ return self._InternalInstallAs(*args, **kw) |
+ env.AddMethod(Install) |
+ env.AddMethod(InstallAs) |
+ |
+def FindTool(tools, env): |
+ for tool in tools: |
+ t = Tool(tool) |
+ if t.exists(env): |
+ return tool |
+ return None |
+ |
+def FindAllTools(tools, env): |
+ def ToolExists(tool, env=env): |
+ return Tool(tool).exists(env) |
+ return list(filter (ToolExists, tools)) |
+ |
+def tool_list(platform, env): |
+ |
+ other_plat_tools=[] |
+ # XXX this logic about what tool to prefer on which platform |
+ # should be moved into either the platform files or |
+ # the tool files themselves. |
+ # The search orders here are described in the man page. If you |
+ # change these search orders, update the man page as well. |
+ if str(platform) == 'win32': |
+ "prefer Microsoft tools on Windows" |
+ linkers = ['mslink', 'gnulink', 'ilink', 'linkloc', 'ilink32' ] |
+ c_compilers = ['msvc', 'mingw', 'gcc', 'intelc', 'icl', 'icc', 'cc', 'bcc32' ] |
+ cxx_compilers = ['msvc', 'intelc', 'icc', 'g++', 'c++', 'bcc32' ] |
+ assemblers = ['masm', 'nasm', 'gas', '386asm' ] |
+ fortran_compilers = ['gfortran', 'g77', 'ifl', 'cvf', 'f95', 'f90', 'fortran'] |
+ ars = ['mslib', 'ar', 'tlib'] |
+ other_plat_tools=['msvs','midl'] |
+ elif str(platform) == 'os2': |
+ "prefer IBM tools on OS/2" |
+ linkers = ['ilink', 'gnulink', ]#'mslink'] |
+ c_compilers = ['icc', 'gcc',]# 'msvc', 'cc'] |
+ cxx_compilers = ['icc', 'g++',]# 'msvc', 'c++'] |
+ assemblers = ['nasm',]# 'masm', 'gas'] |
+ fortran_compilers = ['ifl', 'g77'] |
+ ars = ['ar',]# 'mslib'] |
+ elif str(platform) == 'irix': |
+ "prefer MIPSPro on IRIX" |
+ linkers = ['sgilink', 'gnulink'] |
+ c_compilers = ['sgicc', 'gcc', 'cc'] |
+ cxx_compilers = ['sgic++', 'g++', 'c++'] |
+ assemblers = ['as', 'gas'] |
+ fortran_compilers = ['f95', 'f90', 'f77', 'g77', 'fortran'] |
+ ars = ['sgiar'] |
+ elif str(platform) == 'sunos': |
+ "prefer Forte tools on SunOS" |
+ linkers = ['sunlink', 'gnulink'] |
+ c_compilers = ['suncc', 'gcc', 'cc'] |
+ cxx_compilers = ['sunc++', 'g++', 'c++'] |
+ assemblers = ['as', 'gas'] |
+ fortran_compilers = ['sunf95', 'sunf90', 'sunf77', 'f95', 'f90', 'f77', |
+ 'gfortran', 'g77', 'fortran'] |
+ ars = ['sunar'] |
+ elif str(platform) == 'hpux': |
+ "prefer aCC tools on HP-UX" |
+ linkers = ['hplink', 'gnulink'] |
+ c_compilers = ['hpcc', 'gcc', 'cc'] |
+ cxx_compilers = ['hpc++', 'g++', 'c++'] |
+ assemblers = ['as', 'gas'] |
+ fortran_compilers = ['f95', 'f90', 'f77', 'g77', 'fortran'] |
+ ars = ['ar'] |
+ elif str(platform) == 'aix': |
+ "prefer AIX Visual Age tools on AIX" |
+ linkers = ['aixlink', 'gnulink'] |
+ c_compilers = ['aixcc', 'gcc', 'cc'] |
+ cxx_compilers = ['aixc++', 'g++', 'c++'] |
+ assemblers = ['as', 'gas'] |
+ fortran_compilers = ['f95', 'f90', 'aixf77', 'g77', 'fortran'] |
+ ars = ['ar'] |
+ elif str(platform) == 'darwin': |
+ "prefer GNU tools on Mac OS X, except for some linkers and IBM tools" |
+ linkers = ['applelink', 'gnulink'] |
+ c_compilers = ['gcc', 'cc'] |
+ cxx_compilers = ['g++', 'c++'] |
+ assemblers = ['as'] |
+ fortran_compilers = ['gfortran', 'f95', 'f90', 'g77'] |
+ ars = ['ar'] |
+ else: |
+ "prefer GNU tools on all other platforms" |
+ linkers = ['gnulink', 'mslink', 'ilink'] |
+ c_compilers = ['gcc', 'msvc', 'intelc', 'icc', 'cc'] |
+ cxx_compilers = ['g++', 'msvc', 'intelc', 'icc', 'c++'] |
+ assemblers = ['gas', 'nasm', 'masm'] |
+ fortran_compilers = ['gfortran', 'g77', 'ifort', 'ifl', 'f95', 'f90', 'f77'] |
+ ars = ['ar', 'mslib'] |
+ |
+ c_compiler = FindTool(c_compilers, env) or c_compilers[0] |
+ |
+ # XXX this logic about what tool provides what should somehow be |
+ # moved into the tool files themselves. |
+ if c_compiler and c_compiler == 'mingw': |
+ # MinGW contains a linker, C compiler, C++ compiler, |
+ # Fortran compiler, archiver and assembler: |
+ cxx_compiler = None |
+ linker = None |
+ assembler = None |
+ fortran_compiler = None |
+ ar = None |
+ else: |
+ # Don't use g++ if the C compiler has built-in C++ support: |
+ if c_compiler in ('msvc', 'intelc', 'icc'): |
+ cxx_compiler = None |
+ else: |
+ cxx_compiler = FindTool(cxx_compilers, env) or cxx_compilers[0] |
+ linker = FindTool(linkers, env) or linkers[0] |
+ assembler = FindTool(assemblers, env) or assemblers[0] |
+ fortran_compiler = FindTool(fortran_compilers, env) or fortran_compilers[0] |
+ ar = FindTool(ars, env) or ars[0] |
+ |
+ other_tools = FindAllTools(other_plat_tools + [ |
+ 'dmd', |
+ #TODO: merge 'install' into 'filesystem' and |
+ # make 'filesystem' the default |
+ 'filesystem', |
+ 'm4', |
+ 'wix', #'midl', 'msvs', |
+ # Parser generators |
+ 'lex', 'yacc', |
+ # Foreign function interface |
+ 'rpcgen', 'swig', |
+ # Java |
+ 'jar', 'javac', 'javah', 'rmic', |
+ # TeX |
+ 'dvipdf', 'dvips', 'gs', |
+ 'tex', 'latex', 'pdflatex', 'pdftex', |
+ # Archivers |
+ 'tar', 'zip', 'rpm', |
+ # SourceCode factories |
+ 'BitKeeper', 'CVS', 'Perforce', |
+ 'RCS', 'SCCS', # 'Subversion', |
+ ], env) |
+ |
+ tools = ([linker, c_compiler, cxx_compiler, |
+ fortran_compiler, assembler, ar] |
+ + other_tools) |
+ |
+ return [x for x in tools if x] |
+ |
+# 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/Tool/__init__.py |
___________________________________________________________________ |
Added: svn:eol-style |
+ LF |