prepend builder-temporary construction variables with "_"; reserve lowercase string variables for user
This commit is contained in:
parent
f13664331f
commit
986b8f08cc
@ -8,7 +8,7 @@ module Rscons
|
|||||||
'AR' => 'ar',
|
'AR' => 'ar',
|
||||||
'LIBSUFFIX' => '.a',
|
'LIBSUFFIX' => '.a',
|
||||||
'ARFLAGS' => [],
|
'ARFLAGS' => [],
|
||||||
'ARCOM' => ['$AR', 'rcs', '$ARFLAGS', '$TARGET', '$SOURCES']
|
'ARCOM' => ['$AR', 'rcs', '$ARFLAGS', '$_TARGET', '$_SOURCES']
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -17,8 +17,8 @@ module Rscons
|
|||||||
objects = env.build_sources(sources, [env['OBJSUFFIX'], env['LIBSUFFIX']].flatten, cache, vars)
|
objects = env.build_sources(sources, [env['OBJSUFFIX'], env['LIBSUFFIX']].flatten, cache, vars)
|
||||||
if objects
|
if objects
|
||||||
vars = vars.merge({
|
vars = vars.merge({
|
||||||
'TARGET' => target,
|
'_TARGET' => target,
|
||||||
'SOURCES' => objects,
|
'_SOURCES' => objects,
|
||||||
})
|
})
|
||||||
command = env.build_command(env['ARCOM'], vars)
|
command = env.build_command(env['ARCOM'], vars)
|
||||||
standard_build("AR #{target}", target, command, objects, env, cache)
|
standard_build("AR #{target}", target, command, objects, env, cache)
|
||||||
|
@ -11,8 +11,8 @@ module Rscons
|
|||||||
'ASSUFFIX' => '.S',
|
'ASSUFFIX' => '.S',
|
||||||
'ASPPPATH' => '$CPPPATH',
|
'ASPPPATH' => '$CPPPATH',
|
||||||
'ASPPFLAGS' => '$CPPFLAGS',
|
'ASPPFLAGS' => '$CPPFLAGS',
|
||||||
'ASDEPGEN' => ['-MMD', '-MF', '$DEPFILE'],
|
'ASDEPGEN' => ['-MMD', '-MF', '$_DEPFILE'],
|
||||||
'ASCOM' => ['$AS', '-c', '-o', '$TARGET', '$ASDEPGEN', '-I$[ASPPPATH]', '$ASPPFLAGS', '$ASFLAGS', '$SOURCES'],
|
'ASCOM' => ['$AS', '-c', '-o', '$_TARGET', '$ASDEPGEN', '-I$[ASPPPATH]', '$ASPPFLAGS', '$ASFLAGS', '$_SOURCES'],
|
||||||
|
|
||||||
'CPPFLAGS' => [],
|
'CPPFLAGS' => [],
|
||||||
'CPPPATH' => [],
|
'CPPPATH' => [],
|
||||||
@ -20,14 +20,14 @@ module Rscons
|
|||||||
'CC' => 'gcc',
|
'CC' => 'gcc',
|
||||||
'CFLAGS' => [],
|
'CFLAGS' => [],
|
||||||
'CSUFFIX' => '.c',
|
'CSUFFIX' => '.c',
|
||||||
'CCDEPGEN' => ['-MMD', '-MF', '$DEPFILE'],
|
'CCDEPGEN' => ['-MMD', '-MF', '$_DEPFILE'],
|
||||||
'CCCOM' => ['$CC', '-c', '-o', '$TARGET', '$CCDEPGEN', '-I$[CPPPATH]', '$CPPFLAGS', '$CFLAGS', '$SOURCES'],
|
'CCCOM' => ['$CC', '-c', '-o', '$_TARGET', '$CCDEPGEN', '-I$[CPPPATH]', '$CPPFLAGS', '$CFLAGS', '$_SOURCES'],
|
||||||
|
|
||||||
'CXX' => 'g++',
|
'CXX' => 'g++',
|
||||||
'CXXFLAGS' => [],
|
'CXXFLAGS' => [],
|
||||||
'CXXSUFFIX' => '.cc',
|
'CXXSUFFIX' => '.cc',
|
||||||
'CXXDEPGEN' => ['-MMD', '-MF', '$DEPFILE'],
|
'CXXDEPGEN' => ['-MMD', '-MF', '$_DEPFILE'],
|
||||||
'CXXCOM' =>['$CXX', '-c', '-o', '$TARGET', '$CXXDEPGEN', '-I$[CPPPATH]', '$CPPFLAGS', '$CXXFLAGS', '$SOURCES'],
|
'CXXCOM' =>['$CXX', '-c', '-o', '$_TARGET', '$CXXDEPGEN', '-I$[CPPPATH]', '$CPPFLAGS', '$CXXFLAGS', '$_SOURCES'],
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -40,9 +40,9 @@ module Rscons
|
|||||||
|
|
||||||
def run(target, sources, cache, env, vars = {})
|
def run(target, sources, cache, env, vars = {})
|
||||||
vars = vars.merge({
|
vars = vars.merge({
|
||||||
'TARGET' => target,
|
'_TARGET' => target,
|
||||||
'SOURCES' => sources,
|
'_SOURCES' => sources,
|
||||||
'DEPFILE' => target.set_suffix('.mf'),
|
'_DEPFILE' => target.set_suffix('.mf'),
|
||||||
})
|
})
|
||||||
com_prefix = if sources.first.has_suffix?(env['ASSUFFIX'])
|
com_prefix = if sources.first.has_suffix?(env['ASSUFFIX'])
|
||||||
'AS'
|
'AS'
|
||||||
@ -59,9 +59,9 @@ module Rscons
|
|||||||
FileUtils.rm_f(target)
|
FileUtils.rm_f(target)
|
||||||
return false unless env.execute("#{com_prefix} #{target}", command)
|
return false unless env.execute("#{com_prefix} #{target}", command)
|
||||||
deps = sources
|
deps = sources
|
||||||
if File.exists?(vars['DEPFILE'])
|
if File.exists?(vars['_DEPFILE'])
|
||||||
deps += env.parse_makefile_deps(vars['DEPFILE'], target)
|
deps += env.parse_makefile_deps(vars['_DEPFILE'], target)
|
||||||
FileUtils.rm_f(vars['DEPFILE'])
|
FileUtils.rm_f(vars['_DEPFILE'])
|
||||||
end
|
end
|
||||||
cache.register_build(target, command, deps.uniq)
|
cache.register_build(target, command, deps.uniq)
|
||||||
end
|
end
|
||||||
|
@ -10,7 +10,7 @@ module Rscons
|
|||||||
'LDFLAGS' => [],
|
'LDFLAGS' => [],
|
||||||
'LIBPATH' => [],
|
'LIBPATH' => [],
|
||||||
'LIBS' => [],
|
'LIBS' => [],
|
||||||
'LDCOM' => ['$LD', '-o', '$TARGET', '$LDFLAGS', '$SOURCES', '-L$[LIBPATH]', '-l$[LIBS]']
|
'LDCOM' => ['$LD', '-o', '$_TARGET', '$LDFLAGS', '$_SOURCES', '-L$[LIBPATH]', '-l$[LIBS]']
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -23,8 +23,8 @@ module Rscons
|
|||||||
end.any?
|
end.any?
|
||||||
ld_alt = use_cxx ? env['CXX'] : env['CC']
|
ld_alt = use_cxx ? env['CXX'] : env['CC']
|
||||||
vars = vars.merge({
|
vars = vars.merge({
|
||||||
'TARGET' => target,
|
'_TARGET' => target,
|
||||||
'SOURCES' => objects,
|
'_SOURCES' => objects,
|
||||||
'LD' => env['LD'] || ld_alt,
|
'LD' => env['LD'] || ld_alt,
|
||||||
})
|
})
|
||||||
command = env.build_command(env['LDCOM'], vars)
|
command = env.build_command(env['LDCOM'], vars)
|
||||||
|
@ -11,9 +11,10 @@ module Rscons
|
|||||||
|
|
||||||
# Create an Environment object.
|
# Create an Environment object.
|
||||||
# @param variables [Hash]
|
# @param variables [Hash]
|
||||||
# The variables hash can contain both construction variables, which are
|
# The variables hash can contain construction variables, which are
|
||||||
# uppercase strings (such as "CC" or "LDFLAGS"), and RScons options,
|
# uppercase strings (such as "CC" or "LDFLAGS"), user variables, which
|
||||||
# which are lowercase symbols (such as :echo).
|
# are lowercase strings (such as "sources"), and RScons options, which
|
||||||
|
# are lowercase symbols (such as :echo).
|
||||||
# If a block is given, the Environment object is yielded to the block and
|
# If a block is given, the Environment object is yielded to the block and
|
||||||
# when the block returns, the {#process} method is automatically called.
|
# when the block returns, the {#process} method is automatically called.
|
||||||
def initialize(variables = {})
|
def initialize(variables = {})
|
||||||
|
Loading…
x
Reference in New Issue
Block a user