env = Environment(tools = [my_tool])
.EE
-SCons supports the following tool specifications
-out of the box on
-.B cygwin
-and
-.B posix
-platforms:
+If no tool list is specified, then SCons will auto-detect the installed
+tools using the PATH variable in the ENV construction variable and the
+platform name when the Environment is constructed. Changing the PATH
+variable after the Environment is constructed will not cause the tools to
+be redetected.
+SCons supports the following tool specifications
+out of the box on all platforms:
.ES
ar
dvipdf
dvips
g++
g77
-gas (if the GNU assembler is available)
-gcc
-gnulink
-latex
-lex
-nasm (if the GNU assembler is not available)
-pdflatex
-pdftex
-tar
-tex
-yacc
-.EE
-
-SCons supports the following tool specifications out of the box on
-.B os2
-platforms:
-
-.ES
-dvipdf
-dvips
-g77
-icc
-ifl
-ilink
-latex
-lex
-nasm
-pdflatex
-pdftex
-tex
-yacc
-.EE
-
-SCons supports the following tool specifications out of the box on
-.B win32
-platforms:
-
-.ES
-dvipdf
-dvips
-g77
icc
ifl
ilink
+gas
+gcc
+gnulink
latex
lex
-lib
+masm
mslink
msvc
-masm
nasm
pdflatex
pdftex
yacc
.EE
+On posix and cygwin platforms the GNU tools (e.g. gcc) are preferred by SCons,
+on win32 the Microsoft tools (e.g. msvc) are preferred by SCons, and in OS/2 the IBM
+tools (e.g. icc) are preferred by SCons.
+
.SS Builder Methods
Build rules are specified by calling a construction
%define name scons
-%define version 0.08
+%define version 0.09
%define release 1
Summary: an Open Source software construction tool
/usr/lib/scons/SCons/Tool/__init__.pyc
/usr/lib/scons/SCons/Tool/ar.py
/usr/lib/scons/SCons/Tool/ar.pyc
+/usr/lib/scons/SCons/Tool/default.py
+/usr/lib/scons/SCons/Tool/default.pyc
/usr/lib/scons/SCons/Tool/dvipdf.py
/usr/lib/scons/SCons/Tool/dvipdf.pyc
/usr/lib/scons/SCons/Tool/dvips.py
/usr/lib/scons/SCons/Tool/gnulink.pyc
/usr/lib/scons/SCons/Tool/icc.py
/usr/lib/scons/SCons/Tool/icc.pyc
+/usr/lib/scons/SCons/Tool/ifl.py
+/usr/lib/scons/SCons/Tool/ifl.pyc
/usr/lib/scons/SCons/Tool/ilink.py
/usr/lib/scons/SCons/Tool/ilink.pyc
/usr/lib/scons/SCons/Tool/latex.py
SCons/Taskmaster.py
SCons/Tool/__init__.py
SCons/Tool/ar.py
+SCons/Tool/default.py
SCons/Tool/dvipdf.py
SCons/Tool/dvips.py
SCons/Tool/g++.py
platform = SCons.Platform.Platform(platform)
platform(self)
if tools is None:
- tools = SCons.Platform.DefaultToolList(platform)
+ tools = ['default']
for tool in tools:
if SCons.Util.is_String(tool):
tool = SCons.Tool.Tool(tool)
file.close()
return sys.modules[full_name]
-def DefaultToolList(platform):
+def DefaultToolList(platform, env):
"""Select a default tool list for the specified platform.
"""
- return SCons.Tool.tool_list(platform)
+ return SCons.Tool.tool_list(platform, env)
class PlatformSpec:
def __init__(self, name):
except KeyError:
c_file = SCons.Defaults.CFile()
env['BUILDERS']['CFile'] = c_file
+ env['CFILESUFFIX'] = '.c'
try:
cxx_file = env['BUILDERS']['CXXFile']
except KeyError:
cxx_file = SCons.Defaults.CXXFile()
env['BUILDERS']['CXXFile'] = cxx_file
+ env['CXXFILESUFFIX'] = '.cc'
return (c_file, cxx_file)
-def FindTool(tools):
+def FindTool(tools, env):
for tool in tools:
t = Tool(tool)
- if t.exists():
+ if t.exists(env):
return tool
return None
-def _ToolExists(tool):
- return Tool(tool).exists()
-
-def FindAllTools(tools):
- return filter (_ToolExists, tools)
+def FindAllTools(tools, env):
+ def ToolExists(tool, env=env):
+ return Tool(tool).exists(env)
+ return filter (ToolExists, tools)
-def tool_list(platform):
+def tool_list(platform, env):
if str(platform) == 'win32':
"prefer Microsoft tools on Windows"
linkers = ['mslink', 'gnulink', 'ilink']
fortran_compilers = ['g77', 'ifl']
ars = ['ar', 'lib']
- linker = FindTool(linkers)
- c_compiler = FindTool(c_compilers)
- assembler = FindTool(assemblers)
- fortran_compiler = FindTool(fortran_compilers)
- ar = FindTool(ars)
+ linker = FindTool(linkers, env) or linkers[0]
+ c_compiler = FindTool(c_compilers, env) or c_compilers[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]
# Don't use g++ if the C compiler has built-in C++ support:
if c_compiler and (c_compiler == 'msvc' or c_compiler == 'icc'):
cxx_compiler = None
else:
- cxx_compiler = FindTool(['g++'])
+ cxx_compiler = FindTool(['g++'], env)
other_tools = FindAllTools(['dvipdf', 'dvips',
'latex', 'lex',
'pdflatex', 'pdftex',
- 'tar', 'tex', 'yacc'])
+ 'tar', 'tex', 'yacc'], env)
tools = ([linker, c_compiler, cxx_compiler,
fortran_compiler, assembler, ar]
arcom = '$AR $ARFLAGS $TARGET $SOURCES'
ranlib = 'ranlib'
- if SCons.Util.WhereIs(ranlib):
+ if SCons.Util.Detect([ranlib], env):
arcom = arcom + '\n$RANLIB $RANLIBFLAGS $TARGET'
env['AR'] = 'ar'
env['SHLINKFLAGS'] = '$LINKFLAGS -shared'
env['SHLINKCOM'] = '$SHLINK $SHLINKFLAGS -o $TARGET $SOURCES $_LIBDIRFLAGS $_LIBFLAGS'
-def exists():
- return SCons.Util.WhereIs('ar')
+def exists(env):
+ return SCons.Util.Detect(['ar'], env)
--- /dev/null
+"""SCons.Tool.default
+
+Initialization with a default tool list.
+
+There normally shouldn't be any need to import this module directly.
+It will usually be imported through the generic SCons.Tool.Tool()
+selection method.
+
+"""
+
+#
+# Copyright (c) 2001, 2002 Steven Knight
+#
+# 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__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
+
+import SCons.Tool
+
+def generate(env, platform):
+ """Add default tools."""
+ for t in SCons.Tool.tool_list(platform, env):
+ SCons.Tool.Tool(t, platform)(env, platform)
+
+def exists(env):
+ return 1
env['DVIPDFFLAGS'] = ''
env['PDFCOM'] = '$DVIPDF $DVIPDFFLAGS $SOURCES $TARGET'
-def exists():
- return SCons.Util.WhereIs('dvipdf')
+def exists(env):
+ return SCons.Util.Detect(['dvipdf'], env)
env['DVIPSFLAGS'] = ''
env['PSCOM'] = '$DVIPS $DVIPSFLAGS -o $TARGET $SOURCES'
-def exists():
- return SCons.Util.WhereIs('dvips')
+def exists(env):
+ return SCons.Util.Detect(['dvips'], env)
compilers = ['c++', 'g++']
-for i in compilers:
- if SCons.Util.WhereIs(i):
- cxx = i
- break
- cxx = None
-
CXXSuffixes = ['.cc', '.cpp', '.cxx', '.c++', '.C++']
if os.path.normcase('.c') != os.path.normcase('.C'):
CXXSuffixes.append('.C')
static_obj.add_action(suffix, SCons.Defaults.CXXAction)
shared_obj.add_action(suffix, SCons.Defaults.ShCXXAction)
- env['CXX'] = cxx
+ env['CXX'] = SCons.Util.Detect(compilers, env) or 'c++'
env['CXXFLAGS'] = '$CCFLAGS'
env['CXXCOM'] = '$CXX $CXXFLAGS $CPPFLAGS $_CPPINCFLAGS -c -o $TARGET $SOURCES'
env['SHCXX'] = '$CXX'
env['CXXFILESUFFIX'] = '.cc'
-def exists():
- return cxx
+def exists(env):
+ return SCons.Util.Detect(compilers, env)
import SCons.Util
compilers = ['g77', 'f77']
-for i in compilers:
- if SCons.Util.WhereIs(i):
- compiler = i
- break
- compiler = None
-
F77Suffixes = ['.f', '.for', '.FOR']
F77PPSuffixes = ['.fpp', '.FPP']
static_obj.add_action(suffix, SCons.Defaults.F77PPAction)
shared_obj.add_action(suffix, SCons.Defaults.ShF77PPAction)
- env['F77'] = 'g77'
+ env['F77'] = SCons.Util.Detect(compilers, env) or 'g77'
env['F77FLAGS'] = ''
env['F77COM'] = '$F77 $F77FLAGS $_F77INCFLAGS -c -o $TARGET $SOURCES'
env['F77PPCOM'] = '$F77 $F77FLAGS $CPPFLAGS $_F77INCFLAGS -c -o $TARGET $SOURCES'
env['SHF77COM'] = '$SHF77 $SHF77FLAGS $_F77INCFLAGS -c -o $TARGET $SOURCES'
env['SHF77PPCOM'] = '$SHF77 $SHF77FLAGS $CPPFLAGS $_F77INCFLAGS -c -o $TARGET $SOURCES'
-def exists():
- return compiler
+def exists(env):
+ return SCons.Util.Detect(compilers, env)
assemblers = ['as', 'gas']
-for i in assemblers:
- if SCons.Util.WhereIs(i):
- as = i
- break
- as = None
-
-
ASSuffixes = ['.s', '.asm', '.ASM']
ASPPSuffixes = ['.spp', '.SPP']
if os.path.normcase('.s') == os.path.normcase('.S'):
for suffix in ASPPSuffixes:
static_obj.add_action(suffix, SCons.Defaults.ASPPAction)
- env['AS'] = as
+ env['AS'] = SCons.Util.Detect(assemblers, env) or 'as'
env['ASFLAGS'] = ''
env['ASCOM'] = '$AS $ASFLAGS -o $TARGET $SOURCES'
env['ASPPCOM'] = '$CC $ASFLAGS $CPPFLAGS -o $TARGET $SOURCES'
-def exists():
- return as
+def exists(env):
+ return SCons.Util.Detect(assemblers, env)
compilers = ['cc', 'gcc']
-for i in compilers:
- if SCons.Util.WhereIs(i):
- cc = i
- break
- cc = None
-
-
CSuffixes = ['.c']
if os.path.normcase('.c') == os.path.normcase('.C'):
CSuffixes.append('.C')
static_obj.add_action(suffix, SCons.Defaults.CAction)
shared_obj.add_action(suffix, SCons.Defaults.ShCAction)
- env['CC'] = cc
+ env['CC'] = SCons.Util.Detect(compilers, env) or 'cc'
env['CCFLAGS'] = ''
env['CCCOM'] = '$CC $CCFLAGS $CPPFLAGS $_CPPINCFLAGS -c -o $TARGET $SOURCES'
env['SHCC'] = '$CC'
env['CFILESUFFIX'] = '.c'
-def exists():
- return cc
+def exists(env):
+ return SCons.Util.Detect(compilers, env)
linkers = ['c++', 'cc', 'g++', 'gcc']
-for i in linkers:
- if SCons.Util.WhereIs(i):
- linker = i
- break
- linker = None
-
def generate(env, platform):
"""Add Builders and construction variables for gnulink to an Environment."""
env['BUILDERS']['SharedLibrary'] = SCons.Defaults.SharedLibrary
env['SHLINKFLAGS'] = '$LINKFLAGS -shared'
env['SHLINKCOM'] = '$SHLINK $SHLINKFLAGS -o $TARGET $SOURCES $_LIBDIRFLAGS $_LIBFLAGS'
env['SHLIBEMITTER']= None
- env['LINK'] = linker
+ env['LINK'] = SCons.Util.Detect(linkers, env) or 'c++'
env['LINKFLAGS'] = ''
env['LINKCOM'] = '$LINK $LINKFLAGS -o $TARGET $SOURCES $_LIBDIRFLAGS $_LIBFLAGS'
env['LIBDIRPREFIX']='-L'
env['LIBLINKPREFIX']='-l'
env['LIBLINKSUFFIX']=''
-def exists():
- return linker
+def exists(env):
+ return SCons.Util.Detect(linkers, env)
env['CXXCOM'] = '$CXX $CXXFLAGS $CPPFLAGS $_CPPINCFLAGS /c $SOURCES /Fo$TARGET'
env['INCPREFIX'] = '/I'
env['INCSUFFIX'] = ''
-
+
env['CFILESUFFIX'] = '.c'
env['CXXFILESUFFIX'] = '.cc'
-
-def exists():
- return SCons.Util.WhereIs('icc')
+
+def exists(env):
+ return SCons.Util.Detect(['icc'], env)
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
import os.path
-import string
import SCons.Action
import SCons.Tool
env['SHF77COM'] = '$SHF77 $SHF77FLAGS $_F77INCFLAGS /c $SOURCES /Fo$TARGET'
env['SHF77PPCOM'] = '$SHF77 $SHF77FLAGS $CPPFLAGS $_F77INCFLAGS /c $SOURCES /Fo$TARGET'
-def exists():
- return SCons.Util.WhereIs('ifl')
+def exists(env):
+ return SCons.Util.Detect(['ifl'], env)
env['LIBLINKPREFIX']=''
env['LIBLINKSUFFIX']='$LIBSUFFIX'
-def exists():
- return SCons.Util.WhereIs('ilink')
+def exists(env):
+ return SCons.Util.Detect(['ilink'], env)
env['LATEXFLAGS'] = ''
env['LATEXCOM'] = '$LATEX $LATEXFLAGS $SOURCES'
-def exists():
- return SCons.Util.WhereIs('latex')
+def exists(env):
+ return SCons.Util.Detect(['latex'], env)
env['LEXFLAGS'] = ''
env['LEXCOM'] = '$LEX $LEXFLAGS -t $SOURCES > $TARGET'
-def exists():
- return SCons.Util.WhereIs('lex')
+def exists(env):
+ return SCons.Util.Detect(['lex'], env)
env['ARFLAGS'] = '/nologo'
env['ARCOM'] = '$AR $ARFLAGS /OUT:$TARGET $SOURCES'
-def exists():
- return SCons.Util.WhereIs('lib')
+def exists(env):
+ return SCons.Util.Detect(['lib'], env)
env['ASCOM'] = '$AS $ASFLAGS /c /Fo$TARGET $SOURCES'
env['ASPPCOM'] = '$CC $ASFLAGS $CPPFLAGS /c /Fo$TARGET $SOURCES'
-def exists():
- return SCons.Util.WhereIs('ml')
+def exists(env):
+ return SCons.Util.Detect(['ml'], env)
env['ENV']['LIB'] = lib_path
env['ENV']['PATH'] = exe_path
-def exists():
- return SCons.Util.WhereIs('link')
+def exists(env):
+ return SCons.Util.Detect(['link'], env)
include_path, lib_path, exe_path = get_msdev_paths()
env['ENV']['INCLUDE'] = include_path
env['ENV']['PATH'] = exe_path
-
+
env['CFILESUFFIX'] = '.c'
env['CXXFILESUFFIX'] = '.cc'
-
-def exists():
- return SCons.Util.WhereIs('cl')
+
+def exists(env):
+ return SCons.Util.Detect(['cl'], env)
env['ASCOM'] = '$AS $ASFLAGS -o $TARGET $SOURCES'
env['ASPPCOM'] = '$CC $ASFLAGS $CPPFLAGS -c -o $TARGET $SOURCES'
-def exists():
- return SCons.Util.WhereIs('nasm')
+def exists(env):
+ return SCons.Util.Detect(['nasm'], env)
env['PDFLATEXFLAGS'] = ''
env['PDFLATEXCOM'] = '$PDFLATEX $PDFLATEXFLAGS $SOURCES $TARGET'
-def exists():
- return SCons.Util.WhereIs('pdflatex')
+def exists(env):
+ return SCons.Util.Detect(['pdflatex'], env)
env['PDFTEXFLAGS'] = ''
env['PDFTEXCOM'] = '$PDFTEX $PDFTEXFLAGS $SOURCES $TARGET'
-def exists():
- return SCons.Util.WhereIs('pdftex')
+def exists(env):
+ return SCons.Util.Detect(['pdftex'], env)
tars = ['gtar', 'tar']
-for i in tars:
- if SCons.Util.WhereIs(i):
- tar = i
- break
- tar = None
-
TarBuilder = SCons.Builder.Builder(action = '$TARCOM',
source_factory = SCons.Node.FS.default_fs.Entry,
suffix = '$TARSUFFIX',
bld = TarBuilder
env['BUILDERS']['Tar'] = bld
- env['TAR'] = tar
+ env['TAR'] = SCons.Util.Detect(tars, env) or 'gtar'
env['TARFLAGS'] = '-c'
env['TARCOM'] = '$TAR $TARFLAGS -f $TARGET $SOURCES'
env['TARSUFFIX'] = '.tar'
-def exists():
- return tar
+def exists(env):
+ return SCons.Util.Detect(tars, env)
env['TEXFLAGS'] = ''
env['TEXCOM'] = '$TEX $TEXFLAGS $SOURCES'
-def exists():
- return SCons.Util.WhereIs('tex')
+def exists(env):
+ return SCons.Util.Detect(['tex'], env)
env['YACCFLAGS'] = ''
env['YACCCOM'] = '$YACC $YACCFLAGS -o $TARGET $SOURCES'
-def exists():
- return SCons.Util.WhereIs('yacc')
+def exists(env):
+ return SCons.Util.Detect(['yacc'], env)
if stat.S_IMODE(st[stat.ST_MODE]) & 0111:
return f
return None
+
+def Detect(progs, env=None):
+ "Return the first available program in progs"
+ path = None
+ pathext = None
+ if env and env.has_key('ENV'):
+ if env['ENV'].has_key('PATH'):
+ path = env['ENV']['PATH']
+ if env['ENV'].has_key('PATHEXT'):
+ pathext = env['ENV']['PATHEXT']
+ for prog in progs:
+ path = WhereIs(prog, path, pathext)
+ if path: return prog
+ return None
""")
test.write('SConstruct', """
-env = Environment(LEX = r'%s mylex.py')
+env = Environment(LEX = r'%s mylex.py', tools = ['lex'])
env.CFile(target = 'foo', source = 'foo.l')
env.Copy(CFILESUFFIX = '.xyz').CFile(target = 'bar', source = 'bar.l')
""" % python)
""")
test.write('SConstruct', """
-env = Environment(LEX = r'%s mylex.py')
+env = Environment(LEX = r'%s mylex.py', tools = ['lex'])
env.CXXFile(target = 'foo', source = 'foo.ll')
env.Copy(CXXFILESUFFIX = '.xyz').CXXFile(target = 'bar', source = 'bar.ll')
""" % python)
test.write('SConstruct', """
env = Environment(TEX = r'%s mytex.py',
LATEX = r'%s mylatex.py',
- DVIPDF = r'%s mydvipdf.py')
+ DVIPDF = r'%s mydvipdf.py',
+ tools=['latex', 'tex', 'dvipdf'])
dvi = env.DVI(target = 'test1.dvi', source = 'test1.tex')
env.DVI(target = 'test2.dvi', source = 'test2.tex')
env.PDF(target = 'test1.pdf', source = dvi)
test.write('SConstruct', """
env = Environment(TEX = r'%s mytex.py',
LATEX = r'%s mylatex.py',
- DVIPDF = r'%s mydvipdf.py', DVIPDFFLAGS = '-x')
+ DVIPDF = r'%s mydvipdf.py', DVIPDFFLAGS = '-x',
+ tools = ['tex', 'latex', 'dvipdf'])
dvi = env.DVI(target = 'test1.dvi', source = 'test1.tex')
env.DVI(target = 'test2.dvi', source = 'test2.tex')
env.PDF(target = 'test1.pdf', source = dvi)
test.write('SConstruct', """
env = Environment(TEX = r'%s mytex.py',
LATEX = r'%s mylatex.py',
- DVIPS = r'%s mydvips.py')
+ DVIPS = r'%s mydvips.py',
+ tools=['tex', 'latex', 'dvips'])
dvi = env.DVI(target = 'test1.dvi', source = 'test1.tex')
env.PostScript(target = 'test1.ps', source = dvi)
env.PostScript(target = 'test2.ps', source = 'test2.tex')
test.write('SConstruct', """
env = Environment(TEX = r'%s mytex.py',
LATEX = r'%s mylatex.py',
- DVIPS = r'%s mydvips.py', DVIPSFLAGS = '-x')
+ DVIPS = r'%s mydvips.py', DVIPSFLAGS = '-x',
+ tools=['tex', 'latex', 'dvips'])
dvi = env.DVI(target = 'test1.dvi', source = 'test1.tex')
env.PostScript(target = 'test1.ps', source = dvi)
env.PostScript(target = 'test2.ps', source = 'test2.tex')
""")
test.write('SConstruct', """
-env = Environment(LATEX = r'%s mylatex.py')
+env = Environment(LATEX = r'%s mylatex.py', tools=['latex'])
env.DVI(target = 'test1.dvi', source = 'test1.ltx')
env.DVI(target = 'test2.dvi', source = 'test2.latex')
""" % python)
""")
test.write('SConstruct', """
-env = Environment(LATEX = r'%s mylatex.py', LATEXFLAGS = '-x')
+env = Environment(LATEX = r'%s mylatex.py', LATEXFLAGS = '-x', tools=['latex'])
env.DVI(target = 'test1.dvi', source = 'test1.ltx')
env.Copy(LATEXFLAGS = '-t').DVI(target = 'test2.dvi', source = 'test2.latex')
""" % python)
""")
test.write('SConstruct', """
-env = Environment(LEX = r'%s mylex.py')
+env = Environment(LEX = r'%s mylex.py', tools=['default', 'lex'])
env.Program(target = 'aaa', source = 'aaa.l')
""" % python)
""")
test.write('SConstruct', """
-env = Environment(LEX = r'%s mylex.py', LEXFLAGS = '-x')
+env = Environment(LEX = r'%s mylex.py', LEXFLAGS = '-x', tools=['default', 'lex'])
env.Program(target = 'aaa', source = 'aaa.l')
""" % python)
""")
test.write('SConstruct', """
-env = Environment(PDFLATEX = r'%s mypdflatex.py')
+env = Environment(PDFLATEX = r'%s mypdflatex.py', tools=['pdflatex'])
env.PDF(target = 'test1.pdf', source = 'test1.ltx')
env.PDF(target = 'test2.pdf', source = 'test2.latex')
""" % python)
""")
test.write('SConstruct', """
-env = Environment(PDFLATEX = r'%s mypdflatex.py', PDFLATEXFLAGS = '-x')
+env = Environment(PDFLATEX = r'%s mypdflatex.py', PDFLATEXFLAGS = '-x', tools=['pdflatex'])
env.PDF(target = 'test1.pdf', source = 'test1.ltx')
env.Copy(PDFLATEXFLAGS = '-t').PDF(target = 'test2.pdf', source = 'test2.latex')
""" % python)
""")
test.write('SConstruct', """
-env = Environment(PDFTEX = r'%s mypdftex.py')
+env = Environment(PDFTEX = r'%s mypdftex.py', tools=['pdftex'])
env.PDF(target = 'test.pdf', source = 'test.tex')
""" % python)
""")
test.write('SConstruct', """
-env = Environment(PDFTEX = r'%s mypdftex.py', PDFTEXFLAGS = '-x')
+env = Environment(PDFTEX = r'%s mypdftex.py', PDFTEXFLAGS = '-x', tools=['pdftex'])
env.PDF(target = 'test.pdf', source = 'test.tex')
""" % python)
""")
test.write('SConstruct', """
-env = Environment(TEX = r'%s mytex.py')
+env = Environment(TEX = r'%s mytex.py', tools=['tex'])
env.DVI(target = 'test.dvi', source = 'test.tex')
""" % python)
""")
test.write('SConstruct', """
-env = Environment(TEX = r'%s mytex.py', TEXFLAGS = '-x')
+env = Environment(TEX = r'%s mytex.py', TEXFLAGS = '-x', tools=['tex'])
env.DVI(target = 'test.dvi', source = 'test.tex')
""" % python)
if sys.platform == 'win32':
_exe = '.exe'
+ compiler = 'msvc'
+ linker = 'mslink'
else:
_exe = ''
+ compiler = 'gcc'
+ linker = 'gnulink'
test = TestSCons.TestSCons()
sys.exit(0)
""")
+
+
test.write('SConstruct', """
-env = Environment(YACC = r'%s myyacc.py')
+env = Environment(YACC = r'%s myyacc.py', tools=['default', 'yacc'])
env.Program(target = 'aaa', source = 'aaa.y')
""" % python)
if sys.platform == 'win32':
_exe = '.exe'
+ compiler = 'msvc'
+ linker = 'mslink'
else:
_exe = ''
+ compiler = 'gcc'
+ linker = 'gnulink'
test = TestSCons.TestSCons()
""")
test.write('SConstruct', """
-env = Environment(YACC = r'%s myyacc.py', YACCFLAGS = '-x')
+env = Environment(YACC = r'%s myyacc.py', YACCFLAGS = '-x', tools=['yacc', '%s', '%s'])
env.Program(target = 'aaa', source = 'aaa.y')
-""" % python)
+""" % (python, linker, compiler))
test.write('aaa.y', r"""
int