Scons: remove pch, add stdlib_debug and profiling options

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@14188 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Bo Peng 2006-06-24 03:49:11 +00:00
parent 331e78d3e0
commit de064bd88a

View File

@ -14,7 +14,7 @@
import os, sys, copy, cPickle, glob import os, sys, copy, cPickle, glob
# config/scons_utils.py defines a few utility function # scons_utils.py defines a few utility function
sys.path.append('config') sys.path.append('config')
import scons_utils as utils import scons_utils as utils
@ -29,11 +29,11 @@ EnsureSConsVersion(0, 96)
# determine where I am ... # determine where I am ...
# #
# called as 'scons -f development/scons/SConstruct' # called as 'cd development/scons; scons'
if os.path.isfile('SConstruct'): if os.path.isfile('SConstruct'):
top_src_dir = '../..' top_src_dir = '../..'
scons_dir = '.' scons_dir = '.'
# called as 'cd development/scons; scons' # called as 'scons -f development/scons/SConstruct'
else: else:
top_src_dir = '.' top_src_dir = '.'
scons_dir = 'development/scons' scons_dir = 'development/scons'
@ -115,7 +115,7 @@ if os.path.isfile('config.py'):
opts = Options(['config.py']) opts = Options(['config.py'])
opts.AddOptions( opts.AddOptions(
# frontend, # frontend
EnumOption('frontend', 'Main GUI', default_frontend, EnumOption('frontend', 'Main GUI', default_frontend,
allowed_values = ('xform', 'qt2', 'qt3', 'qt4', 'gtk') ), allowed_values = ('xform', 'qt2', 'qt3', 'qt4', 'gtk') ),
# debug or release build # debug or release build
@ -145,21 +145,22 @@ opts.AddOptions(
allowed_values = ('windows', 'posix', 'macosx')), allowed_values = ('windows', 'posix', 'macosx')),
# #
BoolOption('fast_start', 'Whether or not use cached tests and keep current config.h', True), BoolOption('fast_start', 'Whether or not use cached tests and keep current config.h', True),
# # No precompiled header support (too troublesome to make it work for msvc)
BoolOption('pch', 'Whether or not use pch', False), # BoolOption('pch', 'Whether or not use pch', False),
# enable assertion, (config.h has ENABLE_ASSERTIOS # enable assertion, (config.h has ENABLE_ASSERTIOS
BoolOption('assertions', 'Use assertions', True), BoolOption('assertions', 'Use assertions', True),
# enable warning, (config.h has WITH_WARNINGS) # enable warning, (config.h has WITH_WARNINGS)
# default to False since MSVC does not have #warning # default to False since MSVC does not have #warning
BoolOption('warnings', 'Use warnings', False), BoolOption('warnings', 'Use warnings', False),
# enable glib, (config.h has _GLIBCXX_CONCEPT_CHECKS) # config.h define _GLIBCXX_CONCEPT_CHECKS
# Note: for earlier version of gcc (3.3) define _GLIBCPP_CONCEPT_CHECKS
BoolOption('concept_checks', 'Enable concept checks', True), BoolOption('concept_checks', 'Enable concept checks', True),
# #
BoolOption('nls', 'Whether or not use native language support', True), BoolOption('nls', 'Whether or not use native language support', True),
# FIXME: not implemented #
BoolOption('profile', '(NA) Whether or not enable profiling', False), BoolOption('profiling', 'Whether or not enable profiling', False),
# FIXME: not implemented # config.h define _GLIBCXX_DEBUG and _GLIBCXX_DEBUG_PEDANTIC
BoolOption('std_debug', '(NA) Whether or not turn on stdlib debug', False), BoolOption('stdlib_debug', 'Whether or not turn on stdlib debug', False),
# using x11? # using x11?
BoolOption('X11', 'Use x11 windows system', default_with_x), BoolOption('X11', 'Use x11 windows system', default_with_x),
# use MS VC++ to build lyx # use MS VC++ to build lyx
@ -310,7 +311,6 @@ env['ENV']['INCLUDE'] = os.environ.get('INCLUDE')
frontend = env['frontend'] frontend = env['frontend']
prefix = env['prefix'] prefix = env['prefix']
mode = env['mode'] mode = env['mode']
use_pch = env['pch']
if platform_name == 'win32': if platform_name == 'win32':
if env.has_key('use_vc'): if env.has_key('use_vc'):
@ -445,10 +445,6 @@ else:
env['CC'] = 'g++' env['CC'] = 'g++'
env['LINK'] = 'g++' env['LINK'] = 'g++'
# only support gcc now
if use_pch and not use_vc:
CCFLAGS_required.extend(['-Winvalid-pch'])
# for debug/release mode # for debug/release mode
if env.has_key('optimization') and env['optimization'] is not None: if env.has_key('optimization') and env['optimization'] is not None:
# if user supplies optimization flags, use it anyway # if user supplies optimization flags, use it anyway
@ -464,13 +460,29 @@ if mode == 'debug':
LINKFLAGS_required.extend(['/debug', '/map']) LINKFLAGS_required.extend(['/debug', '/map'])
else: else:
CCFLAGS_required.append('-g') CCFLAGS_required.append('-g')
CCFLAGS_default.extend(['-Wall', '-O']) CCFLAGS_default.append('-O')
elif mode == 'release' and set_default_optimization_flags: elif mode == 'release' and set_default_optimization_flags:
if use_vc: if use_vc:
CCFLAGS_default.append('/O2') CCFLAGS_default.append('/O2')
else: else:
CCFLAGS_default.append('-O2') CCFLAGS_default.append('-O2')
# msvc uses separate tools for profiling
if env.has_key('profiling') and env['profiling']:
if use_vc:
print 'Visual C++ does not use profiling options'
else:
CCFLAGS_required.append('-pg')
LINKFLAGS_required.append('-pg')
if env.has_key('warnings') and env['warnings']:
if use_vc:
CCFLAGS_default.append('/W2')
else:
# Note: autotools detect gxx version and pass -W for 3.x
# and -Wextra for other versions of gcc
CCFLAGS_default.append('-Wall')
# Now, set the variables as follows: # Now, set the variables as follows:
# 1. if command line option exists: replace default # 1. if command line option exists: replace default
# 2. then if s envronment variable exists: replace default # 2. then if s envronment variable exists: replace default
@ -987,6 +999,14 @@ int count()
'_GLIBCXX_CONCEPT_CHECKS', '_GLIBCXX_CONCEPT_CHECKS',
'libstdc++ concept checking' 'libstdc++ concept checking'
), ),
(env.has_key('stdlib_debug') and env['stdlib_debug'],
'_GLIBCXX_DEBUG',
'libstdc++ debug mode'
),
(env.has_key('stdlib_debug') and env['stdlib_debug'],
'_GLIBCXX_DEBUG_PEDANTIC',
'libstdc++ pedantic debug mode'
),
(os.name != 'nt', 'BOOST_POSIX', (os.name != 'nt', 'BOOST_POSIX',
'Indicates to boost which API to use (posix or windows).' 'Indicates to boost which API to use (posix or windows).'
), ),
@ -1152,17 +1172,6 @@ env['CPPPATH'].remove(qt_inc_path)
# #
# install customized builders # install customized builders
env['BUILDERS']['substFile'] = Builder(action = utils.env_subst) env['BUILDERS']['substFile'] = Builder(action = utils.env_subst)
if use_pch and not use_vc:
env['CCPCHFLAGS'] = '-x c++-header'
env['BUILDERS']['PCH'] = Builder(
action = '$CXX $CPPFLAGS $_CPPDEFFLAGS $_CPPINCFLAGS $CCPCHFLAGS $SOURCES -o $TARGET',
suffix = '.h.pch', src_suffix = '.h'
)
else:
# do nothing
def emptyTarget(target, source, env):
return [], source
env['BUILDERS']['PCH'] = Builder(action = '', emitter = emptyTarget)
# #
# A Link script for cygwin see # A Link script for cygwin see
@ -1547,12 +1556,10 @@ if build_mathed:
# src/mathed # src/mathed
# #
print "Processing files in src/mathed..." print "Processing files in src/mathed..."
env['PCH_H'] = '$TOP_SRCDIR/src/mathed/pch.h'
env['PCH_FILE'] = env.PCH(env['PCH_H'])
# #
mathed = env.StaticLibrary( mathed = env.StaticLibrary(
target = '$LOCALLIBPATH/mathed', target = '$LOCALLIBPATH/mathed',
source = env['PCH_FILE'] + utils.globSource(dir = env.subst('$TOP_SRCDIR/src/mathed'), source = utils.globSource(dir = env.subst('$TOP_SRCDIR/src/mathed'),
pattern = lyx_ext, pattern = lyx_ext,
exclude = ['math_xyarrowinset.C', 'math_mboxinset.C', 'formulamacro.C'], exclude = ['math_xyarrowinset.C', 'math_mboxinset.C', 'formulamacro.C'],
build_dir = '$BUILDDIR/common/mathed') build_dir = '$BUILDDIR/common/mathed')