mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-12-22 13:18:28 +00:00
Bug fixes to the scons system.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@13831 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
bee53b6c8d
commit
c7fa09fe9f
@ -16,7 +16,7 @@ Import('env')
|
||||
# boost libraries
|
||||
#
|
||||
if env['INCLUDED_BOOST']:
|
||||
env.BuildDir('#$BUILDDIR/common', '$TOP_SRC_DIR/boost/libs', duplicate = 0)
|
||||
env.BuildDir('$BUILDDIR/boost', '$TOP_SRC_DIR/boost/libs', duplicate = 0)
|
||||
|
||||
boostenv = env.Copy()
|
||||
boostenv.Append(CCFLAGS = '-DBOOST_USER_CONFIG="<config.h>"')
|
||||
@ -27,7 +27,7 @@ if env['INCLUDED_BOOST']:
|
||||
|
||||
filesystem = boostenv.StaticLibrary(
|
||||
target = '$LOCALLIBPATH/boost_filesystem',
|
||||
source = ["#$BUILDDIR/common/filesystem/src/%s" % x for x in Split('''
|
||||
source = ["$BUILDDIR/boost/filesystem/src/%s" % x for x in Split('''
|
||||
convenience.cpp
|
||||
exception.cpp
|
||||
operations_posix_windows.cpp
|
||||
@ -39,7 +39,7 @@ if env['INCLUDED_BOOST']:
|
||||
|
||||
regex = boostenv.StaticLibrary(
|
||||
target = '$LOCALLIBPATH/boost_regex',
|
||||
source = ["#$BUILDDIR/common/regex/src/%s" % x for x in Split('''
|
||||
source = ["$BUILDDIR/boost/regex/src/%s" % x for x in Split('''
|
||||
cpp_regex_traits.cpp
|
||||
c_regex_traits.cpp
|
||||
cregex.cpp
|
||||
@ -52,16 +52,11 @@ if env['INCLUDED_BOOST']:
|
||||
''')]
|
||||
)
|
||||
|
||||
# Return the library
|
||||
Return('regex')
|
||||
|
||||
Import('boostenv')
|
||||
|
||||
print 'Processing files in boost/libs/signals/src...'
|
||||
|
||||
signals = boostenv.StaticLibrary(
|
||||
target = '$LOCALLIBPATH/boost_signals',
|
||||
source = ["#$BUILDDIR/common/signals/src/%s" % x for x in Split('''
|
||||
source = ["$BUILDDIR/boost/signals/src/%s" % x for x in Split('''
|
||||
connection.cpp
|
||||
named_slot_map.cpp
|
||||
signal_base.cpp
|
||||
@ -74,7 +69,7 @@ if env['INCLUDED_BOOST']:
|
||||
|
||||
iostreams = boostenv.StaticLibrary(
|
||||
target = '$LOCALLIBPATH/boost_iostreams',
|
||||
source = ["#$BUILDDIR/common/iostreams/src/%s" % x for x in Split('''
|
||||
source = ["$BUILDDIR/boost/iostreams/src/%s" % x for x in Split('''
|
||||
file_descriptor.cpp
|
||||
mapped_file.cpp
|
||||
zlib.cpp
|
||||
@ -86,7 +81,7 @@ if env['INCLUDED_BOOST']:
|
||||
# Now, src code under src/
|
||||
#
|
||||
|
||||
env.BuildDir('#$BUILDDIR/common', '$TOP_SRC_DIR/src', duplicate = 0)
|
||||
env.BuildDir('$BUILDDIR/common', '$TOP_SRC_DIR/src', duplicate = 0)
|
||||
|
||||
#
|
||||
# src/support
|
||||
@ -97,11 +92,11 @@ print "Processing files in src/support"
|
||||
env.Append(CPPPATH = ['.'])
|
||||
|
||||
env['SUBST_KEYS'] = ['LYX_DIR', 'LOCALEDIR', 'TOP_SRCDIR', 'PROGRAM_SUFFIX']
|
||||
env.substFile('#$BUILDDIR/common/support/package.C', '$TOP_SRC_DIR/src/support/package.C.in')
|
||||
env.substFile('$BUILDDIR/common/support/package.C', '$TOP_SRC_DIR/src/support/package.C.in')
|
||||
|
||||
supports = env.StaticLibrary(
|
||||
target = '$LOCALLIBPATH/supports',
|
||||
source = ['#$BUILDDIR/common/support/%s' % x for x in Split('''
|
||||
source = ['$BUILDDIR/common/support/%s' % x for x in Split('''
|
||||
FileMonitor.C
|
||||
abort.C
|
||||
chdir.C
|
||||
@ -141,7 +136,7 @@ print "Processing files in src/mathed"
|
||||
|
||||
mathed = env.StaticLibrary(
|
||||
target = '$LOCALLIBPATH/mathed',
|
||||
source = ["#$BUILDDIR/common/mathed/%s" % x for x in Split('''
|
||||
source = ["$BUILDDIR/common/mathed/%s" % x for x in Split('''
|
||||
textpainter.C
|
||||
math_amsarrayinset.C
|
||||
math_arrayinset.C
|
||||
@ -225,7 +220,7 @@ print "Processing files in src/insets"
|
||||
|
||||
insets = env.StaticLibrary(
|
||||
target = '$LOCALLIBPATH/insets',
|
||||
source = ["#$BUILDDIR/common/insets/%s" % x for x in Split('''
|
||||
source = ["$BUILDDIR/common/insets/%s" % x for x in Split('''
|
||||
mailinset.C
|
||||
ExternalSupport.C
|
||||
ExternalTemplate.C
|
||||
@ -287,7 +282,7 @@ print "Processing files in src/frontends"
|
||||
|
||||
frontends = env.StaticLibrary(
|
||||
target = '$LOCALLIBPATH/frontends',
|
||||
source = ["#$BUILDDIR/common/frontends/%s" % x for x in Split('''
|
||||
source = ["$BUILDDIR/common/frontends/%s" % x for x in Split('''
|
||||
Alert.C
|
||||
Dialogs.C
|
||||
LyXView.C
|
||||
@ -309,7 +304,7 @@ print "Processing files in src/graphics"
|
||||
|
||||
graphics = env.StaticLibrary(
|
||||
target = '$LOCALLIBPATH/graphics',
|
||||
source = ["#$BUILDDIR/common/graphics/%s" % x for x in Split('''
|
||||
source = ["$BUILDDIR/common/graphics/%s" % x for x in Split('''
|
||||
GraphicsCache.C
|
||||
GraphicsCacheItem.C
|
||||
GraphicsConverter.C
|
||||
@ -332,7 +327,7 @@ print "Processing files in src/frontends/controllers"
|
||||
|
||||
controllers = env.StaticLibrary(
|
||||
target = '$LOCALLIBPATH/controllers',
|
||||
source = ["#$BUILDDIR/common/frontends/controllers/%s" % x for x in Split('''
|
||||
source = ["$BUILDDIR/common/frontends/controllers/%s" % x for x in Split('''
|
||||
Dialog.C
|
||||
Kernel.C
|
||||
biblio.C
|
||||
@ -389,7 +384,7 @@ controllers = env.StaticLibrary(
|
||||
#
|
||||
|
||||
frontend = env['frontend']
|
||||
env.BuildDir('#$BUILDDIR/$frontend', '$TOP_SRC_DIR/src/frontend/$frontend', duplicate = 0)
|
||||
env.BuildDir('$BUILDDIR/$frontend', '$TOP_SRC_DIR/src/frontend/$frontend', duplicate = 0)
|
||||
|
||||
if frontend == 'qt3':
|
||||
print "Processing files in src/frontends/qt3"
|
||||
@ -400,11 +395,11 @@ if frontend == 'qt3':
|
||||
qt3env.Tool('qt')
|
||||
|
||||
qt3env.Append(CPPPATH = [
|
||||
'#$BUILDDIR/common',
|
||||
'#$BUILDDIR/common/frontends',
|
||||
'#$BUILDDIR/common/images',
|
||||
'#$BUILDDIR/common/frontends/controllers',
|
||||
'#$BUILDDIR/common/frontends/qt3',
|
||||
'$BUILDDIR/common',
|
||||
'$BUILDDIR/common/frontends',
|
||||
'$BUILDDIR/common/images',
|
||||
'$BUILDDIR/common/frontends/controllers',
|
||||
'$BUILDDIR/common/frontends/qt3',
|
||||
'$QT_INC_DIR',
|
||||
'.']
|
||||
)
|
||||
@ -482,7 +477,7 @@ if frontend == 'qt3':
|
||||
''')
|
||||
|
||||
|
||||
qt3_moc_files = ["#$BUILDDIR/common/frontends/qt3/%s" % x for x in Split('''
|
||||
qt3_moc_files = ["$BUILDDIR/common/frontends/qt3/%s" % x for x in Split('''
|
||||
BulletsModule.C
|
||||
emptytable.C
|
||||
FileDialog_private.C
|
||||
@ -548,11 +543,11 @@ if frontend == 'qt3':
|
||||
# file extension from .C to .cpp
|
||||
qt3_moced_files = []
|
||||
if os.name == 'nt' or sys.platform == 'cygwin':
|
||||
qt3_moced_files = [qt3env.Moc('$BUILDDIR/common/frontends/qt3/'+x.replace('.C', '.h')) for x in moc_files]
|
||||
qt3_moced_files = [qt3env.Moc('$BUILDDIR/common/frontends/qt3/'+x.replace('.C', '.h')) for x in qt3_moc_files]
|
||||
|
||||
qt3 = qt3env.StaticLibrary(
|
||||
target = '$LOCALLIBPATH/qt3',
|
||||
source = ["#$BUILDDIR/common/frontends/qt3/%s" % x for x in Split('''
|
||||
source = ["$BUILDDIR/common/frontends/qt3/%s" % x for x in Split('''
|
||||
QDialogView.C
|
||||
Alert_pimpl.C
|
||||
Dialogs.C
|
||||
@ -615,7 +610,7 @@ if frontend == 'qt3':
|
||||
qt_helpers.C
|
||||
''')] +
|
||||
qt3_moc_files + qt3_moced_files +
|
||||
['#$BUILDDIR/common/frontends/qt3/ui/' + x for x in qt3_ui_files]
|
||||
['$BUILDDIR/common/frontends/qt3/ui/' + x for x in qt3_ui_files]
|
||||
)
|
||||
elif frontend == 'qt4':
|
||||
print "Processing files in src/frontends/qt4"
|
||||
@ -629,15 +624,15 @@ elif frontend == 'qt4':
|
||||
# process .C file!!! (add to cxx_suffixes )
|
||||
#
|
||||
if frontend == 'qt4':
|
||||
qt4env.Tool('qt4', '.')
|
||||
qt4env.Tool('qt4', [env['SCONS_DIR']])
|
||||
qt4env.EnableQt4Modules(env['QT_LIB'], debug = False)
|
||||
|
||||
qt4env.Append(CPPPATH = [
|
||||
'#$BUILDDIR/common',
|
||||
'#$BUILDDIR/common/images',
|
||||
'#$BUILDDIR/common/frontends',
|
||||
'#$BUILDDIR/common/frontends/qt4',
|
||||
'#$BUILDDIR/common/frontends/controllers',
|
||||
'$BUILDDIR/common',
|
||||
'$BUILDDIR/common/images',
|
||||
'$BUILDDIR/common/frontends',
|
||||
'$BUILDDIR/common/frontends/qt4',
|
||||
'$BUILDDIR/common/frontends/controllers',
|
||||
'$QT_INC_PATH',
|
||||
'$QT_INC_PATH/Qt',
|
||||
'$QT_INC_PATH/QtCore',
|
||||
@ -793,7 +788,7 @@ elif frontend == 'qt4':
|
||||
# Compile resources
|
||||
#
|
||||
for x in qt4_ui_files:
|
||||
qt4env.Uic4('#$BUILDDIR/common/frontends/qt4/ui/' + x)
|
||||
qt4env.Uic4('$BUILDDIR/common/frontends/qt4/ui/' + x)
|
||||
|
||||
qt4_source_files = Split('''
|
||||
QDialogView.C
|
||||
@ -862,8 +857,8 @@ elif frontend == 'qt4':
|
||||
qt4 = qt4env.StaticLibrary(
|
||||
target = '$LOCALLIBPATH/qt4',
|
||||
LIBS = qt4env['QT_LIB'],
|
||||
source = ["#$BUILDDIR/common/frontends/qt4/%s" % x for x in qt4_source_files] + \
|
||||
["#$BUILDDIR/common/frontends/qt4/%s" % x for x in qt4_moc_files]
|
||||
source = ["$BUILDDIR/common/frontends/qt4/%s" % x for x in qt4_source_files] + \
|
||||
["$BUILDDIR/common/frontends/qt4/%s" % x for x in qt4_moc_files]
|
||||
)
|
||||
|
||||
|
||||
@ -871,51 +866,49 @@ elif frontend == 'qt4':
|
||||
# src/client
|
||||
#
|
||||
|
||||
if 'client' in env['BUILD_TARGETS']:
|
||||
env.BuildDir('#$BUILDDIR/common', '$TOP_SRC_DIR/src', duplicate = 0)
|
||||
env.BuildDir('$BUILDDIR/common', '$TOP_SRC_DIR/src', duplicate = 0)
|
||||
|
||||
print "Processing files in src/client"
|
||||
print "Processing files in src/client"
|
||||
|
||||
lyxclient = env.Program(
|
||||
target = '#$BUILDDIR/common/client/lyxclient',
|
||||
LIBS = env['BOOST_LIBRARIES'] + env['socket_libs'],
|
||||
source = ["#$BUILDDIR/common/client/%s" % x for x in Split('''
|
||||
lyxclient = env.Program(
|
||||
target = '$BUILDDIR/common/client/lyxclient',
|
||||
LIBS = env['BOOST_LIBRARIES'] + env['socket_libs'] + ['supports'],
|
||||
source = ["$BUILDDIR/common/client/%s" % x for x in Split('''
|
||||
boost.C
|
||||
client.C
|
||||
debug.C
|
||||
gettext.C
|
||||
messages.C
|
||||
''')]
|
||||
)
|
||||
|
||||
env.copyFile('#$BUILDDIR/lyxclient', '#$BUILDDIR/common/client/lyxclient')
|
||||
)
|
||||
env.fileCopy('$BUILDDIR/lyxclient', '$BUILDDIR/common/client/lyxclient')
|
||||
Alias('lyxclient', lyxclient)
|
||||
|
||||
#
|
||||
# tex2lyx
|
||||
#
|
||||
if 'tex2lyx' in env['BUILD_TARGETS']:
|
||||
print "Processing files in src/tex2lyx"
|
||||
print "Processing files in src/tex2lyx"
|
||||
|
||||
tex2lyx_env = env.Copy()
|
||||
# the order is important here.
|
||||
tex2lyx_env.Prepend(CPPPATH = ['#$BUILDDIR/common/tex2lyx'])
|
||||
tex2lyx_env.Append(LIBPATH = ['#$LOCALLIBPATH'])
|
||||
tex2lyx_env = env.Copy()
|
||||
# the order is important here.
|
||||
tex2lyx_env.Prepend(CPPPATH = ['$BUILDDIR/common/tex2lyx'])
|
||||
tex2lyx_env.Append(LIBPATH = ['#$LOCALLIBPATH'])
|
||||
|
||||
tex2lyx_env.fileCopy('#$BUILDDIR/common/tex2lyx/FloatList.C', 'src/FloatList.C')
|
||||
tex2lyx_env.fileCopy('#$BUILDDIR/common/tex2lyx/Floating.C', 'src/Floating.C')
|
||||
tex2lyx_env.fileCopy('#$BUILDDIR/common/tex2lyx/counters.C', 'src/counters.C')
|
||||
# for some reason I do not know, I have to copy the header files as well.
|
||||
tex2lyx_env.fileCopy('#$BUILDDIR/common/tex2lyx/lyxlayout.h', 'src/lyxlayout.h')
|
||||
tex2lyx_env.fileCopy('#$BUILDDIR/common/tex2lyx/lyxlayout.C', 'src/lyxlayout.C')
|
||||
tex2lyx_env.fileCopy('#$BUILDDIR/common/tex2lyx/lyxtextclass.h', 'src/lyxtextclass.h')
|
||||
tex2lyx_env.fileCopy('#$BUILDDIR/common/tex2lyx/lyxtextclass.C', 'src/lyxtextclass.C')
|
||||
tex2lyx_env.fileCopy('#$BUILDDIR/common/tex2lyx/lyxlex.C', 'src/lyxlex.C')
|
||||
tex2lyx_env.fileCopy('#$BUILDDIR/common/tex2lyx/lyxlex_pimpl.C', 'src/lyxlex_pimpl.C')
|
||||
tex2lyx_env.fileCopy('$BUILDDIR/common/tex2lyx/FloatList.C', '$TOP_SRC_DIR/src/FloatList.C')
|
||||
tex2lyx_env.fileCopy('$BUILDDIR/common/tex2lyx/Floating.C', '$TOP_SRC_DIR/src/Floating.C')
|
||||
tex2lyx_env.fileCopy('$BUILDDIR/common/tex2lyx/counters.C', '$TOP_SRC_DIR/src/counters.C')
|
||||
# for some reason I do not know, I have to copy the header files as well.
|
||||
tex2lyx_env.fileCopy('$BUILDDIR/common/tex2lyx/lyxlayout.h', '$TOP_SRC_DIR/src/lyxlayout.h')
|
||||
tex2lyx_env.fileCopy('$BUILDDIR/common/tex2lyx/lyxlayout.C', '$TOP_SRC_DIR/src/lyxlayout.C')
|
||||
tex2lyx_env.fileCopy('$BUILDDIR/common/tex2lyx/lyxtextclass.h', '$TOP_SRC_DIR/src/lyxtextclass.h')
|
||||
tex2lyx_env.fileCopy('$BUILDDIR/common/tex2lyx/lyxtextclass.C', '$TOP_SRC_DIR/src/lyxtextclass.C')
|
||||
tex2lyx_env.fileCopy('$BUILDDIR/common/tex2lyx/lyxlex.C', '$TOP_SRC_DIR/src/lyxlex.C')
|
||||
tex2lyx_env.fileCopy('$BUILDDIR/common/tex2lyx/lyxlex_pimpl.C', '$TOP_SRC_DIR/src/lyxlex_pimpl.C')
|
||||
|
||||
tex2lyx = tex2lyx_env.Program(
|
||||
target = '#$BUILDDIR/common/tex2lyx/tex2lyx',
|
||||
tex2lyx = tex2lyx_env.Program(
|
||||
target = '$BUILDDIR/common/tex2lyx/tex2lyx',
|
||||
LIBS = ['supports'] + env['BOOST_LIBRARIES'] + env['SYSTEM_LIBS'],
|
||||
source = ["#$BUILDDIR/common/tex2lyx/%s" % x for x in Split('''
|
||||
source = ["$BUILDDIR/common/tex2lyx/%s" % x for x in Split('''
|
||||
FloatList.C
|
||||
Floating.C
|
||||
counters.C
|
||||
@ -935,8 +928,9 @@ if 'tex2lyx' in env['BUILD_TARGETS']:
|
||||
table.C
|
||||
text.C
|
||||
''')]
|
||||
)
|
||||
|
||||
)
|
||||
env.fileCopy('$BUILDDIR/tex2lyx', '$BUILDDIR/common/tex2lyx/tex2lyx')
|
||||
Alias('tex2lyx', tex2lyx)
|
||||
#
|
||||
# src/
|
||||
#
|
||||
@ -944,7 +938,7 @@ if 'tex2lyx' in env['BUILD_TARGETS']:
|
||||
print "Processing files in src"
|
||||
|
||||
env['SUBST_KEYS'] = ['PACKAGE_VERSION', 'VERSION_INFO']
|
||||
env.substFile('#$BUILDDIR/common/version.C', '$TOP_SRC_DIR/src/version.C.in')
|
||||
env.substFile('$BUILDDIR/common/version.C', '$TOP_SRC_DIR/src/version.C.in')
|
||||
|
||||
lyx_source = Split('''
|
||||
Bidi.C
|
||||
@ -1065,13 +1059,12 @@ elif env.has_key('USE_PSPELL') and env['USE_PSPELL']:
|
||||
elif env.has_key('USE_ISPELL') and env['USE_ISPELL']:
|
||||
lyx_source.append('ispell.C')
|
||||
|
||||
env.BuildDir('#$BUILDDIR/common', '$TOP_SRC_DIR/src', duplicate = 0)
|
||||
#
|
||||
# Build lyx with given frontend
|
||||
#
|
||||
lyx = env.Program(
|
||||
target = '#$BUILDDIR/$frontend/lyx',
|
||||
source = ["#$BUILDDIR/common/%s" % x for x in lyx_source],
|
||||
target = '$BUILDDIR/$frontend/lyx',
|
||||
source = ["$BUILDDIR/common/%s" % x for x in lyx_source],
|
||||
LIBS = [
|
||||
'mathed',
|
||||
'insets',
|
||||
@ -1084,4 +1077,17 @@ lyx = env.Program(
|
||||
env['EXTRA_LIBS'] +
|
||||
env['SYSTEM_LIBS']
|
||||
)
|
||||
Alias('lyx', lyx)
|
||||
|
||||
env.fileCopy('$BUILDDIR/lyx$frontend', '$BUILDDIR/$frontend/lyx')
|
||||
|
||||
# other targets include client, tex2lyx
|
||||
Default('lyx')
|
||||
|
||||
Alias('install', env.installProg(Dir(env['BIN_DIR']),
|
||||
[lyx, tex2lyx, lyxclient]))
|
||||
## Alias('install', env.installProg(Dir(os.path.join(env['PREFIX'], 'share/lyx/')),
|
||||
## [Dir(env.subst('$TOP_SRC_DIR/lib/') + dir) for dir in ['images', 'layouts', 'scripts', 'templates', \
|
||||
## 'examples', 'kbd', 'lyx2lyx', 'tex', 'clipart', 'doc', 'ui'] ] + \
|
||||
## [File(env.subst('$TOP_SRC_DIR/lib/') + file) for file in ['configure.py', 'encodings', 'chkconfig.ltx', 'CREDITS', \
|
||||
## 'external_templates', 'symbols', 'languages', 'lyxrc.example', 'syntax.default']]))
|
||||
|
@ -12,19 +12,28 @@
|
||||
# This is a scons based building system for lyx, you can use it as follows:
|
||||
# (after of course installation of scons from www.scons.org)
|
||||
#
|
||||
# scons [frontend=qt3|gt4] [boost=included|auto] ...
|
||||
# $ cd development/scons
|
||||
# $ scons [options] [targets]
|
||||
# or:
|
||||
# $ scons -f development/scons/SConstruct [options] [targets]
|
||||
#
|
||||
# After compiling, you can install lyx by
|
||||
# $ scons [prefix=.] install
|
||||
#
|
||||
# Where:
|
||||
# * use scons -h for details about parameters
|
||||
# * targets can be one or more of lyx, tex2lyx, client, default to lyx
|
||||
# * options: use scons -h for details about parameters, the most important
|
||||
# one is frontend=qt3|qt4.
|
||||
# * qt3 is used by default on linux, cygwin and mac
|
||||
# * qt4 is used by default on win32
|
||||
# * qt4 is used by default on win32/mingw
|
||||
#
|
||||
# File layouts (Important):
|
||||
# * Unless you specify builddir=dir, building will happen
|
||||
# in $BUILDDIR = $mode/$platform-$frontend. E.g., something like
|
||||
# debug/linux-qt3/
|
||||
# * All shared libs will be put in $BUILDDIR/libs, e.g.
|
||||
# debug/linux-qt3/libs
|
||||
# in $BUILDDIR = $mode, which can be debug or release
|
||||
# * $BUILDDIR has subdirectories
|
||||
# libs: all intermediate libraries
|
||||
# boost: boost libraries, if boost=included is used
|
||||
# qt3: build result
|
||||
# * lyx executable will be in directories like debug/linux-qt3
|
||||
#
|
||||
# Hints:
|
||||
@ -79,8 +88,16 @@ EnsurePythonVersion(1, 5)
|
||||
# Please use at least 0.96.91 (not 0.96.1)
|
||||
EnsureSConsVersion(0, 96)
|
||||
|
||||
# I am in TOP_SRC_DIR/developement/scons
|
||||
TOP_SRC_DIR = '../..'
|
||||
# determine where I am ...
|
||||
#
|
||||
# called as 'scons -f development/scons/SConstruct'
|
||||
if os.path.isfile('SConstruct'):
|
||||
TOP_SRC_DIR = '../..'
|
||||
SCONS_DIR = '.'
|
||||
# called as 'cd development/scons; scons'
|
||||
else:
|
||||
TOP_SRC_DIR = '.'
|
||||
SCONS_DIR = 'development/scons'
|
||||
|
||||
#----------------------------------------------------------
|
||||
# Global definitions
|
||||
@ -232,10 +249,10 @@ opts.AddOptions(
|
||||
BoolOption('nls', '(NA) Whether or not use native language support', False),
|
||||
# FIXME: not implemented
|
||||
BoolOption('profile', '(NA) Whether or not enable profiling', False),
|
||||
# FIXME: not implemented
|
||||
PathOption('prefix', '(NA) install architecture-independent files in PREFIX', '.'),
|
||||
# FIXME: not implemented
|
||||
PathOption('exec_prefix', '(NA) install architecture-independent executable files in PREFIX', '.'),
|
||||
#
|
||||
PathOption('prefix', 'install architecture-independent files in PREFIX', '.'),
|
||||
#
|
||||
PathOption('exec_prefix', 'install architecture-independent executable files in PREFIX', '.'),
|
||||
# FIXME: not implemented
|
||||
BoolOption('std_debug', '(NA) Whether or not turn on stdlib debug', False),
|
||||
# using x11?
|
||||
@ -270,14 +287,17 @@ use_X11 = ARGUMENTS.get('X11', default_with_x)
|
||||
# Setting up environment
|
||||
#---------------------------------------------------------
|
||||
|
||||
env = Environment(
|
||||
options = opts
|
||||
)
|
||||
env = Environment(options = opts)
|
||||
|
||||
# set environment since I do not really like ENV = os.environ
|
||||
#env['ENV']['PATH'] = os.environ.get('PATH')
|
||||
env['ENV']['PATH'] = os.environ.get('PATH')
|
||||
env['ENV']['HOME'] = os.environ.get('HOME')
|
||||
env['TOP_SRC_DIR'] = TOP_SRC_DIR
|
||||
env['SCONS_DIR'] = SCONS_DIR
|
||||
# install to current directory by default
|
||||
env['PREFIX'] = ARGUMENTS.get('prefix', '.')
|
||||
env['BIN_DIR'] = ARGUMENTS.get('exec_prefix',
|
||||
os.path.join(env['PREFIX'], 'bin'))
|
||||
|
||||
# speed up source file processing
|
||||
#env['CPPSUFFIXES'] = ['.C', '.cc', '.cpp']
|
||||
@ -322,10 +342,10 @@ if ARGUMENTS.has_key('build_dir'):
|
||||
env['BUILDDIR'] = build_dir
|
||||
else:
|
||||
# Determine the name of the build (platform+frontend
|
||||
env['BUILDDIR'] = env['mode']
|
||||
env['BUILDDIR'] = '#' + env['mode']
|
||||
# all built libraries will go to build_dir/libs
|
||||
# (This is different from the make file approach)
|
||||
env['LOCALLIBPATH'] = '#$BUILDDIR/libs'
|
||||
env['LOCALLIBPATH'] = '$BUILDDIR/libs'
|
||||
env.AppendUnique(LIBPATH = ['$LOCALLIBPATH'])
|
||||
|
||||
#
|
||||
@ -771,6 +791,9 @@ else:
|
||||
env['BUILDERS']['substFile'] = Builder(action = utils.env_subst)
|
||||
# FIXME: there must be a better way.
|
||||
env['BUILDERS']['fileCopy'] = Builder(action = utils.env_filecopy)
|
||||
# install
|
||||
env['BUILDERS']['installProg'] = Builder(action = utils.env_installProg)
|
||||
env['BUILDERS']['installFile'] = Builder(action = utils.env_installFile)
|
||||
|
||||
#
|
||||
# A Link script for cygwin see
|
||||
@ -874,11 +897,6 @@ SConsignFile(os.path.abspath('%s/sconsign' % env['BUILDDIR']))
|
||||
|
||||
print "Building all targets recursively"
|
||||
|
||||
# Now, specification of targets is difficult
|
||||
# we can do this though:
|
||||
#
|
||||
env['BUILD_TARGETS'] = BUILD_TARGETS
|
||||
|
||||
env.SConscript('SConscript', duplicate = 0)
|
||||
env.SConscript('$SCONS_DIR/SConscript', duplicate = 0)
|
||||
|
||||
|
||||
|
@ -329,8 +329,6 @@ def processLang(env, folder):
|
||||
if not languages or country in languages:
|
||||
result = env.Transfiles(file)
|
||||
# FIXME
|
||||
# dir=env.join( getInstDirForResType(env, 'KDELOCALE'), country)
|
||||
# env.bksys_install(env.join(dir, 'LC_MESSAGES'), result, destfile=appname+'.mo')
|
||||
|
||||
|
||||
def installCygwinLDScript(path):
|
||||
@ -619,40 +617,48 @@ def setLoggedSpawn(env, logfile = '', longarg=False, info=''):
|
||||
# replace the old SPAWN by the new function
|
||||
env['SPAWN'] = ls.spawn
|
||||
|
||||
#
|
||||
# Install program with permission
|
||||
# http://www.scons.org/cgi-sys/cgiwrap/scons/moin.cgi/InstallTargets
|
||||
#
|
||||
import SCons
|
||||
from SCons.Script.SConscript import SConsEnvironment
|
||||
|
||||
SConsEnvironment.Chmod = SCons.Action.ActionFactory(os.chmod,
|
||||
lambda dest, mode: 'Chmod("%s", 0%o)' % (dest, mode))
|
||||
|
||||
def installPerm(target, source, env, perm):
|
||||
''' install program with permission, will copy
|
||||
files recursively if needed '''
|
||||
# FIXME: mixed use of scons and python interfaces?
|
||||
target_dir = str(target[0])
|
||||
if os.path.isfile(target_dir):
|
||||
print "Target should be a directory: ", target_dir
|
||||
return
|
||||
if not os.path.isdir(target_dir):
|
||||
os.makedirs(target_dir)
|
||||
objs = []
|
||||
for fnode in source:
|
||||
fname = str(fnode)
|
||||
print "Installing", fname, "to", target_dir
|
||||
if os.path.isfile(fname):
|
||||
objs.append(os.path.join(target_dir, fname))
|
||||
shutil.copy(fname, target_dir)
|
||||
elif os.path.isdir(fname):
|
||||
# FIXME: directory permission is not set
|
||||
if os.path.isdir(os.path.join(target_dir, fname)):
|
||||
shutil.rmtree(os.path.join(target_dir, fname))
|
||||
shutil.copytree(fname, target_dir)
|
||||
#for i in objs:
|
||||
# env.AddPostAction(File(i), env.Chmod(i, perm))
|
||||
return target
|
||||
|
||||
def env_installProg(target, source, env):
|
||||
installPerm(target, source, env, 0755)
|
||||
|
||||
def env_installFile(target, source, env):
|
||||
installPerm(target, source, env, 0644)
|
||||
|
||||
## def CheckPython(context, minver):
|
||||
## context.Message('Checking for Python >= %s...' % '.'.join(str(x) for x in minver))
|
||||
## try:
|
||||
## python = context.env['PYTHON']
|
||||
## except KeyError:
|
||||
## try:
|
||||
## python = os.environ['PYTHON']
|
||||
## except KeyError:
|
||||
## python = WhereIs("python")
|
||||
## if not python:
|
||||
## python = python = WhereIs("python%i.%i" % (minver[0], minver[1]))
|
||||
## minverhex = 0
|
||||
## minver = list(minver) + [0, 0, 0, 0]
|
||||
## for i in xrange(0, 4):
|
||||
## minverhex = (minverhex << 8) + minver[i]
|
||||
## prog = "import sys; sys.exit(sys.hexversion >= %s)" % minverhex
|
||||
## if python is None:
|
||||
## python = 'python'
|
||||
## try:
|
||||
## result = Popen([python, "-c", prog]).wait()
|
||||
## except OSError:
|
||||
## context.Result(False)
|
||||
## return False
|
||||
## context.Result(result)
|
||||
## if result:
|
||||
## context.env.Replace(PYTHON=python)
|
||||
## proc = Popen([python, "-c", "import sys; print sys.version[:3]"], stdout=PIPE)
|
||||
## pyver = proc.communicate()[0].rstrip()
|
||||
## context.env.Replace(PYTHON_VERSION=pyver)
|
||||
## context.env.Replace(pythondir="$prefix/lib/python$PYTHON_VERSION/site-packages")
|
||||
## context.env.Replace(pyexecdir="${exec_prefix}/lib/python$PYTHON_VERSION/site-packages")
|
||||
## return result
|
||||
##
|
||||
## def DistSources(env, node):
|
||||
## env.DistFiles(_get_sources(env, node))
|
||||
##
|
||||
|
Loading…
Reference in New Issue
Block a user