- Supply a more descriptive error message when the source for a target
can't be found.
+ - Initialize all *FLAGS variables with objects do the right thing with
+ appending flags as strings or lists.
+
From Vincent Risi:
- Add support for the bcc32, ilink32 and tlib Borland tools.
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
-import as
from SCons.Tool.PharLapCommon import addPharLapPaths
+import SCons.Util
+
+import as
def generate(env):
"""Add Builders and construction variables for ar to an Environment."""
as.generate(env)
env['AS'] = '386asm'
- env['ASFLAGS'] = ''
+ env['ASFLAGS'] = SCons.Util.CLVar('')
env['ASCOM'] = '$AS $ASFLAGS $SOURCES -o $TARGET'
env['ASPPCOM'] = '$CC $ASFLAGS $CPPFLAGS $_CPPDEFFLAGS $_CPPINCFLAGS $SOURCES -o $TARGET'
import os.path
import SCons.Builder
+import SCons.Util
def generate(env):
"""Add a Builder factory function and construction variables for
env['BITKEEPER'] = 'bk'
env['BITKEEPERGET'] = '$BITKEEPER get'
- env['BITKEEPERGETFLAGS'] = ''
+ env['BITKEEPERGETFLAGS'] = SCons.Util.CLVar('')
env['BITKEEPERCOM'] = '$BITKEEPERGET $BITKEEPERGETFLAGS $TARGET'
def exists(env):
import os.path
import SCons.Builder
+import SCons.Util
def generate(env):
"""Add a Builder factory function and construction variables for
setattr(env, 'CVS', CVSFactory)
env['CVS'] = 'cvs'
- env['CVSFLAGS'] = '-d $CVSREPOSITORY'
- env['CVSCOFLAGS'] = ''
+ env['CVSFLAGS'] = SCons.Util.CLVar('-d $CVSREPOSITORY')
+ env['CVSCOFLAGS'] = SCons.Util.CLVar('')
env['CVSCOM'] = '$CVS $CVSFLAGS co $CVSCOFLAGS ${TARGET.posix}'
def exists(env):
import os
import SCons.Builder
-import SCons.Util
import SCons.Node.FS
+import SCons.Util
# This function should maybe be moved to SCons.Util?
from SCons.Tool.PharLapCommon import addPathIfNotExists
setattr(env, 'Perforce', PerforceFactory)
env['P4'] = 'p4'
- env['P4FLAGS'] = ''
+ env['P4FLAGS'] = SCons.Util.CLVar('')
env['P4COM'] = '$P4 $P4FLAGS sync $TARGET'
try:
environ = env['ENV']
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
import SCons.Builder
+import SCons.Util
def generate(env):
"""Add a Builder factory function and construction variables for
env['RCS'] = 'rcs'
env['RCS_CO'] = 'co'
- env['RCS_COFLAGS'] = ''
+ env['RCS_COFLAGS'] = SCons.Util.CLVar('')
env['RCS_COCOM'] = '$RCS_CO $RCS_COFLAGS $TARGET'
def exists(env):
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
import SCons.Builder
+import SCons.Util
def generate(env):
"""Add a Builder factory function and construction variables for
setattr(env, 'SCCS', SCCSFactory)
env['SCCS'] = 'sccs'
- env['SCCSFLAGS'] = ''
- env['SCCSGETFLAGS'] = ''
+ env['SCCSFLAGS'] = SCons.Util.CLVar('')
+ env['SCCSGETFLAGS'] = SCons.Util.CLVar('')
env['SCCSCOM'] = '$SCCS $SCCSFLAGS get $SCCSGETFLAGS $TARGET'
def exists(env):
import os.path
import SCons.Builder
+import SCons.Util
def generate(env):
"""Add a Builder factory function and construction variables for
setattr(env, 'Subversion', SubversionFactory)
env['SVN'] = 'svn'
- env['SVNFLAGS'] = ''
+ env['SVNFLAGS'] = SCons.Util.CLVar('')
env['SVNCOM'] = '$SVN $SVNFLAGS cat $SVNREPOSITORY/$SVNMODULE$TARGET > $TARGET'
def exists(env):
t = SCons.Tool.Tool('g++')
t(env)
assert (env['CXX'] == 'c++' or env['CXX'] == 'g++'), env['CXX']
- assert env['CXXFLAGS'] == '$CCFLAGS', env['CXXFLAGS']
+ assert env['CXXFLAGS'] == ['$CCFLAGS'], env['CXXFLAGS']
assert env['INCPREFIX'] == '-I', env['INCPREFIX']
assert env['TOOLS'] == ['g++'], env['TOOLS']
import os
import os.path
+import SCons.Util
+
import aixcc
import link
link.generate(env)
env['SMARTLINKFLAGS'] = smart_linkflags
- env['LINKFLAGS'] = '$SMARTLINKFLAGS'
- env['SHLINKFLAGS'] = '$LINKFLAGS -qmkshrobj -qsuppress=1501-218'
+ env['LINKFLAGS'] = SCons.Util.CLVar('$SMARTLINKFLAGS')
+ env['SHLINKFLAGS'] = SCons.Util.CLVar('$LINKFLAGS -qmkshrobj -qsuppress=1501-218')
env['SHLIBSUFFIX'] = '.a'
def exists(env):
import SCons.Defaults
import SCons.Tool
+import SCons.Util
def generate(env):
"""Add Builders and construction variables for ar to an Environment."""
arcom = arcom + '\n$RANLIB $RANLIBFLAGS $TARGET'
env['AR'] = 'ar'
- env['ARFLAGS'] = 'r'
+ env['ARFLAGS'] = SCons.Util.CLVar('r')
env['RANLIB'] = ranlib
- env['RANLIBFLAGS'] = ''
+ env['RANLIBFLAGS'] = SCons.Util.CLVar('')
env['ARCOM'] = arcom
def exists(env):
static_obj.add_action(suffix, SCons.Defaults.ASPPAction)
env['AS'] = env.Detect(assemblers) or 'as'
- env['ASFLAGS'] = ''
+ env['ASFLAGS'] = SCons.Util.CLVar('')
env['ASCOM'] = '$AS $ASFLAGS -o $TARGET $SOURCES'
env['ASPPCOM'] = '$CC $ASFLAGS $CPPFLAGS $_CPPDEFFLAGS $_CPPINCFLAGS -c -o $TARGET $SOURCES'
static_obj.add_action(suffix, SCons.Defaults.CAction)
shared_obj.add_action(suffix, SCons.Defaults.ShCAction)
env['CC'] = 'bcc32'
- env['CCFLAGS'] = ''
+ env['CCFLAGS'] = SCons.Util.CLVar('')
env['CCCOM'] = '$CC -q $CCFLAGS $CPPFLAGS $_CPPDEFFLAGS $_CPPINCFLAGS -c -o $TARGET $SOURCES'
env['SHCC'] = '$CC'
- env['SHCCFLAGS'] = '$CCFLAGS'
+ env['SHCCFLAGS'] = SCons.Util.CLVar('$CCFLAGS')
env['SHCCCOM'] = '$SHCC -WD $SHCCFLAGS $CPPFLAGS $_CPPDEFFLAGS $_CPPINCFLAGS -c -o $TARGET $SOURCES'
env['CPPDEFPREFIX'] = '-D'
env['CPPDEFSUFFIX'] = ''
shared_obj.add_action(suffix, SCons.Defaults.ShCXXAction)
env['CXX'] = 'c++'
- env['CXXFLAGS'] = '$CCFLAGS'
+ env['CXXFLAGS'] = SCons.Util.CLVar('$CCFLAGS')
env['CXXCOM'] = '$CXX $CXXFLAGS $CPPFLAGS $_CPPDEFFLAGS $_CPPINCFLAGS -c -o $TARGET $SOURCES'
env['SHCXX'] = '$CXX'
- env['SHCXXFLAGS'] = '$CXXFLAGS'
+ env['SHCXXFLAGS'] = SCons.Util.CLVar('$CXXFLAGS')
env['SHCXXCOM'] = '$SHCXX $SHCXXFLAGS $CPPFLAGS $_CPPDEFFLAGS $_CPPINCFLAGS -c -o $TARGET $SOURCES'
env['CPPDEFPREFIX'] = '-D'
shared_obj.add_action(suffix, SCons.Defaults.ShCAction)
env['CC'] = 'cc'
- env['CCFLAGS'] = ''
+ env['CCFLAGS'] = SCons.Util.CLVar('')
env['CCCOM'] = '$CC $CCFLAGS $CPPFLAGS $_CPPDEFFLAGS $_CPPINCFLAGS -c -o $TARGET $SOURCES'
env['SHCC'] = '$CC'
- env['SHCCFLAGS'] = '$CCFLAGS'
+ env['SHCCFLAGS'] = SCons.Util.CLVar('$CCFLAGS')
env['SHCCCOM'] = '$SHCC $SHCCFLAGS $CPPFLAGS $_CPPDEFFLAGS $_CPPINCFLAGS -c -o $TARGET $SOURCES'
env['CPPDEFPREFIX'] = '-D'
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
import SCons.Defaults
+import SCons.Util
def generate(env):
"""Add Builders and construction variables for dvipdf to an Environment."""
bld.add_action('.dvi', '$PDFCOM')
env['DVIPDF'] = 'dvipdf'
- env['DVIPDFFLAGS'] = ''
+ env['DVIPDFFLAGS'] = SCons.Util.CLVar('')
env['DVIPDFCOM'] = '$DVIPDF $DVIPDFFLAGS $SOURCES $TARGET'
# Deprecated synonym.
- env['PDFCOM'] = '$DVIPDFCOM'
+ env['PDFCOM'] = ['$DVIPDFCOM']
def exists(env):
return env.Detect('dvipdf')
import SCons.Action
import SCons.Defaults
+import SCons.Util
PostScript = SCons.Builder.Builder(action = '$PSCOM',
prefix = '$PSPREFIX',
env['BUILDERS']['PostScript'] = PostScript
env['DVIPS'] = 'dvips'
- env['DVIPSFLAGS'] = ''
+ env['DVIPSFLAGS'] = SCons.Util.CLVar('')
env['PSCOM'] = '$DVIPS $DVIPSFLAGS -o $TARGET $SOURCES'
def exists(env):
shared_obj.add_action(suffix, SCons.Defaults.ShF77PPAction)
env['F77'] = env.Detect(compilers) or 'f77'
- env['F77FLAGS'] = ''
+ env['F77FLAGS'] = SCons.Util.CLVar('')
env['F77COM'] = '$F77 $F77FLAGS $_F77INCFLAGS -c -o $TARGET $SOURCES'
env['F77PPCOM'] = '$F77 $F77FLAGS $CPPFLAGS $_CPPDEFFLAGS $_F77INCFLAGS -c -o $TARGET $SOURCES'
env['SHF77'] = '$F77'
- env['SHF77FLAGS'] = '$F77FLAGS'
+ env['SHF77FLAGS'] = SCons.Util.CLVar('$F77FLAGS')
env['SHF77COM'] = '$SHF77 $SHF77FLAGS $_F77INCFLAGS -c -o $TARGET $SOURCES'
env['SHF77PPCOM'] = '$SHF77 $SHF77FLAGS $CPPFLAGS $_CPPDEFFLAGS $_F77INCFLAGS -c -o $TARGET $SOURCES'
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
import os.path
-import string
import re
import SCons.Defaults
# platform specific settings
if env['PLATFORM'] == 'cygwin':
- env['SHCXXFLAGS'] = '$CXXFLAGS'
+ env['SHCXXFLAGS'] = SCons.Util.CLVar('$CXXFLAGS')
elif env['PLATFORM'] == 'aix':
# Original line from Christian Engel added -DPIC:
- #env['SHCXXFLAGS'] = '$CXXFLAGS -DPIC -mminimal-toc'
- env['SHCXXFLAGS'] = '$CXXFLAGS -mminimal-toc'
+ #env['SHCXXFLAGS'] = SCons.Util.CLVar('$CXXFLAGS -DPIC -mminimal-toc')
+ env['SHCXXFLAGS'] = SCons.Util.CLVar('$CXXFLAGS -mminimal-toc')
env['STATIC_AND_SHARED_OBJECTS_ARE_THE_SAME'] = 1
env['SHOBJSUFFIX'] = '$OBJSUFFIX'
elif env['PLATFORM'] == 'hpux':
# Original line from Christian Engel added -DPIC:
- #env['SHCXXFLAGS'] = '$CXXFLAGS -fPIC -DPIC'
- env['SHCXXFLAGS'] = '$CXXFLAGS -fPIC'
+ #env['SHCXXFLAGS'] = SCons.Util.CLVar('$CXXFLAGS -fPIC -DPIC')
+ env['SHCXXFLAGS'] = SCons.Util.CLVar('$CXXFLAGS -fPIC')
env['SHOBJSUFFIX'] = '.pic.o'
elif env['PLATFORM'] == 'sunos':
# Original line from Christian Engel added -DPIC:
- #env['SHCXXFLAGS'] = '$CXXFLAGS -fPIC -DPIC'
- env['SHCXXFLAGS'] = '$CXXFLAGS -fPIC'
+ #env['SHCXXFLAGS'] = SCons.Util.CLVar('$CXXFLAGS -fPIC -DPIC')
+ env['SHCXXFLAGS'] = SCons.Util.CLVar('$CXXFLAGS -fPIC')
env['SHOBJSUFFIX'] = '.pic.o'
else:
# Original line from Christian Engel added -DPIC:
- #env['SHCXXFLAGS'] = '$CXXFLAGS -fPIC -DPIC'
- env['SHCXXFLAGS'] = '$CXXFLAGS -fPIC'
+ #env['SHCXXFLAGS'] = SCons.Util.CLVar('$CXXFLAGS -fPIC -DPIC')
+ env['SHCXXFLAGS'] = SCons.Util.CLVar('$CXXFLAGS -fPIC')
# determine compiler version
if env['CXX']:
line = os.popen(env['CXX'] + ' --version').readline()
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
+import SCons.Util
+
import cc
compilers = ['gcc', 'cc']
env['CC'] = env.Detect(compilers) or 'gcc'
if env['PLATFORM'] == 'cygwin':
- env['SHCCFLAGS'] = '$CCFLAGS'
+ env['SHCCFLAGS'] = SCons.Util.CLVar('$CCFLAGS')
else:
- env['SHCCFLAGS'] = ['$CCFLAGS', '-fPIC']
+ env['SHCCFLAGS'] = SCons.Util.CLVar('$CCFLAGS -fPIC')
def exists(env):
return env.Detect(compilers)
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
+import SCons.Util
+
import link
linkers = ['g++', 'gcc']
link.generate(env)
if env['PLATFORM'] == 'hpux':
- env['SHLINKFLAGS'] = '$LINKFLAGS -shared -fPIC'
+ env['SHLINKFLAGS'] = SCons.Util.CLVar('$LINKFLAGS -shared -fPIC')
def exists(env):
return env.Detect(linkers)
import SCons.Defaults
import SCons.Platform
+import SCons.Util
# Ghostscript goes by different names on different platforms...
platform = SCons.Platform.platform_default()
bld.add_action('.ps', '$GSCOM')
env['GS'] = gs
- env['GSFLAGS'] = '-dNOPAUSE -dBATCH -sDEVICE=pdfwrite'
+ env['GSFLAGS'] = SCons.Util.CLVar('-dNOPAUSE -dBATCH -sDEVICE=pdfwrite')
env['GSCOM'] = '$GS $GSFLAGS -sOutputFile=$TARGET $SOURCES'
import os.path
import string
+import SCons.Util
+
cplusplus = __import__('c++', globals(), locals(), [])
acc = None
env['CXXVERSION'] = string.split(line)[-1]
if env['PLATFORM'] == 'cygwin':
- env['SHCXXFLAGS'] = '$CXXFLAGS'
+ env['SHCXXFLAGS'] = SCons.Util.CLVar('$CXXFLAGS')
else:
- env['SHCXXFLAGS'] = '$CXXFLAGS +Z'
+ env['SHCXXFLAGS'] = SCons.Util.CLVar('$CXXFLAGS +Z')
def exists(env):
return acc
import os
import os.path
+import SCons.Util
+
import link
ccLinker = None
"""
link.generate(env)
- env['LINKFLAGS'] = '-Wl,+s -Wl,+vnocompatwarnings'
- env['SHLINKFLAGS'] = '$LINKFLAGS -b'
+ env['LINKFLAGS'] = SCons.Util.CLVar('-Wl,+s -Wl,+vnocompatwarnings')
+ env['SHLINKFLAGS'] = SCons.Util.CLVar('$LINKFLAGS -b')
env['SHLIBSUFFIX'] = '.sl'
def exists(env):
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
+import SCons.Util
+
import cc
def generate(env):
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
+import SCons.Util
+
import f77
def generate(env):
f77.generate(env)
env['F77'] = 'ifl'
- env['F77FLAGS'] = ''
+ env['F77FLAGS'] = SCons.Util.CLVar('')
env['F77COM'] = '$F77 $F77FLAGS $_F77INCFLAGS /c $SOURCES /Fo$TARGET'
env['F77PPCOM'] = '$F77 $F77FLAGS $CPPFLAGS $_CPPDEFFLAGS $_F77INCFLAGS /c $SOURCES /Fo$TARGET'
env['SHF77'] = '$F77'
- env['SHF77FLAGS'] = '$F77FLAGS'
+ env['SHF77FLAGS'] = SCons.Util.CLVar('$F77FLAGS')
env['SHF77COM'] = '$SHF77 $SHF77FLAGS $_F77INCFLAGS /c $SOURCES /Fo$TARGET'
env['SHF77PPCOM'] = '$SHF77 $SHF77FLAGS $CPPFLAGS $_CPPDEFFLAGS $_F77INCFLAGS /c $SOURCES /Fo$TARGET'
import SCons.Defaults
import SCons.Tool
+import SCons.Util
def generate(env):
"""Add Builders and construction variables for ilink to an Environment."""
SCons.Tool.createProgBuilder(env)
env['LINK'] = 'ilink'
- env['LINKFLAGS'] = ''
+ env['LINKFLAGS'] = SCons.Util.CLVar('')
env['LINKCOM'] = '$LINK $LINKFLAGS /O:$TARGET $SOURCES $( $_LIBDIRFLAGS $) $_LIBFLAGS'
env['LIBDIRPREFIX']='/LIBPATH:'
env['LIBDIRSUFFIX']=''
import SCons.Tool
import SCons.Tool.bcc32
+import SCons.Util
def generate(env):
"""Add Builders and construction variables for ilink to an
SCons.Tool.createProgBuilder(env)
env['LINK'] = '$CC'
- env['LINKFLAGS'] = ''
+ env['LINKFLAGS'] = SCons.Util.CLVar('')
env['LINKCOM'] = '$LINK -q $LINKFLAGS $SOURCES $LIBS'
env['LIBDIRPREFIX']=''
env['LIBDIRSUFFIX']=''
import os.path
import SCons.Builder
+import SCons.Util
def jarSources(target, source, env, for_signature):
"""Only include sources that are not a manifest file."""
def jarFlags(target, source, env, for_signature):
"""If we have a manifest, make sure that the 'm'
flag is specified."""
+ jarflags = env.subst('$JARFLAGS')
for src in source:
contents = src.get_contents()
if contents[:16] == "Manifest-Version":
- if not 'm' in env['JARFLAGS']:
- return env['JARFLAGS'] + 'm'
+ if not 'm' in jarflags:
+ return jarflags + 'm'
break
- return env['JARFLAGS']
+ return jarflags
def jarChdir(target, source, env, for_signature):
"""If we have an Environment variable by the name
env['BUILDERS']['Jar'] = JarBuilder
env['JAR'] = 'jar'
- env['JARFLAGS'] = 'cf'
+ env['JARFLAGS'] = SCons.Util.CLVar('cf')
env['_JARFLAGS'] = jarFlags
env['_JARMANIFEST'] = jarManifest
env['_JARSOURCES'] = jarSources
import SCons.Builder
from SCons.Node.FS import _my_normcase
from SCons.Tool.JavaCommon import parse_java_file
+import SCons.Util
def classname(path):
"""Turn a string (path name) into a Java class name."""
env['BUILDERS']['Java'] = JavaBuilder
env['JAVAC'] = 'javac'
- env['JAVACFLAGS'] = ''
+ env['JAVACFLAGS'] = SCons.Util.CLVar('')
env['JAVACCOM'] = '$JAVAC $JAVACFLAGS -d ${TARGET.attributes.java_classdir} -sourcepath ${SOURCE.dir.rdir()} $SOURCES'
env['JAVACLASSSUFFIX'] = '.class'
env['JAVASUFFIX'] = '.java'
import SCons.Builder
import SCons.Node.FS
import SCons.Tool.javac
+import SCons.Util
def emit_java_headers(target, source, env):
"""Create and return lists of Java stub header files that will
env['_JAVAHOUTFLAG'] = JavaHOutFlagGenerator
env['JAVAH'] = 'javah'
- env['JAVAHFLAGS'] = ''
+ env['JAVAHFLAGS'] = SCons.Util.CLVar('')
env['JAVAHCOM'] = '$JAVAH $JAVAHFLAGS $_JAVAHOUTFLAG -classpath ${SOURCE.attributes.java_classdir} ${SOURCES.attributes.java_classname}'
env['JAVACLASSSUFFIX'] = '.class'
import SCons.Action
import SCons.Defaults
+import SCons.Util
LaTeXAction = SCons.Action.Action('$LATEXCOM')
bld.add_action('.latex', LaTeXAction)
env['LATEX'] = 'latex'
- env['LATEXFLAGS'] = ''
+ env['LATEXFLAGS'] = SCons.Util.CLVar('')
env['LATEXCOM'] = '$LATEX $LATEXFLAGS $SOURCES'
def exists(env):
import SCons.Defaults
import SCons.Tool
+import SCons.Util
def generate(env):
"""Add Builders and construction variables for lex to an Environment."""
cxx_file.add_action('.ll', '$LEXCOM')
env['LEX'] = env.Detect('flex') or 'lex'
- env['LEXFLAGS'] = ''
+ env['LEXFLAGS'] = SCons.Util.CLVar('')
env['LEXCOM'] = '$LEX $LEXFLAGS -t $SOURCES > $TARGET'
def exists(env):
SCons.Tool.createProgBuilder(env)
env['SHLINK'] = '$LINK'
- env['SHLINKFLAGS'] = '$LINKFLAGS -shared'
+ env['SHLINKFLAGS'] = SCons.Util.CLVar('$LINKFLAGS -shared')
env['SHLINKCOM'] = '$SHLINK $SHLINKFLAGS -o $TARGET $SOURCES $_LIBDIRFLAGS $_LIBFLAGS'
env['SHLIBEMITTER']= None
env['SMARTLINK'] = smart_link
env['LINK'] = "$SMARTLINK"
- env['LINKFLAGS'] = ''
+ env['LINKFLAGS'] = SCons.Util.CLVar('')
env['LINKCOM'] = '$LINK $LINKFLAGS -o $TARGET $SOURCES $_LIBDIRFLAGS $_LIBFLAGS'
env['LIBDIRPREFIX']='-L'
env['LIBDIRSUFFIX']=''
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
import os.path
-import string
import re
import SCons.Action
env['SUBST_CMD_FILE'] = LinklocGenerator
env['SHLINK'] = '$LINK'
- env['SHLINKFLAGS'] = '$LINKFLAGS'
+ env['SHLINKFLAGS'] = SCons.Util.CLVar('$LINKFLAGS')
env['SHLINKCOM'] = '${SUBST_CMD_FILE("$SHLINK $SHLINKFLAGS $( $_LIBDIRFLAGS $) $_LIBFLAGS -dll $TARGET $SOURCES")}'
env['SHLIBEMITTER']= None
env['LINK'] = "linkloc"
- env['LINKFLAGS'] = ''
+ env['LINKFLAGS'] = SCons.Util.CLVar('')
env['LINKCOM'] = '${SUBST_CMD_FILE("$LINK $LINKFLAGS $( $_LIBDIRFLAGS $) $_LIBFLAGS -exe $TARGET $SOURCES")}'
env['LIBDIRPREFIX']='-libpath '
env['LIBDIRSUFFIX']=''
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
import SCons.Builder
+import SCons.Util
def generate(env):
"""Add Builders and construction variables for m4 to an Environment."""
# The src_suffix setup is like so: file.c.m4 -> file.c,
# file.cpp.m4 -> file.cpp etc.
env['M4'] = 'm4'
- env['M4FLAGS'] = '-E'
+ env['M4FLAGS'] = SCons.Util.CLVar('-E')
env['M4COM'] = 'cd ${SOURCE.rsrcdir} && $M4 $M4FLAGS < ${SOURCE.file} > ${TARGET.abspath}'
def exists(env):
import SCons.Defaults
import SCons.Tool
+import SCons.Util
ASSuffixes = ['.s', '.asm', '.ASM']
ASPPSuffixes = ['.spp', '.SPP']
shared_obj.add_action(suffix, SCons.Defaults.ASPPAction)
env['AS'] = 'ml'
- env['ASFLAGS'] = '/nologo'
+ env['ASFLAGS'] = SCons.Util.CLVar('/nologo')
env['ASCOM'] = '$AS $ASFLAGS /c /Fo$TARGET $SOURCES'
env['ASPPCOM'] = '$CC $ASFLAGS $CPPFLAGS $_CPPDEFFLAGS $_CPPINCFLAGS /c /Fo$TARGET $SOURCES'
env['STATIC_AND_SHARED_OBJECTS_ARE_THE_SAME'] = 1
"""Add Builders and construction variables for midl to an Environment."""
env['MIDL'] = 'MIDL.EXE'
- env['MIDLFLAGS'] = '/nologo'
- env['MIDLCOM'] = "$MIDL $MIDLFLAGS /tlb ${TARGETS[0]} /h ${TARGETS[1]} /iid ${TARGETS[2]} /proxy ${TARGETS[3]} /dlldata ${TARGETS[4]} $SOURCE 2> NUL"
+ env['MIDLFLAGS'] = SCons.Util.CLVar('/nologo')
+ env['MIDLCOM'] = '$MIDL $MIDLFLAGS /tlb ${TARGETS[0]} /h ${TARGETS[1]} /iid ${TARGETS[2]} /proxy ${TARGETS[3]} /dlldata ${TARGETS[4]} $SOURCE 2> NUL'
env['BUILDERS']['TypeLibrary'] = midl_builder
def exists(env):
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
-import os.path
import os
+import os.path
+import string
+
import SCons.Tool
import SCons.Util
-import string
# This is what we search for to find mingw:
key_program = 'mingw32-gcc'
return env.WhereIs(key_program) or SCons.Util.WhereIs(key_program)
def shlib_generator(target, source, env, for_signature):
- cmd = ['$SHLINK', '$SHLINKFLAGS']
+ cmd = SCons.Util.CLVar('$SHLINK', '$SHLINKFLAGS')
dll = env.FindIxes(target, 'SHLIBPREFIX', 'SHLIBSUFFIX')
if dll: cmd.extend(['-o', dll])
#... but a few things differ:
env['CC'] = 'gcc'
- env['SHCCFLAGS'] = '$CCFLAGS'
+ env['SHCCFLAGS'] = SCons.Util.CLVar('$CCFLAGS')
env['CXX'] = 'g++'
- env['SHCXXFLAGS'] = '$CXXFLAGS'
- env['SHLINKFLAGS'] = '$LINKFLAGS -shared'
+ env['SHCXXFLAGS'] = SCons.Util.CLVar('$CXXFLAGS')
+ env['SHLINKFLAGS'] = SCons.Util.CLVar('$LINKFLAGS -shared')
env['SHLINKCOM'] = shlib_action
env['SHLIBEMITTER']= shlib_emitter
env['LINK'] = 'g++'
env['STATIC_AND_SHARED_OBJECTS_ARE_THE_SAME'] = 1
env['RC'] = 'windres'
- env['RCFLAGS'] = ''
- env['RCINCFLAGS'] = '$( ${_concat(RCINCPREFIX, CPPPATH, RCINCSUFFIX, __env__, RDirs)} $)'
+ env['RCFLAGS'] = SCons.Util.CLVar('')
+ env['RCINCFLAGS'] = SCons.Util.CLVar('$( ${_concat(RCINCPREFIX, CPPPATH, RCINCSUFFIX, __env__, RDirs)} $)')
env['RCINCPREFIX'] = '--include-dir '
env['RCINCSUFFIX'] = ''
env['RCCOM'] = '$RC $RCINCFLAGS $RCFLAGS -i $SOURCE -o $TARGET'
import SCons.Tool
import SCons.Tool.msvs
import SCons.Tool.msvc
+import SCons.Util
def generate(env):
"""Add Builders and construction variables for lib to an Environment."""
pass
env['AR'] = 'lib'
- env['ARFLAGS'] = '/nologo'
+ env['ARFLAGS'] = SCons.Util.CLVar('/nologo')
env['ARCOM'] = "${TEMPFILE('$AR $ARFLAGS /OUT:$TARGET $SOURCES')}"
def exists(env):
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
import os.path
-import string
import SCons.Action
import SCons.Defaults
import SCons.Errors
-import SCons.Util
+import SCons.Platform.win32
import SCons.Tool
-import SCons.Tool.msvs
import SCons.Tool.msvc
-import SCons.Platform.win32
+import SCons.Tool.msvs
+import SCons.Util
def pdbGenerator(env, target, source, for_signature):
if target and env.has_key('PDB') and env['PDB']:
SCons.Tool.createProgBuilder(env)
env['SHLINK'] = '$LINK'
- env['SHLINKFLAGS'] = '$LINKFLAGS /dll'
+ env['SHLINKFLAGS'] = SCons.Util.CLVar('$LINKFLAGS /dll')
env['_SHLINK_TARGETS'] = win32ShlinkTargets
env['_SHLINK_SOURCES'] = win32ShlinkSources
env['SHLINKCOM'] = compositeLinkAction
env['SHLIBEMITTER']= win32LibEmitter
env['LINK'] = 'link'
- env['LINKFLAGS'] = '/nologo'
+ env['LINKFLAGS'] = SCons.Util.CLVar('/nologo')
env['_PDB'] = pdbGenerator
env['LINKCOM'] = '${TEMPFILE("$LINK $LINKFLAGS /OUT:$TARGET $( $_LIBDIRFLAGS $) $_LIBFLAGS $_PDB $SOURCES")}'
env['PROGEMITTER'] = prog_emitter
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
import os.path
+import re
import string
import types
-import re
import SCons.Action
-import SCons.Tool
-import SCons.Errors
-import SCons.Warnings
import SCons.Builder
-import SCons.Util
+import SCons.Errors
import SCons.Platform.win32
+import SCons.Tool
import SCons.Tool.msvs
+import SCons.Util
+import SCons.Warnings
CSuffixes = ['.c', '.C']
CXXSuffixes = ['.cc', '.cpp', '.cxx', '.c++', '.C++']
static_obj.add_action(suffix, SCons.Defaults.CXXAction)
shared_obj.add_action(suffix, SCons.Defaults.ShCXXAction)
- env['CCPDBFLAGS'] = '${(PDB and "/Zi /Fd%s"%File(PDB)) or ""}'
- env['CCPCHFLAGS'] = '${(PCH and "/Yu%s /Fp%s"%(PCHSTOP or "",File(PCH))) or ""}'
+ env['CCPDBFLAGS'] = SCons.Util.CLVar(['${(PDB and "/Zi /Fd%s"%File(PDB)) or ""}'])
+ env['CCPCHFLAGS'] = SCons.Util.CLVar(['${(PCH and "/Yu%s /Fp%s"%(PCHSTOP or "",File(PCH))) or ""}'])
env['CCCOMFLAGS'] = '$CPPFLAGS $_CPPDEFFLAGS $_CPPINCFLAGS /c $SOURCES /Fo$TARGET $CCPCHFLAGS $CCPDBFLAGS'
env['CC'] = 'cl'
- env['CCFLAGS'] = '/nologo'
- env['CCCOM'] = '$CC $CCFLAGS $CCCOMFLAGS'
+ env['CCFLAGS'] = SCons.Util.CLVar('/nologo')
+ env['CCCOM'] = '$CC $CCFLAGS $CCCOMFLAGS'
env['SHCC'] = '$CC'
- env['SHCCFLAGS'] = '$CCFLAGS'
+ env['SHCCFLAGS'] = SCons.Util.CLVar('$CCFLAGS')
env['SHCCCOM'] = '$SHCC $SHCCFLAGS $CCCOMFLAGS'
env['CXX'] = '$CC'
- env['CXXFLAGS'] = ['$CCFLAGS', '$(', '/TP', '$)']
+ env['CXXFLAGS'] = SCons.Util.CLVar('$CCFLAGS $( /TP $)')
env['CXXCOM'] = '$CXX $CXXFLAGS $CCCOMFLAGS'
env['SHCXX'] = '$CXX'
- env['SHCXXFLAGS'] = '$CXXFLAGS'
+ env['SHCXXFLAGS'] = SCons.Util.CLVar('$CXXFLAGS')
env['SHCXXCOM'] = '$SHCXX $SHCXXFLAGS $CCCOMFLAGS'
env['CPPDEFPREFIX'] = '/D'
env['CPPDEFSUFFIX'] = ''
env['STATIC_AND_SHARED_OBJECTS_ARE_THE_SAME'] = 1
env['RC'] = 'rc'
- env['RCFLAGS'] = ''
+ env['RCFLAGS'] = SCons.Util.CLVar('')
env['RCCOM'] = '$RC $_CPPDEFFLAGS $_CPPINCFLAGS $RCFLAGS /fo$TARGET $SOURCES'
CScan = env.get_scanner('.c')
if CScan:
import SCons.Defaults
import SCons.Tool
+import SCons.Util
ASSuffixes = ['.s', '.asm', '.ASM']
ASPPSuffixes = ['.spp', '.SPP']
static_obj.add_action(suffix, SCons.Defaults.ASPPAction)
env['AS'] = 'nasm'
- env['ASFLAGS'] = ''
+ env['ASFLAGS'] = SCons.Util.CLVar('')
env['ASCOM'] = '$AS $ASFLAGS -o $TARGET $SOURCES'
env['ASPPCOM'] = '$CC $ASFLAGS $CPPFLAGS $_CPPDEFFLAGS $_CPPINCFLAGS -c -o $TARGET $SOURCES'
import SCons.Action
import SCons.Defaults
+import SCons.Util
PDFLaTeXAction = SCons.Action.Action('$PDFLATEXCOM')
bld.add_action('.latex', PDFLaTeXAction)
env['PDFLATEX'] = 'pdflatex'
- env['PDFLATEXFLAGS'] = ''
+ env['PDFLATEXFLAGS'] = SCons.Util.CLVar('')
env['PDFLATEXCOM'] = '$PDFLATEX $PDFLATEXFLAGS $SOURCES $TARGET'
def exists(env):
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
import SCons.Defaults
+import SCons.Util
def generate(env):
"""Add Builders and construction variables for pdftex to an Environment."""
bld.add_action('.tex', '$PDFTEXCOM')
env['PDFTEX'] = 'pdftex'
- env['PDFTEXFLAGS'] = ''
+ env['PDFTEXFLAGS'] = SCons.Util.CLVar('')
env['PDFTEXCOM'] = '$PDFTEX $PDFTEXFLAGS $SOURCES $TARGET'
def exists(env):
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
-import sys
import os.path
import re
+import sys
import SCons.Defaults
import SCons.Tool
# Some QT specific flags. I don't expect someone wants to
# manipulate those ...
- env['QT_UICIMPLFLAGS'] = ''
- env['QT_UICDECLFLAGS'] = ''
- env['QT_MOCFROMHFLAGS'] = ''
- env['QT_MOCFROMCXXFLAGS'] = '-i'
+ env['QT_UICIMPLFLAGS'] = SCons.Util.CLVar('')
+ env['QT_UICDECLFLAGS'] = SCons.Util.CLVar('')
+ env['QT_MOCFROMHFLAGS'] = SCons.Util.CLVar('')
+ env['QT_MOCFROMCXXFLAGS'] = SCons.Util.CLVar('-i')
# Suffixes for the headers / sources to generate
env['QT_HSUFFIX'] = '.h'
import SCons.Builder
import SCons.Node.FS
+import SCons.Util
def emit_rmic_classes(target, source, env):
"""Create and return lists of Java RMI stub and skeleton
env['BUILDERS']['RMIC'] = RMICBuilder
env['RMIC'] = 'rmic'
- env['RMICFLAGS'] = ''
+ env['RMICFLAGS'] = SCons.Util.CLVar('')
env['RMICCOM'] = '$RMIC $RMICFLAGS -d ${TARGET.attributes.java_lookupdir} -classpath ${SOURCE.attributes.java_classdir} ${SOURCES.attributes.java_classname}'
env['JAVACLASSSUFFIX'] = '.class'
import SCons.Defaults
import SCons.Tool
+import SCons.Util
def generate(env):
"""Add Builders and construction variables for ar to an Environment."""
if env.Detect('CC'):
env['AR'] = 'CC'
- env['ARFLAGS'] = '-ar'
+ env['ARFLAGS'] = SCons.Util.CLVar('-ar')
env['ARCOM'] = '$AR $ARFLAGS -o $TARGET $SOURCES'
else:
env['AR'] = 'ar'
- env['ARFLAGS'] = 'r'
+ env['ARFLAGS'] = SCons.Util.CLVar('r')
env['ARCOM'] = '$AR $ARFLAGS $TARGET $SOURCES'
env['SHLINK'] = '$LINK'
- env['SHLINKFLAGS'] = '$LINKFLAGS -shared'
+ env['SHLINKFLAGS'] = SCons.Util.CLVar('$LINKFLAGS -shared')
env['SHLINKCOM'] = '$SHLINK $SHLINKFLAGS -o $TARGET $SOURCES $_LIBDIRFLAGS $_LIBFLAGS'
def exists(env):
selection method.
"""
-__revision__ = ""
+
+#
+# __COPYRIGHT__
+#
+# 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 os.path
-import string
+
+import SCons.Util
cplusplus = __import__('c++', globals(), locals(), [])
cplusplus.generate(env)
env['CXX'] = 'CC'
- env['CXXFLAGS'] = ['$CCFLAGS', '-LANG:std']
+ env['CXXFLAGS'] = SCons.Util.CLVar('$CCFLAGS -LANG:std')
env['SHCXX'] = 'CC'
env['SHOBJSUFFIX'] = '.o'
env['STATIC_AND_SHARED_OBJECTS_ARE_THE_SAME'] = 1
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
+import SCons.Util
+
import link
linkers = ['CC', 'cc']
link.generate(env)
env['LINK'] = env.Detect(linkers) or 'cc'
- env['SHLINKFLAGS'] = '$LINKFLAGS -shared'
+ env['SHLINKFLAGS'] = SCons.Util.CLVar('$LINKFLAGS -shared')
def exists(env):
return env.Detect(linkers)
import SCons.Defaults
import SCons.Tool
+import SCons.Util
def generate(env):
"""Add Builders and construction variables for ar to an Environment."""
if env.Detect('CC'):
env['AR'] = 'CC'
- env['ARFLAGS'] = '-xar'
+ env['ARFLAGS'] = SCons.Util.CLVar('-xar')
env['ARCOM'] = '$AR $ARFLAGS -o $TARGET $SOURCES'
else:
env['AR'] = 'ar'
- env['ARFLAGS'] = 'r'
+ env['ARFLAGS'] = SCons.Util.CLVar('r')
env['ARCOM'] = '$AR $ARFLAGS $TARGET $SOURCES'
env['SHLINK'] = '$LINK'
- env['SHLINKFLAGS'] = '$LINKFLAGS -G'
+ env['SHLINKFLAGS'] = SCons.Util.CLVar('$LINKFLAGS -G')
env['SHLINKCOM'] = '$SHLINK $SHLINKFLAGS -o $TARGET $SOURCES $_LIBDIRFLAGS $_LIBFLAGS'
def exists(env):
import os
import os.path
+import SCons.Util
+
import link
ccLinker = None
"""Add Builders and construction variables for Forte to an Environment."""
link.generate(env)
- env['SHLINKFLAGS'] = '$LINKFLAGS -G'
+ env['SHLINKFLAGS'] = SCons.Util.CLVar('$LINKFLAGS -G')
def exists(env):
return ccLinker
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
import os.path
-import string
import SCons.Defaults
import SCons.Tool
+import SCons.Util
def swigSuffixEmitter(env, source):
- if '-c++' in string.split(env.subst("$SWIGFLAGS")):
+ if '-c++' in SCons.Util.CLVar(env.subst("$SWIGFLAGS")):
return '$SWIGCXXFILESUFFIX'
else:
return '$SWIGCFILESUFFIX'
cxx_file.add_action('.i', '$SWIGCOM')
env['SWIG'] = 'swig'
- env['SWIGFLAGS'] = ''
+ env['SWIGFLAGS'] = SCons.Util.CLVar('')
env['SWIGCFILESUFFIX'] = '_wrap$CFILESUFFIX'
env['SWIGCXXFILESUFFIX'] = '_wrap$CXXFILESUFFIX'
env['SWIGCOM'] = '$SWIG $SWIGFLAGS -o $TARGET $SOURCES'
env['BUILDERS']['Tar'] = bld
env['TAR'] = env.Detect(tars) or 'gtar'
- env['TARFLAGS'] = '-c'
+ env['TARFLAGS'] = SCons.Util.CLVar('-c')
env['TARCOM'] = '$TAR $TARFLAGS -f $TARGET $SOURCES'
env['TARSUFFIX'] = '.tar'
bld.add_action('.tex', TeXLaTeXAction)
env['TEX'] = 'tex'
- env['TEXFLAGS'] = ''
+ env['TEXFLAGS'] = SCons.Util.CLVar('')
env['TEXCOM'] = '$TEX $TEXFLAGS $SOURCES'
# Duplicate from latex.py. If latex.py goes away, then this is still OK.
env['LATEX'] = 'latex'
- env['LATEXFLAGS'] = ''
+ env['LATEXFLAGS'] = SCons.Util.CLVar('')
env['LATEXCOM'] = '$LATEX $LATEXFLAGS $SOURCES'
env['BIBTEX'] = 'bibtex'
- env['BIBTEXFLAGS'] = ''
+ env['BIBTEXFLAGS'] = SCons.Util.CLVar('')
env['BIBTEXCOM'] = '$BIBTEX $BIBTEXFLAGS $SOURCES'
import SCons.Tool
import SCons.Tool.bcc32
+import SCons.Util
def generate(env):
SCons.Tool.bcc32.findIt('tlib', env)
"""Add Builders and construction variables for ar to an Environment."""
SCons.Tool.createStaticLibBuilder(env)
env['AR'] = 'tlib'
- env['ARFLAGS'] = ''
+ env['ARFLAGS'] = SCons.Util.CLVar('')
env['ARCOM'] = '$AR $TARGET $ARFLAGS /a $SOURCES'
def exists(env):
__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
import os.path
-import string
import SCons.Tool
import SCons.Util
# If -d is specified on the command line, yacc will emit a .h
# or .hpp file as well as a .c or .cpp file, depending on whether
# the input file is a .y or .yy, respectively.
- if len(source) and '-d' in string.split(env.subst("$YACCFLAGS")):
+ if len(source) and '-d' in SCons.Util.CLVar(env.subst("$YACCFLAGS")):
base, ext = os.path.splitext(SCons.Util.to_String(source[0]))
if ext == ysuf:
base, ext = os.path.splitext(SCons.Util.to_String(target[0]))
cxx_file.add_emitter('.yy', yyEmitter)
env['YACC'] = env.Detect('bison') or 'yacc'
- env['YACCFLAGS'] = ''
+ env['YACCFLAGS'] = SCons.Util.CLVar('')
env['YACCCOM'] = '$YACC $YACCFLAGS -o $TARGET $SOURCES'
def exists(env):
env['BUILDERS']['Zip'] = bld
env['ZIP'] = 'zip'
- env['ZIPFLAGS'] = ''
+ env['ZIPFLAGS'] = SCons.Util.CLVar('')
env['ZIPCOM'] = zipAction
env['ZIPCOMPRESSION'] = zipcompression
env['ZIPSUFFIX'] = '.zip'
display = DisplayEngine()
+def Split(arg):
+ if is_List(arg):
+ return arg
+ elif is_String(arg):
+ return string.split(arg)
+ else:
+ return [arg]
+
+class CLVar(UserList.UserList):
+ """A class for command-line construction variables.
+
+ This is a list that uses Split() to split an initial string along
+ white-space arguments, and similarly to split any strings that get
+ added. This allows us to Do the Right Thing with Append() and
+ Prepend() (as well as straight Python foo = env['VAR'] + 'arg1
+ arg2') regardless of whether a user adds a list or a string to a
+ command-line construction variable.
+ """
+ def __init__(self, seq = []):
+ UserList.UserList.__init__(self, Split(seq))
+ def __coerce__(self, other):
+ if is_String(other):
+ other = Split(other)
+ return (self, other)
+ def __str__(self):
+ return string.join(self.data)
+
class Selector(UserDict.UserDict):
"""A callable dictionary that maps file suffixes to dictionary
values."""
assert nl[0:2].child.bar == [ 't1child', 't2child' ], \
nl[0:2].child.bar
+ def test_CLVar(self):
+ """Test the command-line construction variable class"""
+ f = SCons.Util.CLVar('a b')
+
+ r = f + 'c d'
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a', 'b', 'c', 'd'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + ' c d'
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a', 'b', 'c', 'd'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + ['c d']
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a', 'b', 'c d'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + [' c d']
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a', 'b', ' c d'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + ['c', 'd']
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a', 'b', 'c', 'd'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + [' c', 'd']
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a', 'b', ' c', 'd'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ f = SCons.Util.CLVar(['a b'])
+
+ r = f + 'c d'
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a b', 'c', 'd'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + ' c d'
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a b', 'c', 'd'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + ['c d']
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a b', 'c d'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + [' c d']
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a b', ' c d'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + ['c', 'd']
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a b', 'c', 'd'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + [' c', 'd']
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a b', ' c', 'd'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ f = SCons.Util.CLVar(['a', 'b'])
+
+ r = f + 'c d'
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a', 'b', 'c', 'd'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + ' c d'
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a', 'b', 'c', 'd'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + ['c d']
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a', 'b', 'c d'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + [' c d']
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a', 'b', ' c d'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + ['c', 'd']
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a', 'b', 'c', 'd'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ r = f + [' c', 'd']
+ assert isinstance(r, SCons.Util.CLVar), type(r)
+ assert r.data == ['a', 'b', ' c', 'd'], r.data
+ assert str(r) == 'a b c d', str(r)
+
+ loc = {}
+ loc['FOO'] = 'foo'
+ loc['BAR'] = SCons.Util.CLVar('bar')
+ loc['CALL'] = lambda target, source, env, for_signature: 'call'
+ env = DummyEnv(loc)
+
+ cmd = SCons.Util.CLVar("test $FOO $BAR $CALL test")
+
+ newcmd = scons_subst(cmd, env)
+ assert newcmd == 'test foo bar call test', newcmd
+
+ cmd_list = scons_subst_list(cmd, env)
+ assert len(cmd_list) == 1, cmd_list
+ assert cmd_list[0][0] == "test", cmd_list[0][0]
+ assert cmd_list[0][1] == "foo", cmd_list[0][1]
+ assert cmd_list[0][2] == "bar", cmd_list[0][2]
+ assert cmd_list[0][3] == "call", cmd_list[0][3]
+ assert cmd_list[0][4] == "test", cmd_list[0][4]
+
def test_Selector(self):
"""Test the Selector class"""
test.write('SConstruct', """
foo = Environment(LIBS = ['foo'], LIBPATH = ['.'])
-ar = foo.Dictionary('AR')
-arflags = foo.Dictionary('ARFLAGS')
bar = Environment(LIBS = ['bar'], LIBPATH = ['.'],
- AR = '', ARFLAGS = r'%s wrapper.py ' + ar + ' ' + arflags)
+ AR = '', ARFLAGS = foo.subst(r'%s wrapper.py $AR $ARFLAGS'))
foo.Library(target = 'foo', source = 'foo.c')
bar.Library(target = 'bar', source = 'bar.c')
f.close()
env = Environment(ENV = { 'PATH' : os.environ['PATH'] },
BUILDERS={'Cat':Builder(action=cat)})
-env.Prepend(CVSFLAGS='-Q ')
+env.Prepend(CVSFLAGS='-Q')
env.Cat('aaa.out', 'foo/aaa.in')
env.Cat('bbb.out', 'foo/bbb.in')
env.Cat('ccc.out', 'foo/ccc.in')
f.close()
env = Environment(ENV = { 'PATH' : os.environ['PATH'] },
BUILDERS={'Cat':Builder(action=cat)})
-env.Prepend(CVSFLAGS='-q ')
+env.Prepend(CVSFLAGS='-q')
env.Cat('aaa.out', 'aaa.in')
env.Cat('bbb.out', 'bbb.in')
env.Cat('ccc.out', 'ccc.in')
import os
ENV = { 'PATH' : os.environ['PATH'] }
foo = Environment(ENV = ENV)
-foo.Append(GSFLAGS = ' -q')
+foo.Append(GSFLAGS = '-q')
foo.PDF(target = 'foo.pdf', source = 'foo.ps')
""")
test = TestSCons.TestSCons()
test.write('SConstruct', """
+import string
env = Environment()
print env['CC']
-print env['CCFLAGS']
+print string.join(env['CCFLAGS'])
Default(env.Alias('dummy', None))
""")
test.run()
cc, ccflags = string.split(test.stdout(), '\n')[1:3]
test.write('SConstruct', """
+import string
+
# test validator. Change a key and add a new one to the environment
def validator(key, value, environ):
environ[key] = "v"
def test_tool(env):
if env['RELEASE_BUILD']:
- env['CCFLAGS'] = env['CCFLAGS'] + ' -O'
+ env.Append(CCFLAGS = '-O')
if env['DEBUG_BUILD']:
- env['CCFLAGS'] = env['CCFLAGS'] + ' -g'
+ env.Append(CCFLAGS = '-g')
env = Environment(options=opts, tools=['default', test_tool])
print env['RELEASE_BUILD']
print env['DEBUG_BUILD']
print env['CC']
-print env['CCFLAGS']
+print string.join(env['CCFLAGS'])
print env['VALIDATE']
print env['valid_key']
assert result[1:len(expect)+1] == expect, (result[1:len(expect)+1], expect)
test.run()
-check(['0', '1', cc, ccflags + ' -g', 'v', 'v'])
+check(['0', '1', cc, string.strip(ccflags + ' -g'), 'v', 'v'])
test.run(arguments='"RELEASE_BUILD=1"')
-check(['1', '1', cc, ccflags + ' -O -g', 'v', 'v'])
+check(['1', '1', cc, string.strip(ccflags + ' -O -g'), 'v', 'v'])
test.run(arguments='"RELEASE_BUILD=1" "DEBUG_BUILD=0"')
-check(['1', '0', cc, ccflags + ' -O', 'v', 'v'])
+check(['1', '0', cc, string.strip(ccflags + ' -O'), 'v', 'v'])
test.run(arguments='"CC=not_a_c_compiler"')
-check(['0', '1', 'not_a_c_compiler', ccflags + ' -g', 'v', 'v'])
+check(['0', '1', 'not_a_c_compiler', string.strip(ccflags + ' -g'), 'v', 'v'])
test.run(arguments='"UNDECLARED=foo"')
-check(['0', '1', cc, ccflags + ' -g', 'v', 'v'])
+check(['0', '1', cc, string.strip(ccflags + ' -g'), 'v', 'v'])
test.run(arguments='"CCFLAGS=--taco"')
-check(['0', '1', cc, ccflags + ' -g', 'v', 'v'])
+check(['0', '1', cc, string.strip(ccflags + ' -g'), 'v', 'v'])
test.write('custom.py', """
DEBUG_BUILD=0
""")
test.run()
-check(['1', '0', cc, ccflags + ' -O', 'v', 'v'])
+check(['1', '0', cc, string.strip(ccflags + ' -O'), 'v', 'v'])
test.run(arguments='"DEBUG_BUILD=1"')
-check(['1', '1', cc, ccflags + ' -O -g', 'v', 'v'])
+check(['1', '1', cc, string.strip(ccflags + ' -O -g'), 'v', 'v'])
test.run(arguments='-h',
stdout = """scons: Reading SConscript files ...
test.write('SConstruct', """
foo = Environment(LIBS = ['foo'], LIBPATH = ['.'])
-ranlib = foo.Dictionary('RANLIB')
-ranlibflags = foo.Dictionary('RANLIBFLAGS')
bar = Environment(LIBS = ['bar'], LIBPATH = ['.'], RANLIB = '',
- RANLIBFLAGS = r'%s wrapper.py ' + ranlib + ' ' + ranlibflags)
+ RANLIBFLAGS = foo.subst(r'%s wrapper.py $RANLIB $RANLIBFLAGS'))
foo.Library(target = 'foo', source = 'foo.c')
bar.Library(target = 'bar', source = 'bar.c')
test.write('SConstruct', """
foo = Environment()
-shlink = foo.Dictionary('SHLINK')
-shlinkflags = foo.Dictionary('SHLINKFLAGS')
bar = Environment(SHLINK = '',
- SHLINKFLAGS = r'%s wrapper.py ' + shlink + ' ' + shlinkflags)
+ SHLINKFLAGS = foo.subst(r'%s wrapper.py $SHLINK $SHLINKFLAGS'))
foo.SharedLibrary(target = 'foo', source = 'foo.c')
bar.SharedLibrary(target = 'bar', source = 'bar.c')
""" % python)