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:
Eryn Wells 2014-07-04 10:55:32 -07:00
parent 98e1fdd4fb
commit fea154a058

View file

@ -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'))