Page Menu
Home
Phabricator (Chris)
Search
Configure Global Search
Log In
Files
F131910
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Flag For Later
Award Token
Authored By
Unknown
Size
9 KB
Referenced Files
None
Subscribers
None
View Options
diff --git a/SConscript b/SConscript
index f2f6e71e..1cafe822 100644
--- a/SConscript
+++ b/SConscript
@@ -1,170 +1,173 @@
import os
import sys
Import('root')
#print "Rtech1 sys path", Dir('.').rel_path(Dir("#%s" % root))
#print Dir('.').abspath
#print Dir(Dir('.').rel_path(Dir("#r-tech1"))).abspath
sys.path.append(Dir('.').rel_path(Dir("#%s" % root)))
import scons_rtech1.utils
import scons_rtech1.checks
Import('env')
+Import('build_dir_root')
build_type = 'release'
if scons_rtech1.utils.useAndroid():
build_type = 'armeabi-v7a'
if scons_rtech1.utils.useAndroidX64():
build_type = 'android-x64'
config = env.Configure(custom_tests = {'CheckAllegro5': scons_rtech1.checks.checkAllegro5(scons_rtech1.checks.debug()),
'CheckFreetype': scons_rtech1.checks.checkFreetype,
'ConfigChecks': scons_rtech1.checks.configChecks})
if scons_rtech1.utils.useAndroidX64():
env['HAVE_ALLEGRO5'] = True
env.Append(CPPDEFINES = ['USE_ALLEGRO5'])
else:
config.CheckAllegro5()
config.CheckFreetype()
config.ConfigChecks()
env = config.Finish()
if not env['HAVE_ALLEGRO5']:
Exit(1)
if scons_rtech1.checks.debug():
env.Append(CXXFLAGS = ['-g3','-ggdb', '-Werror'])
-build_dir = 'build/%s' % build_type if not scons_rtech1.checks.debug() else 'build/debug'
+build_dir = '%s/%s' % (build_dir_root, build_type if not scons_rtech1.checks.debug() else 'debug')
options = {'networking': False,
'allegro5': True
}
def getLibName():
if scons_rtech1.utils.useAndroid():
return 'lib/r-tech1-arm'
if scons_rtech1.checks.debug():
return 'lib/r-tech1-debug'
return 'lib/r-tech1'
libname = getLibName()
env.Append(CPPPATH = [Dir('include', Dir('.').rel_path(Dir('#' + root)))])
env.VariantDir(build_dir, 'src')
libs = env.SConscript('src/SConscript', variant_dir=build_dir, exports=['env', 'options', 'root'])
rtech1 = env.StaticLibrary(libname, libs)
Alias('rtech1', rtech1)
tests_build_dir = os.path.join(build_dir, 'tests')
unit_tests = []
if not scons_rtech1.utils.useAndroid() and False:
unit_tests = SConscript('tests/SConscript', variant_dir = tests_build_dir, exports = ['env', 'rtech1', 'root'], duplicate=0)
env.Depends(unit_tests, rtech1)
if os.access(env.installPrefix, os.W_OK):
+ installEnv = env.Clone(tools = ['textfile'])
# Install target and configuration
- env.Install('{0}/lib'.format(env.installPrefix), rtech1)
+ installEnv.Install('{0}/lib'.format(installEnv.installPrefix), rtech1)
- header_prefix = '{0}/include/r-tech1'.format(env.installPrefix)
+ header_prefix = '{0}/include/r-tech1'.format(installEnv.installPrefix)
include_dir = 'include/r-tech1'
for root, dirs, files in os.walk(include_dir):
for file in files:
# print "Install %s, %s" % (header_prefix + root[len('include/r-tech1'):], os.path.join(root, file))
# Install to <header location>/<local subdirectory>. The root contains the full
# include/r-tech1/subdirectory, so we chop off the leading include/r-tech1
- env.Install(header_prefix + root[len(include_dir):], os.path.join(root, file))
+ installEnv.Install(header_prefix + root[len(include_dir):], os.path.join(root, file))
- env.Install(os.path.join(header_prefix, 'lz4'), 'src/libs/lz4/lz4.h')
+ installEnv.Install(os.path.join(header_prefix, 'lz4'), 'src/libs/lz4/lz4.h')
# Construct dependency cflags and libraries for pc script
def createList(content, modifier):
deps = ''
for item in content:
- deps += '-{0}{1} '.format(modifier, item) if 'r-tech1' not in item else ''
+ deps += '-{0}{1} '.format(modifier, item) if 'r-tech1' not in str(item) else ''
return deps
- pcflags = createList(env['CPPPATH'], 'I')
- pclibs = createList(env['LIBS'], 'l')
- pclibpaths = createList(env['LIBPATH'], 'L')
+ pcflags = createList(installEnv['CPPPATH'], 'I')
+ pclibs = createList(installEnv['LIBS'], 'l')
+ pclibpaths = createList(installEnv['LIBPATH'], 'L')
# PC script
replacelist = {
'%lib%': 'r-tech1' if not scons_rtech1.checks.debug() else 'r-tech1-debug',
- '%prefix%': env.installPrefix,
+ '%prefix%': installEnv.installPrefix,
'%rtech1_version%': '1',
'%flags%': pcflags,
'%libs%': pclibs,
'%libpaths%': pclibpaths
}
def script(name):
- pc_install = '{0}/lib/pkgconfig/{1}.pc'.format(env.installPrefix, name)
+ pc_install = '{0}/lib/pkgconfig/{1}.pc'.format(installEnv.installPrefix, name)
pc_copied = Command(build_dir + '/temp.pc.in', 'misc/r-tech1.pc.in'.format(name), Copy('$TARGET', '$SOURCE'))
- pc_script = env.Substfile(build_dir + '/temp.pc.in', SUBST_DICT = replacelist)
- env.Depends(pc_script, pc_copied)
+ print installEnv
+ pc_script = installEnv.Substfile(build_dir + '/temp.pc.in', SUBST_DICT = replacelist)
+ installEnv.Depends(pc_script, pc_copied)
pc_mod = Command(build_dir + '/{0}.pc'.format(name), build_dir + '/temp.pc', Copy('$TARGET', '$SOURCE'))
- env.Depends(pc_mod, pc_script)
- env.InstallAs(pc_install, pc_mod)
+ installEnv.Depends(pc_mod, pc_script)
+ installEnv.InstallAs(pc_install, pc_mod)
return pc_mod, pc_install
pc_mod, pc_install = script('r-tech1') if not scons_rtech1.checks.debug() else script('r-tech1-debug')
# Install
- env.Alias('install', [env.installPrefix, pc_install])
- env.Depends([env.installPrefix, pc_mod], rtech1)
+ installEnv.Alias('install', [installEnv.installPrefix, pc_install])
+ installEnv.Depends([installEnv.installPrefix, pc_mod], rtech1)
# Uninstall target
- env.Command("uninstall", None, Delete(FindInstalledFiles()))
+ installEnv.Command("uninstall", None, Delete(FindInstalledFiles()))
else:
def needsudo(target, source, env):
print 'No write priveleges to {0}, run target [{1}] as sudo'.format(env.installPrefix, target[0])
env.Command('install', None, needsudo)
env.Depends('install', ['rtech1', 'tests'])
env.Command('uninstall', None, needsudo)
env.Depends('uninstall', ['rtech1', 'tests'])
#env.Install('headers', Dir('include', Dir('.').rel_path(Dir("#%s" % root))).abspath)
#env.Install('headers/include/lz4', File('src/libs/lz4/lz4.h', Dir('.').rel_path(Dir('#%s' % root))).abspath)
#env.Install(os.path.join(build_dir, 'headers'), Dir('include', Dir('.').rel_path(Dir("#%s" % root))).abspath)
#env['RTECH1_HEADERS'] = Dir('headers', Dir(build_dir))
include_dir = 'include/r-tech1'
root_dir = Dir('include/r-tech1', Dir('#%s' % root)).abspath
for myroot, dirs, files in os.walk(root_dir):
for file in files:
source = os.path.join(myroot, file)
dir = myroot[len(root_dir) + 1:]
# print "Stripped %s" % os.path.join(source[len(root_dir) + 1:])
# print Dir('headers/r-tech1', Dir(build_dir)).abspath
destination = Dir(dir, Dir('headers/r-tech1', Dir(build_dir))).abspath
# print "Install %s -> %s" % (source, destination)
# Install to <header location>/<local subdirectory>. The root contains the full
# include/r-tech1/subdirectory, so we chop off the leading include/r-tech1
# env.Install(os.path.join(build_dir, 'headers/r-tech1', root[len(include_dir):]), File(os.path.join(root, file), Dir('.').rel_path(Dir('#%s' % root))).abspath)
# env.Install(destination, File(source, Dir('.').rel_path('#%s' % root)).abspath)
# env.Install(destination, File(source))
# env.Install(os.path.join(build_dir, 'headers/r-tech1/lz4'), File('src/libs/lz4/lz4.h', Dir('.').rel_path(Dir('#%s' % root))).abspath)
# env['RTECH1_HEADERS'] = [Dir('include', Dir('.').rel_path(Dir('#%s' % root))).abspath, Dir('headers', Dir(build_dir))]
env['RTECH1_HEADERS'] = [Dir('include', Dir('.').rel_path(Dir('#%s' % root))).abspath]
# env['RTECH1_HEADERS'] = [Dir('headers', Dir(build_dir))]
# env.Default(rtech1)
env.Alias('tests', unit_tests)
for test in unit_tests:
orig = str(test).translate(None,'[]\'')
to = orig.replace('{0}/tests/'.format(build_dir), '')
#print orig, to
copy = Command('bin/{0}'.format(to), orig, Copy('$TARGET', '$SOURCE'))
env.Depends(copy, test)
env.Alias('tests', copy)
Return('rtech1')
diff --git a/SConstruct b/SConstruct
index 7a7d3d12..ae3c6602 100644
--- a/SConstruct
+++ b/SConstruct
@@ -1,22 +1,23 @@
import os
import scons_rtech1.utils
import scons_rtech1.checks
import scons_rtech1.env
SetOption('num_jobs', scons_rtech1.utils.detectCPUs())
# FIXME: use Dir('.').rel_path(Dir('#"))
includedir = '{0}/include'.format(os.getcwd())
env = Environment(ENV = os.environ, CPPPATH=includedir, tools=['textfile', 'default'])
if scons_rtech1.utils.useAndroid():
env = scons.env.android(env)
if scons_rtech1.utils.useAndroidX64():
env = scons.env.androidx64(env)
if not scons_rtech1.utils.isVerbose():
env = scons_rtech1.utils.less_verbose(env)
root = '.'
-env.Default(SConscript('SConscript', exports = ['env', 'root']))
+build_dir_root = 'build'
+env.Default(SConscript('SConscript', exports = ['env', 'root', 'build_dir_root']))
File Metadata
Details
Attached
Mime Type
text/x-diff
Expires
Tue, Jun 16, 12:24 AM (2 w, 1 d ago)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
70823
Default Alt Text
(9 KB)
Attached To
Mode
R75 R-Tech1
Attached
Detach File
Event Timeline