summaryrefslogtreecommitdiffstats
path: root/build/SConscript.main
diff options
context:
space:
mode:
Diffstat (limited to 'build/SConscript.main')
-rw-r--r--build/SConscript.main752
1 files changed, 365 insertions, 387 deletions
diff --git a/build/SConscript.main b/build/SConscript.main
index 275df6d3..43477b2 100644
--- a/build/SConscript.main
+++ b/build/SConscript.main
@@ -7,6 +7,27 @@ import shutil
import sys
+
+# Overlay things from a layer below.
+Dir('base').addRepository(Dir('../base'))
+Dir('breakpad').addRepository(Dir('../breakpad'))
+Dir('gears').addRepository(Dir('../gears'))
+Dir('net').addRepository(Dir('../net'))
+Dir('rlz').addRepository(Dir('../rlz'))
+Dir('sandbox').addRepository(Dir('../sandbox'))
+Dir('skia').addRepository(Dir('../skia'))
+Dir('sdch').addRepository(Dir('../sdch'))
+Dir('testing').addRepository(Dir('../testing'))
+Dir('third_party').addRepository(Dir('../third_party'))
+Dir('webkit').addRepository(Dir('../webkit'))
+
+# This one is somewhat special.
+Dir('../build').addRepository(Dir('../googleurl'))
+
+
+#-----------------------------------------------------------------------
+
+
p = ARGUMENTS.get('PROGRESS')
if p == 'spinner':
Progress(['/\r', '|\r', '\\\r', '-\r'], interval=5, file=open('con', 'w'))
@@ -25,18 +46,17 @@ else:
load = []
-env = Environment(
- BUILD_TYPE = ARGUMENTS.get('BUILD_TYPE', 'Hammer'),
- TARGET_ROOT = '#/$BUILD_TYPE',
- OBJ_ROOT = '$TARGET_ROOT',
-
- LIBS_DIR = '#/$BUILD_TYPE/Libs',
+base_env = Environment(tools = ['component_setup'])
+base_env.Replace(
+ # $MAIN_DIR refers to the directory in which the SConstruct lives.
+ # $ROOT_DIR is src/
+ ROOT_DIR = '$MAIN_DIR/..',
- BASE_DIR = '#/$BUILD_TYPE/base',
- BREAKPAD_DIR = '#/$BUILD_TYPE/breakpad',
- CHROME_DIR = '#/$BUILD_TYPE/chrome',
- GEARS_DIR = '#/$BUILD_TYPE/gears',
- GOOGLE_UPDATE_DIR = '#/$BUILD_TYPE/google_update',
+ BASE_DIR = '$ROOT_DIR/base',
+ BREAKPAD_DIR = '$ROOT_DIR/breakpad',
+ CHROME_DIR = '$ROOT_DIR/chrome',
+ GEARS_DIR = '$ROOT_DIR/gears',
+ GOOGLE_UPDATE_DIR = '$ROOT_DIR/google_update',
# Work around a limitation (bug?) in SCons in that, when we build
# from a different directory, it forces the build targets defined
@@ -45,18 +65,18 @@ env = Environment(
# the SConstruct directory from which SCons was launched. When
# we roll forward to a version of SCons that fixes this, we'll
# need to revert to the $BUILD_TYPE definition of GOOGLEURL_DIR.
- #GOOGLEURL_DIR = '#/$BUILD_TYPE/googleurl',
- GOOGLEURL_DIR = '#/../build/googleurl',
-
- NET_DIR = '#/$BUILD_TYPE/net',
- RLZ_DIR = '#/$BUILD_TYPE/rlz',
- SANDBOX_DIR = '#/$BUILD_TYPE/sandbox',
- SDCH_DIR = '#/$BUILD_TYPE/sdch',
- SKIA_DIR = '#/$BUILD_TYPE/skia',
- TESTING_DIR = '#/$BUILD_TYPE/testing',
- THIRD_PARTY_DIR = '#/$BUILD_TYPE/third_party',
- V8_DIR = '#/$BUILD_TYPE/v8',
- WEBKIT_DIR = '#/$BUILD_TYPE/webkit',
+
+ GOOGLEURL_DIR = '$ROOT_DIR/build/googleurl',
+
+ NET_DIR = '$ROOT_DIR/net',
+ RLZ_DIR = '$ROOT_DIR/rlz',
+ SANDBOX_DIR = '$ROOT_DIR/sandbox',
+ SDCH_DIR = '$ROOT_DIR/sdch',
+ SKIA_DIR = '$ROOT_DIR/skia',
+ TESTING_DIR = '$ROOT_DIR/testing',
+ THIRD_PARTY_DIR = '$OBJ_ROOT/third_party',
+ V8_DIR = '$ROOT_DIR/v8',
+ WEBKIT_DIR = '$OBJ_ROOT/webkit',
GTEST_DIR = '$TESTING_DIR/gtest',
@@ -71,14 +91,51 @@ env = Environment(
LIBXSLT_DIR = '$THIRD_PARTY_DIR/libxslt',
LZMA_SDK_DIR = '$THIRD_PARTY_DIR/lzma_sdk',
MODP_B64_DIR = '$THIRD_PARTY_DIR/modp_b64',
- NPAPI_DIR = '$THIRD_PARTY_DIR/npapi',
+ NPAPI_DIR = '$ROOT_DIR/third_party/npapi',
ZLIB_DIR = '$THIRD_PARTY_DIR/zlib',
- THIRD_PARTY_WEBKIT_DIR = '$THIRD_PARTY_DIR/WebKit',
+ THIRD_PARTY_WEBKIT_DIR = '$ROOT_DIR/third_party/WebKit',
PYTHON=sys.executable,
- LIBPATH = ['$LIBS_DIR'],
+ # This is temporarily in flux.
+ # Currently these are all relative to src/build, with the additional,
+ # wrinkle that several addRepository lines at the top of this file cause
+ # everything in src to be conceptually underlayed in src/build.
+ # Thus things like src/SConscript.googleurl are listed directly,
+ # but things like base/SConscript are down a layer.
+ # Some of this will hopefully get cleaner if we move the SConstruct up a
+ # layer.
+ BUILD_SCONSCRIPTS = [
+ 'base/SConscript',
+ 'breakpad/SConscript',
+ #'chrome/SConscript',
+ #'gears/SConscript',
+ #'google_update_dir/SConscript',
+ 'SConscript.googleurl',
+ 'net/SConscript',
+ 'rlz/SConscript',
+ 'sandbox/src/SConscript',
+ 'sdch/SConscript',
+ 'skia/SConscript',
+
+ 'testing/SConscript.gtest',
+
+ 'third_party/bsdiff/SConscript',
+ 'third_party/bzip2/SConscript',
+ 'third_party/icu38/SConscript',
+ 'third_party/libpng/SConscript',
+ 'third_party/lzma_sdk/SConscript',
+ 'third_party/modp_b64/SConscript',
+ 'third_party/zlib/SConscript',
+
+ 'third_party/libjpeg/SConscript',
+ 'third_party/libxml/SConscript',
+ 'third_party/libxslt/SConscript',
+
+ 'SConscript.v8',
+ 'webkit/SConscript',
+ ],
PERL = 'perl',
PERL_INCLUDE_FLAG = '-I ',
@@ -89,87 +146,62 @@ env = Environment(
'__env__, RDirs, TARGET, SOURCE)}'),
)
-def AddPdbToTarget(args):
- """Add the windows pdb file to the build target.
-
- Arguments:
- args is a tuple passed to ChromeProgram or ChromeTestProgram
- Returns:
- A tuple to pass on to Environment.Program."""
- # Only add .pdb to the target if the target was only a string. We can't
- # blindly add foo.pdb because chrome.exe and chrome.dll use chrome_exe.pdb
- # and chrome_dll.pdb.
- if not isinstance(args[0], str):
- return args
-
- mutable_args = list(args)
- mutable_args[0] = [args[0], args[0] + '.pdb']
- return tuple(mutable_args)
-
def ChromeProgram(env, *args, **kw):
- if env['PLATFORM'] == 'win32':
- # TODO(tc): We should handle kw['target'] too.
- args = AddPdbToTarget(args)
- return env.Program(*args, **kw)
-env.AddMethod(ChromeProgram, "ChromeProgram")
+ return env.ComponentProgram(*args, **kw)
+base_env.AddMethod(ChromeProgram)
def ChromeTestProgram(env, *args, **kw):
- if env['PLATFORM'] == 'win32':
- # TODO(tc): We should handle kw['target'] too.
- args = AddPdbToTarget(args)
- return env.Program(*args, **kw)
-env.AddMethod(ChromeTestProgram, "ChromeTestProgram")
+ return env.ComponentTestProgram(*args, **kw)
+base_env.AddMethod(ChromeTestProgram)
def ChromeStaticLibrary(env, *args, **kw):
- result = env.StaticLibrary(*args, **kw)
- if env['PLATFORM'] == 'win32':
- # TODO(sgk):
- # We'd like to do this with env.Install() like we do on other systems,
- # but this causes problems on Windows when the Python copy of the file
- # in one thread prevents a linker spawned by another thread from
- # opening the copied .lib, despite the fact that the copy has
- # successfully concluded before the spawn occurs. Work around the
- # underlying problem (whatever it is) by calling the external Windows
- # xcopy utility.
- env.Command('$LIBS_DIR/${RESULT.name}', '$RESULT',
- "xcopy /q /y $SOURCE ${TARGET.dir}",
- RESULT=result[0])
- else:
- env.Install('$LIBS_DIR', result)
- return result
-env.AddMethod(ChromeStaticLibrary, "ChromeStaticLibrary")
+ kw['COMPONENT_STATIC'] = True
+ return env.ComponentLibrary(*args, **kw)
+base_env.AddMethod(ChromeStaticLibrary)
def ChromeSharedLibrary(env, *args, **kw):
- return env.SharedLibrary(*args, **kw)
-env.AddMethod(ChromeSharedLibrary, "ChromeSharedLibrary")
+ kw['COMPONENT_STATIC'] = False
+ return env.ComponentLibrary(*args, **kw)
+base_env.AddMethod(ChromeSharedLibrary)
+
+def ChromeObject(env, *args, **kw):
+ return env.ComponentObject(*args, **kw)
+base_env.AddMethod(ChromeObject)
+
+
+if ARGUMENTS.get('VERBOSE') in (None, '0'):
+ base_env['CCCOMSTR'] = 'Compiling $TARGET ...'
+ base_env['CXXCOMSTR'] = 'Compiling $TARGET ...'
+ base_env['SHCCCOMSTR'] = 'Compiling $TARGET ...'
+ base_env['SHCXXCOMSTR'] = 'Compiling $TARGET ...'
+ base_env['ARCOMSTR'] = 'Archiving $TARGET ...'
+ base_env['LINKCOMSTR'] = 'Linking $TARGET ...'
+ base_env['BINDINGSCOMSTR'] = 'Building bindings in $TARGET ...'
+
+
+
-if env['PLATFORM'] == 'win32':
- processors = int(os.environ.get('NUMBER_OF_PROCESSORS', 1))
- SetOption('num_jobs', processors + 1)
- msvs_env = Environment(tools=['msvc', 'mslink', 'msvs'])['ENV']
- # Use the absolute path for MSVC because it might not be on the same drive
- # as our source checkout.
- visual_studio_path = (msvs_env['PATH'][0] +
- ':/Program Files/Microsoft Visual Studio 8')
+#-----------------------------------------------------------------------
- env.Replace(
+
+
+# Create environment from which all Windows variants derive.
+windows_env = base_env.Clone(tools = ['target_platform_windows'])
+windows_env.Replace(
CSCRIPT = 'c:\\Windows\\System32\\cscript',
PLATFORMSDK_VISTA_REL = '../third_party/platformsdk_vista_6_0',
PLATFORMSDK_VISTA = '#/$PLATFORMSDK_VISTA_REL',
- VISUAL_STUDIO = visual_studio_path,
- CYGWIN_DIR = Dir('#../third_party/cygwin'),
+ CYGWIN_DIR = '$MAIN_DIR/../third_party/cygwin',
CYGWIN_BIN_DIR = '$CYGWIN_DIR/bin',
PERL = '$CYGWIN_BIN_DIR/perl.exe',
- MSVS_ENV = msvs_env,
-
YACC = '$CYGWIN_BIN_DIR/bison.exe',
ARFLAGS = [
@@ -222,209 +254,230 @@ if env['PLATFORM'] == 'win32':
'$PLATFORMSDK_VISTA/files/Include',
'$PLATFORMSDK_VISTA/files/VC/INCLUDE',
'$VISUAL_STUDIO/VC/atlmfc/include',
+ '$MAIN_DIR/..',
],
LIBS = [
- 'advapi32.lib',
- 'comdlg32.lib',
- 'gdi32.lib',
- 'kernel32.lib',
- 'msimg32.lib',
- 'odbc32.lib',
- 'odbccp32.lib',
- 'ole32.lib',
- 'oleaut32.lib',
- 'psapi.lib',
- 'shell32.lib',
- 'user32.lib',
- 'usp10.lib',
- 'uuid.lib',
- 'version.lib',
- 'wininet.lib',
- 'winspool.lib',
- 'ws2_32.lib',
-
- 'DelayImp.lib',
+ 'advapi32',
+ 'comdlg32',
+ 'gdi32',
+ 'kernel32',
+ 'msimg32',
+ 'odbc32',
+ 'odbccp32',
+ 'ole32',
+ 'oleaut32',
+ 'psapi',
+ 'shell32',
+ 'user32',
+ 'usp10',
+ 'uuid',
+ 'version',
+ 'wininet',
+ 'winspool',
+ 'ws2_32',
+
+ 'DelayImp',
],
LINKFLAGS = [
'/nologo',
'/DEBUG',
],
-
ICU_LIBS = ['icu'],
)
- env.Append(
+windows_env.Append(
LIBPATH = [
'$PLATFORMSDK_VISTA/files/Lib',
'$PLATFORMSDK_VISTA/files/VC/LIB',
'$VISUAL_STUDIO/VC/atlmfc/lib',
],
- )
+)
- # TODO(sgk): remove once we upgrade to SCons 0.98.4
- for var in ['INCLUDE', 'LIB', 'PATH']:
- msvs_env[var] = msvs_env[var].split('|', 1)[0]
- env['ENV'][var] = env['ENV'][var].split('|', 1)[0]
-
- # Force scons to handle long include lines correctly.
- pchcom_fixed = env['PCHCOM']
- pchcom_fixed = pchcom_fixed.replace('${TARGETS[0]}', '$TARGET')
- pchcom_fixed = pchcom_fixed.replace('${TARGETS[1]}', '$TARGETS1')
-
- env.Replace(
- CCCOM = "${TEMPFILE('%s')}" % env['CCCOM'],
- CXXCOM = "${TEMPFILE('%s')}" % env['CXXCOM'],
- SHCCCOM = "${TEMPFILE('%s')}" % env['SHCCCOM'],
- SHCXXCOM = "${TEMPFILE('%s')}" % env['SHCXXCOM'],
- PCHCOM = "${TEMPFILE('%s')}" % pchcom_fixed,
- TARGETS1 = '${TARGETS[1]}',
- )
+# Remove manifest gunk for now.
+windows_env['LINKCOM'] = windows_env['LINKCOM'][0]
+windows_env['SHLINKCOM'] = windows_env['SHLINKCOM'][0]
- env['ENV']['PROGRAMFILES'] = os.environ['PROGRAMFILES']
- env['ENV']['SystemDrive'] = os.environ['SystemDrive']
- env['ENV']['USERPROFILE'] = os.environ['USERPROFILE']
-
- env.AppendENVPath('PATH', ';C:\\WINDOWS\\system32')
-
-elif env['PLATFORM'] == 'posix':
-
- # Copy some environment variables from the outer environment if they exist.
- for envvar in ['CC', 'CXX']:
- if envvar in os.environ:
- env[envvar] = os.environ[envvar]
- # Provide $HOME when compiling so distcc can find its lock file.
- env['ENV']['HOME'] = os.environ['HOME']
- if 'DISTCC_HOSTS' in os.environ:
- env['ENV']['DISTCC_HOSTS'] = os.environ['DISTCC_HOSTS']
-
- # TODO(evanm): this is Linux-specific, not posix.
- # Parse /proc/cpuinfo for processor count.
- cpus = len([l for l in open('/proc/cpuinfo') if l.startswith('processor\t')])
- SetOption('num_jobs', cpus + 1)
-
- # For now, linux only loads the components we know work on Linux, by default.
- load = [
- 'base',
- 'breakpad',
- 'chrome',
- 'googleurl',
- 'net',
- 'sdch',
- 'skia',
- 'testing',
- 'third_party',
- 'v8',
- 'webkit',
- ]
-
- excluded_warnings = [
+# TODO(sgk): find a more elegant way of doing this.
+if base_env['PLATFORM'] == 'win32':
+ msvs_env = Environment(tools=['msvc', 'mslink', 'msvs'])['ENV']
+ windows_env['VISUAL_STUDIO'] = (msvs_env['PATH'][0] +
+ ':/Program Files/Microsoft Visual Studio 8')
+
+# TODO(bradnelson): find a cleaner way of doing this.
+# Force scons to handle long include lines correctly.
+pchcom_fixed = windows_env['PCHCOM']
+pchcom_fixed = pchcom_fixed.replace('${TARGETS[0]}', '$TARGET')
+pchcom_fixed = pchcom_fixed.replace('${TARGETS[1]}', '$TARGETS1')
+
+windows_env.Replace(
+ CCCOM = "${TEMPFILE('%s')}" % windows_env['CCCOM'],
+ CXXCOM = "${TEMPFILE('%s')}" % windows_env['CXXCOM'],
+ SHCCCOM = "${TEMPFILE('%s')}" % windows_env['SHCCCOM'],
+ SHCXXCOM = "${TEMPFILE('%s')}" % windows_env['SHCXXCOM'],
+ PCHCOM = "${TEMPFILE('%s')}" % pchcom_fixed,
+ TARGETS1 = '${TARGETS[1]}',
+)
+
+# Create a debug windows variant.
+debug_win_env = windows_env.Clone(tools = ['target_debug'])
+debug_win_env.Replace(
+ BUILD_TYPE = 'debug-win',
+ BUILD_TYPE_DESCRIPTION = 'Windows debug variant',
+ BUILD_GROUPS = ['default'],
+)
+
+# Create an optimized windows variant.
+release_win_env = windows_env.Clone(tools = ['target_optimized'])
+release_win_env.Replace(
+ BUILD_TYPE = 'release-win',
+ BUILD_TYPE_DESCRIPTION = 'Windows release variant',
+)
+
+
+#-----------------------------------------------------------------------
+
+
+
+excluded_warnings = [
# TODO: Clean up uses of ext/hash_map and remove this.
# (see unordered_map and base/hash_tables.h)
- '-Wno-deprecated', # Needed for using ext/hash_map on GCC 4.3
- '-Wno-unknown-pragmas', # In wtf's ref counting system
- ]
- env.Replace(
- CCFLAGS = ['-m32', '-g', '-pthread'],
- CXXFLAGS = ['-Wall', '-Werror'] + excluded_warnings,
- LINKFLAGS = ['-m32', '-pthread'],
+ '-Wno-deprecated' # Needed for using ext/hash_map on GCC 4.3
+]
+
+# Create the base linux environment.
+linux_env = base_env.Clone(tools = ['target_platform_linux'])
+linux_env.Replace(
+ CCFLAGS = ['-m32', '-g', '-pthread'],
+ CXXFLAGS = ['-Wall', '-Werror'] + excluded_warnings,
+ LINKFLAGS = ['-m32', '-pthread'],
# We need rt for clock_gettime.
- LIBS = ['rt'],
+ LIBS = ['rt'],
+ ICU_LIBS = ['icu'],
- PERL = '/usr/bin/perl',
- PERL_INCLUDE_FLAG = '-I ',
- PERL_INCLUDE_SUFFIX = '',
- _PERL_INCLUDE_FLAGS = ('${_concat(PERL_INCLUDE_FLAG, '
- 'PERL_INCLUDE_PATH, '
- 'PERL_INCLUDE_SUFFIX,'
- '__env__, RDirs, TARGET, SOURCE)}'),
+ PERL = '/usr/bin/perl',
+ PERL_INCLUDE_FLAG = '-I ',
+ PERL_INCLUDE_SUFFIX = '',
+ _PERL_INCLUDE_FLAGS = ('${_concat(PERL_INCLUDE_FLAG, '
+ 'PERL_INCLUDE_PATH, '
+ 'PERL_INCLUDE_SUFFIX,'
+ '__env__, RDirs, TARGET, SOURCE)}'),
+)
- ICU_LIBS = ['icu'],
- )
- # Build with support for gcov when COVERAGE=1.
- if ARGUMENTS.get('COVERAGE') == '1':
- env.Append(CCFLAGS=['-fprofile-arcs', '-ftest-coverage'])
- env.Append(LINKFLAGS=['-fprofile-arcs'])
-
- # Build with system-provided NSS and GTK.
- env.ParseConfig('pkg-config --cflags --libs nss')
- env.ParseConfig('pkg-config --cflags --libs gtk+-2.0')
-
-elif env['PLATFORM'] == 'darwin':
-
- # For now, mac only loads the components we know work on Mac, by default.
- load = [
- 'base',
- #'breakpad',
- 'googleurl',
- 'net',
- 'sdch',
- 'skia',
- 'testing',
- 'third_party',
- #'webkit',
- ]
-
- env.Replace(
- # Reproduce XCode's behavior of using gcc even to link C++,
- # and distinguishing it the -x c++ option.
- CC = 'gcc-4.2',
- CXX = 'g++-4.2',
- LINK = '$CXX',
-
- CFLAGS = [
- '-std=c99',
- ],
- CXXFLAGS = [
- '-fvisibility-inlines-hidden',
- '${str(SOURCE).endswith(".mm") and "-fobjc-gc" or ""}',
- ],
- CCFLAGS = [
- '-fmessage-length=0',
- '-pipe',
- '-O0',
- '-mdynamic-no-pic',
- '-Werror',
- '-Wnewline-eof',
- '-fvisibility=hidden',
- '-gdwarf-2',
- '-Wall',
- '-Wendif-labels',
- '-fstack-protector',
- '-fstack-protector-all',
- ],
- CPPDEFINES = [
- 'DEBUG',
- ],
-
- FRAMEWORKPATH = [
- env.Dir('${TARGET_ROOT}'),
- '/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks',
- ],
- FRAMEWORKS = [
- 'AppKit',
- 'ApplicationServices',
- 'Foundation',
- ],
-
- ICU_LIBS = ['icui18n', 'icuuc', 'icudata'],
- )
+# This conflicts with build_config.h
+linux_env.FilterOut(CPPDEFINES= ['OS_LINUX=OS_LINUX'])
+
+linux_env.FilterOut(
+ BUILD_SCONSCRIPTS = [
+ 'sandbox/src/SConscript',
+ 'third_party/libjpeg/SConscript',
+ 'third_party/libxml/SConscript',
+ 'third_party/libxslt/SConscript',
+ 'third_party/bspatch/SConscript',
+ 'webkit/SConscript',
+ ],
+)
-else:
+linux_env.Append(
+ BUILD_SCONSCRIPTS = [
+ 'third_party/libevent/SConscript',
+ ],
+)
+
+# Build with support for gcov when COVERAGE=1.
+if ARGUMENTS.get('COVERAGE') == '1':
+ linux_env.Append(CCFLAGS=['-fprofile-arcs', '-ftest-coverage'])
+ linux_env.Append(LINKFLAGS=['-fprofile-arcs'])
+
+# Build with system-provided NSS
+if base_env['PLATFORM'] in ['posix', 'linux', 'linux2']:
+ linux_env.ParseConfig('pkg-config --cflags --libs nss')
+ linux_env.ParseConfig('pkg-config --cflags --libs glib-2.0')
+ linux_env.ParseConfig('pkg-config --cflags --libs gtk+-2.0')
+
+# Create a debug linux variant.
+debug_linux_env = linux_env.Clone(tools = ['target_debug'])
+debug_linux_env.Replace(
+ BUILD_TYPE = 'debug-linux',
+ BUILD_TYPE_DESCRIPTION = 'Linux debug variant',
+ BUILD_GROUPS = ['default'],
+)
- print "Unsupported SCons $PLATFORM value %s" % repr(env['PLATFORM'])
- Exit(1)
+# Create a optimized linux variant.
+release_linux_env = linux_env.Clone(tools = ['target_optimized'])
+release_linux_env.Replace(
+ BUILD_TYPE = 'release-linux',
+ BUILD_TYPE_DESCRIPTION = 'Linux release variant',
+)
+
+
+
+
+#-----------------------------------------------------------------------
-if ARGUMENTS.get('VERBOSE') in (None, '0'):
- env['CCCOMSTR'] = 'Compiling $TARGET ...'
- env['CXXCOMSTR'] = 'Compiling $TARGET ...'
- env['SHCCCOMSTR'] = 'Compiling $TARGET ...'
- env['SHCXXCOMSTR'] = 'Compiling $TARGET ...'
- env['ARCOMSTR'] = 'Archiving $TARGET ...'
- env['LINKCOMSTR'] = 'Linking $TARGET ...'
- env['BINDINGSCOMSTR'] = 'Building bindings in $TARGET ...'
+
+# Create the base environment for the mac variant.
+mac_env = base_env.Clone(tools = ['target_platform_mac'])
+mac_env.Replace(
+ # Reproduce XCode's behavior of using gcc even to link C++,
+ # and distinguishing it the -x c++ option.
+ CC = 'gcc-4.2',
+ CXX = 'g++-4.2',
+ LINK = '$CXX',
+
+ CFLAGS = [
+ '-std=c99',
+ ],
+ CXXFLAGS = [
+ '-fvisibility-inlines-hidden',
+ '${str(SOURCE).endswith(".mm") and "-fobjc-gc" or ""}',
+ ],
+ CCFLAGS = [
+ '-fmessage-length=0',
+ '-pipe',
+ '-O0',
+ '-mdynamic-no-pic',
+ '-Werror',
+ '-Wnewline-eof',
+ '-fvisibility=hidden',
+ '-gdwarf-2',
+ '-Wall',
+ '-Wendif-labels',
+ '-fstack-protector',
+ '-fstack-protector-all',
+ ],
+ CPPDEFINES = [
+ 'DEBUG',
+ ],
+
+ FRAMEWORKPATH = [
+ '/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks',
+ ],
+ FRAMEWORKS = [
+ 'AppKit',
+ 'ApplicationServices',
+ 'Foundation',
+ ],
+ ICU_LIBS = ['icui18n', 'icuuc', 'icudata'],
+)
+
+mac_env.FilterOut(
+ BUILD_SCONSCRIPTS = [
+ 'third_party/libjpeg/SConscript',
+ 'third_party/libxml/SConscript',
+ 'third_party/libxslt/SConscript',
+ 'third_party/bspatch/SConscript',
+ 'webkit/SConscript',
+ ],
+)
+
+mac_env.Append(
+ BUILD_SCONSCRIPTS = [
+ 'third_party/libevent/SConscript',
+ ],
+)
# Add --clobber (for the buildbot).
@@ -432,141 +485,66 @@ if ARGUMENTS.get('VERBOSE') in (None, '0'):
AddOption('--clobber', action='store_true', dest='clobber', default=False,
help='Delete build directory before building.')
if GetOption('clobber'):
- shutil.rmtree(env.Dir('$TARGET_ROOT').abspath, True)
+ shutil.rmtree(base_env.Dir('$DESTINATION_ROOT').abspath, True)
+
+# Create a mac debug variant.
+debug_mac_env = mac_env.Clone(tools = ['target_debug'])
+debug_mac_env.Replace(
+ BUILD_TYPE = 'debug-mac',
+ BUILD_TYPE_DESCRIPTION = 'Mac debug variant',
+ BUILD_GROUPS = ['default'],
+)
+# Create a mac opt variant.
+release_mac_env = mac_env.Clone(tools = ['target_optimized'])
+release_mac_env.Replace(
+ BUILD_TYPE = 'release-mac',
+ BUILD_TYPE_DESCRIPTION = 'Mac release variant',
+)
-# Place the .sconsign.dblite in the build directory.
-target_dir = env.Dir('$TARGET_ROOT')
-if not os.path.exists(target_dir.abspath):
- Execute(Mkdir(target_dir))
-SConsignFile(target_dir.File('.sconsign').abspath)
-# Use timestamps change, followed by MD5 for speed
-env.Decider('MD5-timestamp')
+#-----------------------------------------------------------------------
-# Overlay things from a layer below.
-env.Dir('$TARGET_ROOT').addRepository(Dir('..'))
+Help("""
+PROGRESS=type Display a progress indicator:
+ name: print each evaluated target name
+ spinner: print a spinner every 5 targets
+VERBOSE=1 Display full command lines
+""")
-included = [c for c in load if not c.startswith('-')]
-excluded = [c[1:] for c in load if c.startswith('-')]
-if not included:
- included = ['all']
-
-components = ['all']
-
-def LoadComponent(c):
- components.append(c)
- return (not GetOption('help') and
- c in included or
- ('all' in included and not c in excluded))
-
-sconscripts = []
-
-if LoadComponent('base'):
- sconscripts.append('$BASE_DIR/SConscript')
-
-if LoadComponent('breakpad'):
- sconscripts.append('$BREAKPAD_DIR/SConscript')
-
-if LoadComponent('chrome'):
- sconscripts.append('$CHROME_DIR/SConscript')
-
-if LoadComponent('gears'):
- sconscripts.append('$GEARS_DIR/SConscript')
-
-if LoadComponent('google_update'):
- sconscripts.append('$GOOGLE_UPDATE_DIR/SConscript')
-
-if LoadComponent('googleurl'):
- # googleurl comes from a different repository so we provide the SConscript
- # file.
- sconscripts.append('SConscript.googleurl')
-
-if LoadComponent('net'):
- sconscripts.append('$NET_DIR/SConscript')
-
-if LoadComponent('rlz'):
- sconscripts.append('$RLZ_DIR/SConscript')
-
-if LoadComponent('sandbox'):
- sconscripts.append('$SANDBOX_DIR/src/SConscript')
-
-if LoadComponent('sdch'):
- sconscripts.append('$SDCH_DIR/SConscript')
-
-if LoadComponent('skia'):
- sconscripts.append('$SKIA_DIR/SConscript')
-
-if LoadComponent('testing'):
- sconscripts.append('$TESTING_DIR/SConscript.gtest')
-
-if LoadComponent('third_party'):
- sconscripts.extend([
- '$BSDIFF_DIR/SConscript',
- '$BZIP2_DIR/SConscript',
- '$ICU38_DIR/SConscript',
- '$LIBPNG_DIR/SConscript',
- '$LZMA_SDK_DIR/SConscript',
- '$MODP_B64_DIR/SConscript',
- '$ZLIB_DIR/SConscript',
- ])
- # Temporary until we get these building on Mac.
- if env['PLATFORM'] != 'darwin':
- sconscripts.extend([
- '$LIBJPEG_DIR/SConscript',
- '$LIBXML_DIR/SConscript',
- '$LIBXSLT_DIR/SConscript',
- ])
- if env['PLATFORM'] in ('posix', 'darwin'):
- sconscripts.extend([
- '$LIBEVENT_DIR/SConscript',
- ])
- # This is temporary until we get this lib to build on other platforms.
- if env['PLATFORM'] == 'win32':
- sconscripts.extend([
- '$BSPATCH_DIR/SConscript',
- ])
-
-if LoadComponent('v8') and env.Dir('#/../v8').exists():
- env.SConscript('SConscript.v8',
- exports=['env'])
-
-if LoadComponent('webkit'):
- sconscripts.append('$WEBKIT_DIR/SConscript')
-
-env.SConscript(sconscripts, exports=['env'])
-
-
-help_fmt = """
-Usage: hammer [SCONS_OPTIONS] [VARIABLES] [TARGET] ...
-
-Supported build variables:
-
- BUILD_TYPE=type Build type. Also used as the subdirectory name
- in which the build occurs.
- LOAD=[module,...] Comma-separated list of components to load in the
- dependency graph ('-' prefix excludes):
-%s
- PROGRESS=type Display a progress indicator:
- name: print each evaluated target name
- spinner: print a spinner every 5 targets
- VERBOSE=1 Display full command lines
-"""
-
-if GetOption('help'):
- import textwrap
- tw = textwrap.TextWrapper(
- width = 78,
- initial_indent = ' '*32,
- subsequent_indent = ' '*32,
- )
- components = tw.fill(', '.join(components))
- Help(help_fmt % components)
+#-----------------------------------------------------------------------
+
+# Build all programs and libraries by default.
+Default([base_env.Alias('all_programs'),
+ base_env.Alias('all_libraries')])
+
+# Create a list of all variants that are buildable.
+environment_list = [
+ debug_mac_env,
+ release_mac_env,
+ debug_win_env,
+ release_win_env,
+ debug_linux_env,
+ release_linux_env,
+]
+# For each variant in the environment_list, build the SConscript files in its
+# BUILD_SCONSCRIPTS variable.
+BuildComponents(environment_list)
-Import('build_component')
-Default(build_component)
+#-----------------------------------------------------------------------
+
+# Generate a solution, defer to the end.
+solution_env = base_env.Clone(tools = ['visual_studio_solution'])
+solution = solution_env.Solution(
+ 'chrome_hammer', environment_list,
+ exclude_pattern = '.*third_party.*',
+ extra_build_targets = {
+ 'Firefox': 'c:/Program Files/Mozilla FireFox/firefox.exe',
+ },
+)
+solution_env.Alias('solution', solution)