So much clean up...
Brought in the SConscript from Late Fish, which is where a lot of these changes were made. Cleaned up a bunch of stuff. Moved repeated code to functions. Implemented dynamically building libraries in lib/.
This commit is contained in:
parent
98e1fdd4fb
commit
fea154a058
1 changed files with 59 additions and 51 deletions
110
SConstruct
110
SConstruct
|
@ -16,11 +16,9 @@
|
||||||
CC = None
|
CC = None
|
||||||
CXX = None
|
CXX = None
|
||||||
AS = None
|
AS = None
|
||||||
LINK = None
|
LINK = 'clang++'
|
||||||
|
|
||||||
# Same as above but for default CFLAGS. These are appended to both CFLAGS and
|
CCFLAGS = ['-Wall', '-Wextra', '-pedantic']
|
||||||
# CXXFLAGS.
|
|
||||||
CFLAGS = '-Wall -Wextra -pedantic'
|
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
|
@ -29,6 +27,7 @@ CFLAGS = '-Wall -Wextra -pedantic'
|
||||||
|
|
||||||
import os
|
import os
|
||||||
import os.path
|
import os.path
|
||||||
|
import sys
|
||||||
import SCons.Errors
|
import SCons.Errors
|
||||||
|
|
||||||
|
|
||||||
|
@ -75,14 +74,6 @@ set_toolchain_binary(common_env, 'CC', CC, ('clang', 'gcc'))
|
||||||
set_toolchain_binary(common_env, 'CXX', CXX, ('clang++', 'g++'))
|
set_toolchain_binary(common_env, 'CXX', CXX, ('clang++', 'g++'))
|
||||||
set_toolchain_binary(common_env, 'AS', AS)
|
set_toolchain_binary(common_env, 'AS', AS)
|
||||||
set_toolchain_binary(common_env, 'LINK', LINK)
|
set_toolchain_binary(common_env, 'LINK', LINK)
|
||||||
common_env.Append(CFLAGS='{} -std=c99'.format(CFLAGS))
|
|
||||||
common_env.Append(CXXFLAGS='{} -std=c++11'.format(CFLAGS))
|
|
||||||
|
|
||||||
# Add color error messages for clang
|
|
||||||
if 'clang' in common_env['CC']:
|
|
||||||
common_env.Append(CFLAGS=' -fcolor-diagnostics')
|
|
||||||
if 'clang' in common_env['CXX']:
|
|
||||||
common_env.Append(CXXFLAGS=' -fcolor-diagnostics')
|
|
||||||
|
|
||||||
BUILD_CMDS = get_bool_argument(ARGUMENTS.get('BUILD_CMDS', False))
|
BUILD_CMDS = get_bool_argument(ARGUMENTS.get('BUILD_CMDS', False))
|
||||||
if not BUILD_CMDS:
|
if not BUILD_CMDS:
|
||||||
|
@ -99,25 +90,32 @@ if not BUILD_CMDS:
|
||||||
common_env['SHCXXCOMSTR'] = generate_comstr('Building (C++, Shared)')
|
common_env['SHCXXCOMSTR'] = generate_comstr('Building (C++, Shared)')
|
||||||
common_env['SHLINKCOMSTR'] = generate_comstr('Linking (Shared)')
|
common_env['SHLINKCOMSTR'] = generate_comstr('Linking (Shared)')
|
||||||
|
|
||||||
build_dir = Dir('#build')
|
# Separate environment for building libraries because they often don't use the
|
||||||
lib_dir = Dir('#lib')
|
# same CCFLAGS I do.
|
||||||
src_dir = Dir('#src')
|
lib_env = common_env.Clone()
|
||||||
test_dir = Dir('#test')
|
|
||||||
|
common_env.Append(CCFLAGS=CCFLAGS)
|
||||||
|
common_env.Append(CFLAGS=['-std=c99'])
|
||||||
|
common_env.Append(CXXFLAGS=['-std=c++11'])
|
||||||
|
|
||||||
|
# Add color error messages for clang
|
||||||
|
if sys.stdout.isatty():
|
||||||
|
if 'clang' in common_env['CC'] or 'clang' in common_env['CXX']:
|
||||||
|
common_env.Append(CCFLAGS=['-fcolor-diagnostics'])
|
||||||
|
|
||||||
|
BUILD_DIR = Dir('#build')
|
||||||
|
LIB_DIR = Dir('#lib')
|
||||||
|
SRC_DIR = Dir('#src')
|
||||||
|
TEST_DIR = Dir('#test')
|
||||||
|
|
||||||
|
|
||||||
def create_env(name, src_dirs, appends=None):
|
def create_env(name, appends=None):
|
||||||
output_dir = build_dir.Dir(name)
|
output_dir = BUILD_DIR.Dir(name)
|
||||||
env = common_env.Clone()
|
env = common_env.Clone()
|
||||||
|
# Standard env extensions.
|
||||||
|
env.Append(CPPPATH=[SRC_DIR])
|
||||||
|
# Custom env stuff.
|
||||||
env['__name'] = name
|
env['__name'] = name
|
||||||
env['__build_dir'] = output_dir
|
|
||||||
env['__src_dirs'] = []
|
|
||||||
env['__output_dirs'] = []
|
|
||||||
for d in src_dirs:
|
|
||||||
out_dir = output_dir.Dir(d.path)
|
|
||||||
env['__src_dirs'].append(d)
|
|
||||||
env['__output_dirs'].append(out_dir)
|
|
||||||
env.VariantDir(out_dir, d.path, duplicate=0)
|
|
||||||
env.Clean('.', out_dir)
|
|
||||||
if appends:
|
if appends:
|
||||||
for k, v in appends.iteritems():
|
for k, v in appends.iteritems():
|
||||||
if k.startswith('='):
|
if k.startswith('='):
|
||||||
|
@ -127,35 +125,28 @@ def create_env(name, src_dirs, appends=None):
|
||||||
return env
|
return env
|
||||||
|
|
||||||
|
|
||||||
debug_cflags = ' -O0 -g'
|
def do_sconscript(env, build_env, src_dir, out_dir):
|
||||||
debug_env = create_env('debug', [src_dir], {
|
sconscript = src_dir.File('SConscript')
|
||||||
'CPPDEFINES': ['DEBUG'],
|
print 'Reading {}'.format(sconscript)
|
||||||
'CFLAGS': debug_cflags,
|
env.SConscript(sconscript,
|
||||||
'CXXFLAGS': debug_cflags,
|
{'env': build_env},
|
||||||
|
variant_dir=out_dir)
|
||||||
|
|
||||||
|
|
||||||
|
debug_env = create_env('debug', {
|
||||||
|
'CPPDEFINES': ['NDEBUG'],
|
||||||
|
'CCFLAGS': ['-O0', '-g'],
|
||||||
})
|
})
|
||||||
|
|
||||||
release_cflags = ' -O2'
|
release_env = create_env('release', {
|
||||||
release_env = create_env('release', [src_dir], {
|
'CPPDEFINES': ['NRELEASE'],
|
||||||
'CPPDEFINES': ['RELEASE'],
|
'CCFLAGS': ['-O2']
|
||||||
'CFLAGS': release_cflags,
|
|
||||||
'CXXFLAGS': release_cflags,
|
|
||||||
})
|
|
||||||
|
|
||||||
test_gtest_dir = Dir('#lib/gtest')
|
|
||||||
test_cpppath = test_gtest_dir.Dir('include')
|
|
||||||
test_env = create_env('test', [src_dir, test_dir, test_gtest_dir], {
|
|
||||||
'CPPDEFINES': ['DEBUG'],
|
|
||||||
'CPPPATH': [test_cpppath],
|
|
||||||
'LIBPATH': [test_gtest_dir],
|
|
||||||
'CFLAGS': debug_cflags,
|
|
||||||
'CXXFLAGS': debug_cflags,
|
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
modes = {
|
modes = {
|
||||||
'debug': debug_env,
|
'debug': debug_env,
|
||||||
'release': release_env,
|
'release': release_env,
|
||||||
'test': test_env,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
mode = ARGUMENTS.get('MODE', None)
|
mode = ARGUMENTS.get('MODE', None)
|
||||||
|
@ -164,12 +155,29 @@ if mode:
|
||||||
# If MODE=foo is specified, build only that mode.
|
# If MODE=foo is specified, build only that mode.
|
||||||
build_modes.append(mode)
|
build_modes.append(mode)
|
||||||
else:
|
else:
|
||||||
build_modes = modes.keys()
|
build_modes = ['debug']
|
||||||
|
|
||||||
for mode in build_modes:
|
for mode in build_modes:
|
||||||
try:
|
try:
|
||||||
env = modes[mode]
|
env = modes[mode]
|
||||||
except KeyError:
|
except KeyError:
|
||||||
print 'Skipping invalid mode: {}'.format(mode)
|
print 'Skipping invalid mode: {}'.format(mode)
|
||||||
for d in env['__output_dirs']:
|
break
|
||||||
env.SConscript(d.File('SConscript'), {'env': env})
|
|
||||||
|
out_dir = BUILD_DIR.Dir(env['__name'])
|
||||||
|
|
||||||
|
# Process all lib dirs.
|
||||||
|
for lib in os.listdir(LIB_DIR.abspath):
|
||||||
|
lib_out_dir = out_dir.Dir('lib').Dir(lib)
|
||||||
|
if not os.path.isdir(lib_out_dir.abspath):
|
||||||
|
continue
|
||||||
|
do_sconscript(env, lib_env, LIB_DIR.Dir(lib), lib_out_dir)
|
||||||
|
env.Append(LIBPATH=[lib_out_dir])
|
||||||
|
|
||||||
|
# Get source files.
|
||||||
|
src_out_dir = out_dir.Dir('src')
|
||||||
|
do_sconscript(env, env, SRC_DIR, src_out_dir)
|
||||||
|
env.Append(LIBPATH=[src_out_dir])
|
||||||
|
|
||||||
|
# Get test binaries.
|
||||||
|
do_sconscript(env, env, TEST_DIR, out_dir.Dir('test'))
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue