Add base SConstruct
This commit is contained in:
parent
11815346af
commit
104fe40661
1 changed files with 74 additions and 0 deletions
74
SConstruct
Normal file
74
SConstruct
Normal file
|
@ -0,0 +1,74 @@
|
|||
# SConstruct
|
||||
# vim: set ft=python:
|
||||
#
|
||||
# Toplevel Scons build script for the Charles project.
|
||||
#
|
||||
# Eryn Wells <eryn@erynwells.me>
|
||||
|
||||
|
||||
#
|
||||
# DEFAULT CONFIGURATION VALUES
|
||||
#
|
||||
|
||||
# Enabling debugging does the following things:
|
||||
# 1. Turns on debugging symbols
|
||||
# 2. Turns off all optimization
|
||||
# 3. Sets the DEBUG define
|
||||
DEBUG = True
|
||||
|
||||
# Show build commands ("cc [args] -o [out] [file], etc"). If this is False, show
|
||||
# some nice messages for each step of the build.
|
||||
BUILD_CMDS = False
|
||||
|
||||
# Source directories. New directories should contain a SConscript file and be
|
||||
# added here.
|
||||
source_directories = Split("""
|
||||
#src
|
||||
""")
|
||||
|
||||
#
|
||||
# BUILD STUFF BELOW HERE
|
||||
#
|
||||
|
||||
import os.path
|
||||
|
||||
cflags='-Wall -Wextra -pedantic'
|
||||
common_env = Environment(
|
||||
CC='clang',
|
||||
CXX='clang++',
|
||||
CFLAGS=cflags + ' -std=c99',
|
||||
CXXFLAGS=cflags + ' -std=c++11')
|
||||
|
||||
def get_bool_argument(arg):
|
||||
if bool(int(arg)):
|
||||
return True
|
||||
if arg == ('True', 'TRUE', 'true'):
|
||||
return True
|
||||
return False
|
||||
|
||||
BUILD_CMDS = get_bool_argument(ARGUMENTS.get('BUILD_CMDS', BUILD_CMDS))
|
||||
if not BUILD_CMDS:
|
||||
def generate_comstr(action):
|
||||
return '%18s: $TARGET' % (action,)
|
||||
common_env['ASCOMSTR'] = generate_comstr('Assembling'),
|
||||
common_env['CCCOMSTR'] = generate_comstr('Building (C)'),
|
||||
common_env['CXXCOMSTR'] = generate_comstr('Building (C++)'),
|
||||
common_env['LINKCOMSTR'] = generate_comstr('Linking'),
|
||||
common_env['ARCOMSTR'] = generate_comstr('Archiving'),
|
||||
common_env['RANLIBCOMSTR'] = generate_comstr('Indexing')
|
||||
|
||||
debug_env = common_env.Clone()
|
||||
debug_env.VariantDir(os.path.join('build', 'debug'), 'src', duplicate=0)
|
||||
debug_env.Append(CPPDEFINES=['DEBUG'])
|
||||
debug_cflags = ' -O0 -g'
|
||||
debug_env.Append(CFLAGS=debug_cflags, CXXFLAGS=debug_cflags)
|
||||
|
||||
release_env = common_env.Clone()
|
||||
release_env.VariantDir(os.path.join('build', 'release'), 'src', duplicate=0)
|
||||
release_cflags = ' -O2'
|
||||
release_env.Append(CPPDEFINES=['RELEASE'])
|
||||
|
||||
for d in source_directories:
|
||||
sc = os.path.join(d, 'SConscript')
|
||||
debug_env.SConscript(sc, {'env': debug_env})
|
||||
release_env.SConscript(sc, {'env': release_env})
|
Loading…
Add table
Add a link
Reference in a new issue