hammer/SConstruct

99 lines
3.3 KiB
Text
Raw Normal View History

2013-07-11 23:44:28 +02:00
# -*- python -*-
import os
2013-10-28 09:35:44 -04:00
import os.path
2013-10-29 17:35:37 -04:00
import sys
2013-10-29 17:35:37 -04:00
vars = Variables(None, ARGUMENTS)
vars.Add(PathVariable('DESTDIR', "Root directory to install in (useful for packaging scripts)", None, PathVariable.PathIsDirCreate))
vars.Add(PathVariable('prefix', "Where to install in the FHS", "/usr/local", PathVariable.PathAccept))
env = Environment(ENV = {'PATH' : os.environ['PATH']}, variables = vars, tools=['default', 'scanreplace'], toolpath=['tools'])
2013-10-29 17:35:37 -04:00
def calcInstallPath(*elements):
path = os.path.abspath(os.path.join(*map(env.subst, elements)))
if 'DESTDIR' in env:
path = os.path.join(env['DESTDIR'], os.path.relpath(path, start="/"))
return path
rel_prefix = not os.path.isabs(env['prefix'])
env['prefix'] = os.path.abspath(env['prefix'])
if 'DESTDIR' in env:
env['DESTDIR'] = os.path.abspath(env['DESTDIR'])
if rel_prefix:
print >>sys.stderr, "--!!-- You used a relative prefix with a DESTDIR. This is probably not what you"
print >>sys.stderr, "--!!-- you want; files will be installed in"
print >>sys.stderr, "--!!-- %s" % (calcInstallPath("$prefix"),)
env['libpath'] = calcInstallPath("$prefix", "lib")
env['incpath'] = calcInstallPath("$prefix", "include", "hammer")
env['parsersincpath'] = calcInstallPath("$prefix", "include", "hammer", "parsers")
env['backendsincpath'] = calcInstallPath("$prefix", "include", "hammer", "backends")
env['pkgconfigpath'] = calcInstallPath("$prefix", "lib", "pkgconfig")
env.ScanReplace('libhammer.pc.in')
2013-10-29 17:35:37 -04:00
env.MergeFlags("-std=gnu99 -Wall -Wextra -Werror -Wno-unused-parameter -Wno-attributes")
2013-10-18 12:14:18 +02:00
if not env['PLATFORM'] == 'darwin':
env.MergeFlags("-lrt")
env.Append(SHLINKFLAGS = ['-install_name ' + '$TARGET'])
AddOption("--variant",
dest="variant",
nargs=1, type="choice",
choices=["debug", "opt"],
2013-07-10 21:32:05 +02:00
default="opt",
action="store",
help="Build variant (debug or opt)")
2013-09-13 01:14:40 -07:00
AddOption("--coverage",
dest="coverage",
default=False,
action="store_true",
help="Build with coverage instrumentation")
env['BUILDDIR'] = 'build/$VARIANT'
dbg = env.Clone(VARIANT='debug')
dbg.Append(CCFLAGS=['-g'])
opt = env.Clone(VARIANT='opt')
opt.Append(CCFLAGS="-O3")
if GetOption("variant") == 'debug':
env = dbg
else:
env = opt
2013-07-11 23:44:28 +02:00
2013-09-13 01:14:40 -07:00
if GetOption("coverage"):
env.Append(CFLAGS=["-fprofile-arcs", "-ftest-coverage"],
CXXFLAGS=["-fprofile-arcs", "-ftest-coverage"],
LDFLAGS=["-fprofile-arcs", "-ftest-coverage"],
LIBS=['gcov'])
env["CC"] = os.getenv("CC") or env["CC"]
env["CXX"] = os.getenv("CXX") or env["CXX"]
2013-10-18 12:14:18 +02:00
if os.getenv("CC") == "clang" or env['PLATFORM'] == 'darwin':
2013-07-11 23:44:28 +02:00
env.Replace(CC="clang",
CXX="clang++")
2013-09-12 10:39:50 -07:00
env["ENV"].update(x for x in os.environ.items() if x[0].startswith("CCC_"))
2013-09-12 10:39:50 -07:00
#rootpath = env['ROOTPATH'] = os.path.abspath('.')
#env.Append(CPPPATH=os.path.join('#', "hammer"))
Export('env')
env.SConscript(["src/SConscript"], variant_dir='build/$VARIANT/src')
env.SConscript(["examples/SConscript"], variant_dir='build/$VARIANT/examples')
2013-07-10 21:32:05 +02:00
2013-07-11 23:44:28 +02:00
env.Command('test', 'build/$VARIANT/src/test_suite', 'env LD_LIBRARY_PATH=build/$VARIANT/src $SOURCE')
2013-10-29 17:35:37 -04:00
env.Alias("install", "$libpath")
env.Alias("install", "$incpath")
env.Alias("install", "$parsersincpath")
env.Alias("install", "$backendsincpath")
env.Alias("install", "$pkgconfigpath")