wat
This commit is contained in:
parent
c9ff381f39
commit
921890e0b2
8 changed files with 95 additions and 10 deletions
14
SConstruct
14
SConstruct
|
@ -59,8 +59,22 @@ for mode in GetOption('modes'):
|
||||||
env = MODES[mode]
|
env = MODES[mode]
|
||||||
except KeyError:
|
except KeyError:
|
||||||
print 'Skipping invalid mode: {}'.format(mode)
|
print 'Skipping invalid mode: {}'.format(mode)
|
||||||
|
|
||||||
|
# Process libraries
|
||||||
|
env.SConscript(LIB_DIR.File('SConscript'), {
|
||||||
|
'env': env,
|
||||||
|
}, variant_dir=BUILD_DIR.Dir(env['MODE']).Dir('lib'), duplicate=0)
|
||||||
|
|
||||||
|
# Process source
|
||||||
library, binary = env.SConscript(SRC_DIR.File('SConscript'), {
|
library, binary = env.SConscript(SRC_DIR.File('SConscript'), {
|
||||||
'env': env
|
'env': env
|
||||||
}, variant_dir=BUILD_DIR.Dir(env['MODE']).Dir('src'), duplicate=0)
|
}, variant_dir=BUILD_DIR.Dir(env['MODE']).Dir('src'), duplicate=0)
|
||||||
env.Alias('lib', library)
|
env.Alias('lib', library)
|
||||||
env.Alias('bin', binary)
|
env.Alias('bin', binary)
|
||||||
|
|
||||||
|
env.SConscript(TEST_DIR.File('SConscript'), {
|
||||||
|
'env': env,
|
||||||
|
}, variant_dir=BUILD_DIR.Dir(env['MODE']).Dir('test'), duplicate=0)
|
||||||
|
|
||||||
|
Import('LIBS')
|
||||||
|
print LIBS
|
||||||
|
|
24
lib/SConscript
Normal file
24
lib/SConscript
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
# SConscript
|
||||||
|
#
|
||||||
|
# SCons build script for libs in base. Aggregates static and shared libraries in
|
||||||
|
# these directories and exports them in the 'LIBS' variable.
|
||||||
|
#
|
||||||
|
# Eryn Wells <eryn@erynwells.me>
|
||||||
|
|
||||||
|
|
||||||
|
Import('env')
|
||||||
|
|
||||||
|
dirs = (
|
||||||
|
'gtest',
|
||||||
|
)
|
||||||
|
|
||||||
|
env['LIBS'] = {}
|
||||||
|
for d in dirs:
|
||||||
|
static, dynamic = env.SConscript(Dir(d).File('SConscript'), {
|
||||||
|
'env': env,
|
||||||
|
})
|
||||||
|
env['LIBS'][d] = {}
|
||||||
|
if static:
|
||||||
|
env['LIBS'][d]['static'] = static
|
||||||
|
if dynamic:
|
||||||
|
env['LIBS'][d]['dynamic'] = dynamic
|
|
@ -25,4 +25,6 @@ for f in files:
|
||||||
|
|
||||||
env.Append(CPPPATH=[Dir('include').srcnode()])
|
env.Append(CPPPATH=[Dir('include').srcnode()])
|
||||||
|
|
||||||
gtest = env.Library('gtest', objs)
|
gtest_static = env.Library('gtest', [env.StaticObject(f) for f in files])
|
||||||
|
gtest_dynamic = None
|
||||||
|
Return('gtest_static gtest_dynamic')
|
||||||
|
|
9
site_scons/dirs.py
Normal file
9
site_scons/dirs.py
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
# dirs.py
|
||||||
|
# Eryn Wells <eryn@erynwells.me>
|
||||||
|
|
||||||
|
from SCons.Script import Dir
|
||||||
|
|
||||||
|
BUILD_DIR = Dir('#build')
|
||||||
|
LIB_DIR = Dir('#lib')
|
||||||
|
SRC_DIR = Dir('#src')
|
||||||
|
TEST_DIR = Dir('#test')
|
|
@ -7,14 +7,9 @@
|
||||||
|
|
||||||
import os.path
|
import os.path
|
||||||
import SCons.Defaults
|
import SCons.Defaults
|
||||||
import binaries
|
from dirs import *
|
||||||
|
|
||||||
|
|
||||||
BUILD_DIR = Dir('#build')
|
|
||||||
LIB_DIR = Dir('#lib')
|
|
||||||
SRC_DIR = Dir('#src')
|
|
||||||
TEST_DIR = Dir('#test')
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Environment Configuration
|
# Environment Configuration
|
||||||
#
|
#
|
||||||
|
@ -22,11 +17,15 @@ TEST_DIR = Dir('#test')
|
||||||
def has_clang(env):
|
def has_clang(env):
|
||||||
_, cc_tail = os.path.split(env['CC'])
|
_, cc_tail = os.path.split(env['CC'])
|
||||||
_, cxx_tail = os.path.split(env['CXX'])
|
_, cxx_tail = os.path.split(env['CXX'])
|
||||||
return any([cc_tail.startswith('clang'), cxx_tail.startswith('clang')])
|
return all([cc_tail.startswith('clang'), cxx_tail.startswith('clang')])
|
||||||
|
|
||||||
default_env = SCons.Defaults.DefaultEnvironment()
|
default_env = SCons.Defaults.DefaultEnvironment()
|
||||||
default_env.Replace(CC=binaries.first(['clang', 'gcc']),
|
default_env.Append(TOOLS=['gtest'])
|
||||||
CXX=binaries.first(['clang++', 'g++']))
|
print default_env.Dump()
|
||||||
|
|
||||||
|
default_env.Replace(
|
||||||
|
CC=default_env.WhereIs('clang') or default_env.WhereIs('gcc'),
|
||||||
|
CXX=default_env.WhereIs('clang++') or default_env.WhereIs('gcc++'))
|
||||||
|
|
||||||
default_env.Append(CCFLAGS=['-Wall', '-Wextra', '-pedantic'],
|
default_env.Append(CCFLAGS=['-Wall', '-Wextra', '-pedantic'],
|
||||||
CFLAGS=['-std=c99'],
|
CFLAGS=['-std=c99'],
|
||||||
|
|
28
site_scons/site_tools/gtest/__init__.py
Normal file
28
site_scons/site_tools/gtest/__init__.py
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
# gtestprogram.py
|
||||||
|
# Eryn Wells <eryn@erynwells.me>
|
||||||
|
|
||||||
|
import SCons.Util
|
||||||
|
import dirs
|
||||||
|
|
||||||
|
|
||||||
|
def build_gtest_program(env, target, source=None, *args, **kwargs):
|
||||||
|
if not SCons.Util.is_List(source):
|
||||||
|
source = [source]
|
||||||
|
source.insert(0, dirs.LIB_DIR.Dir('gtest').File('gtest_main.cc'))
|
||||||
|
source.append(env['LIBS']['gtest']['static'])
|
||||||
|
return env.Program(target, source, *args, **kwargs)
|
||||||
|
|
||||||
|
|
||||||
|
def generate(env):
|
||||||
|
print 'gtestprogram generate()'
|
||||||
|
try:
|
||||||
|
env.AddMethod(build_gtest_program, 'GTestProgram')
|
||||||
|
except AttributeError:
|
||||||
|
# Old version of SCons
|
||||||
|
from SCons.Script.SConscript import SConsEnvironment
|
||||||
|
SConsEnvironment.GTestProgram = build_gtest_program
|
||||||
|
|
||||||
|
|
||||||
|
def exists(env):
|
||||||
|
print 'gtestprogram exists()'
|
||||||
|
return 'gtest' in env['LIBS']
|
|
@ -18,8 +18,15 @@ for d in subdirs:
|
||||||
|
|
||||||
files = [
|
files = [
|
||||||
# TODO: Put files here.
|
# TODO: Put files here.
|
||||||
|
#'hello.cc',
|
||||||
]
|
]
|
||||||
|
|
||||||
objs = []
|
objs = []
|
||||||
for f in files:
|
for f in files:
|
||||||
objs.append(env.Object(f))
|
objs.append(env.Object(f))
|
||||||
|
|
||||||
|
#lib = env.Library('hello', files)
|
||||||
|
#prog = env.Program('hello', lib)
|
||||||
|
lib = None
|
||||||
|
prog = None
|
||||||
|
Return('prog lib')
|
||||||
|
|
|
@ -23,3 +23,5 @@ files = [
|
||||||
objs = []
|
objs = []
|
||||||
for f in files:
|
for f in files:
|
||||||
objs.append(env.Object(f))
|
objs.append(env.Object(f))
|
||||||
|
|
||||||
|
env.GTestProgram('test_hello', 'test_hello.cc')
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue