summaryrefslogtreecommitdiffstats
path: root/build
diff options
context:
space:
mode:
authorbradnelson@chromium.org <bradnelson@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2008-10-20 23:29:20 +0000
committerbradnelson@chromium.org <bradnelson@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2008-10-20 23:29:20 +0000
commit1bdfd82cea4f30a5751a19c8283b05f34612a818 (patch)
treed41f92852dc4b90c2bf4b469252e535761e27152 /build
parent126a6c706d0db79f5af75b1f019b831cf9680e70 (diff)
downloadchromium_src-1bdfd82cea4f30a5751a19c8283b05f34612a818.zip
chromium_src-1bdfd82cea4f30a5751a19c8283b05f34612a818.tar.gz
chromium_src-1bdfd82cea4f30a5751a19c8283b05f34612a818.tar.bz2
Rolling back switch to hammer patterns again.
Review URL: http://codereview.chromium.org/7530 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@3637 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'build')
-rw-r--r--build/SConscript.googleurl64
-rw-r--r--build/SConscript.main759
-rw-r--r--build/SConscript.v825
3 files changed, 437 insertions, 411 deletions
diff --git a/build/SConscript.googleurl b/build/SConscript.googleurl
index 4407afc..11ca7c7 100644
--- a/build/SConscript.googleurl
+++ b/build/SConscript.googleurl
@@ -28,25 +28,34 @@ if env['PLATFORM'] == 'win32':
)
lib_input_files = [
- 'src/gurl.cc',
- 'src/url_canon_etc.cc',
- 'src/url_canon_fileurl.cc',
- 'src/url_canon_host.cc',
- 'src/url_canon_icu.cc',
- 'src/url_canon_internal.cc',
- 'src/url_canon_ip.cc',
- 'src/url_canon_mailtourl.cc',
- 'src/url_canon_path.cc',
- 'src/url_canon_pathurl.cc',
- 'src/url_canon_query.cc',
- 'src/url_canon_relative.cc',
- 'src/url_canon_stdurl.cc',
- 'src/url_parse.cc',
- 'src/url_parse_file.cc',
- 'src/url_util.cc',
+ 'gurl.cc',
+ 'url_canon_etc.cc',
+ 'url_canon_fileurl.cc',
+ 'url_canon_host.cc',
+ 'url_canon_icu.cc',
+ 'url_canon_internal.cc',
+ 'url_canon_ip.cc',
+ 'url_canon_mailtourl.cc',
+ 'url_canon_path.cc',
+ 'url_canon_pathurl.cc',
+ 'url_canon_query.cc',
+ 'url_canon_relative.cc',
+ 'url_canon_stdurl.cc',
+ 'url_parse.cc',
+ 'url_parse_file.cc',
+ 'url_util.cc',
]
-env.ChromeStaticLibrary('googleurl', lib_input_files)
+def BuildObjectFiles(environ, input_files):
+ obj_files = []
+ for input_file in input_files:
+ source = '../googleurl/src/' + input_file
+ target = '$TARGET_ROOT/googleurl/' + input_file[:input_file.find('.cc')]
+ obj_files.append(environ.StaticObject(source = source, target = target))
+ return obj_files
+
+env.ChromeStaticLibrary('$TARGET_ROOT/googleurl/googleurl',
+ BuildObjectFiles(env, lib_input_files))
env_tests = env.Clone()
@@ -66,20 +75,21 @@ env_tests.Append(
)
test_files = [
- 'src/gurl_unittest.cc',
- 'src/url_canon_unittest.cc',
- 'src/url_parse_unittest.cc',
- 'src/url_util_unittest.cc',
- # The version of gtest that googleurl uses provides a main() function; ours
- # doesn't so include our own main function.
- env_tests.ChromeObject('run_all_unittests',
- '$OBJ_ROOT/base/run_all_unittests.cc'),
+ 'gurl_unittest.cc',
+ 'url_canon_unittest.cc',
+ 'url_parse_unittest.cc',
+ 'url_util_unittest.cc',
]
+test_obj_files = BuildObjectFiles(env_tests, test_files)
# The version of gtest that googleurl uses provides a main() function; ours
# doesn't so include our own main function.
-gurl_unittests = env_tests.ChromeTestProgram('googleurl_unittests', test_files)
+test_obj_files.append(env_tests.StaticObject(source = '../base/run_all_unittests.cc',
+ target = '$TARGET_ROOT/googleurl/run_all_unittests'))
+
+gurl_unittests = env_tests.ChromeTestProgram(
+ '$TARGET_ROOT/googleurl/googleurl_unittests', test_obj_files)
-installed_gurl_unittests = env.Replicate('$MAIN_DIR/Hammer', gurl_unittests)
+installed_gurl_unittests = env.Install('$TARGET_ROOT', gurl_unittests)
env.Alias('googleurl', installed_gurl_unittests)
diff --git a/build/SConscript.main b/build/SConscript.main
index 6a7da71..72b8004 100644
--- a/build/SConscript.main
+++ b/build/SConscript.main
@@ -7,27 +7,6 @@ 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'))
@@ -46,17 +25,18 @@ else:
load = []
-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/..',
+env = Environment(
+ BUILD_TYPE = ARGUMENTS.get('BUILD_TYPE', 'Hammer'),
+ TARGET_ROOT = '#/$BUILD_TYPE',
+ OBJ_ROOT = '$TARGET_ROOT',
+
+ LIBS_DIR = '#/$BUILD_TYPE/Libs',
- 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',
+ 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',
# Work around a limitation (bug?) in SCons in that, when we build
# from a different directory, it forces the build targets defined
@@ -65,18 +45,18 @@ base_env.Replace(
# 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 = '$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 = '$ROOT_DIR/third_party',
- V8_DIR = '$ROOT_DIR/v8',
- WEBKIT_DIR = '$ROOT_DIR/webkit',
+ #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',
GTEST_DIR = '$TESTING_DIR/gtest',
@@ -91,51 +71,14 @@ base_env.Replace(
LIBXSLT_DIR = '$THIRD_PARTY_DIR/libxslt',
LZMA_SDK_DIR = '$THIRD_PARTY_DIR/lzma_sdk',
MODP_B64_DIR = '$THIRD_PARTY_DIR/modp_b64',
- NPAPI_DIR = '$ROOT_DIR/third_party/npapi',
+ NPAPI_DIR = '$THIRD_PARTY_DIR/npapi',
ZLIB_DIR = '$THIRD_PARTY_DIR/zlib',
- THIRD_PARTY_WEBKIT_DIR = '$ROOT_DIR/third_party/WebKit',
+ THIRD_PARTY_WEBKIT_DIR = '$THIRD_PARTY_DIR/WebKit',
PYTHON=sys.executable,
- # 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',
- ],
+ LIBPATH = ['$LIBS_DIR'],
PERL = 'perl',
PERL_INCLUDE_FLAG = '-I ',
@@ -146,62 +89,87 @@ base_env.Replace(
'__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):
- return env.ComponentProgram(*args, **kw)
-base_env.AddMethod(ChromeProgram)
+ if env['PLATFORM'] == 'win32':
+ # TODO(tc): We should handle kw['target'] too.
+ args = AddPdbToTarget(args)
+ return env.Program(*args, **kw)
+env.AddMethod(ChromeProgram, "ChromeProgram")
def ChromeTestProgram(env, *args, **kw):
- return env.ComponentTestProgram(*args, **kw)
-base_env.AddMethod(ChromeTestProgram)
+ if env['PLATFORM'] == 'win32':
+ # TODO(tc): We should handle kw['target'] too.
+ args = AddPdbToTarget(args)
+ return env.Program(*args, **kw)
+env.AddMethod(ChromeTestProgram, "ChromeTestProgram")
def ChromeStaticLibrary(env, *args, **kw):
- kw['COMPONENT_STATIC'] = True
- return env.ComponentLibrary(*args, **kw)
-base_env.AddMethod(ChromeStaticLibrary)
+ 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")
def ChromeSharedLibrary(env, *args, **kw):
- 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 ...'
-
-
-
-
+ return env.SharedLibrary(*args, **kw)
+env.AddMethod(ChromeSharedLibrary, "ChromeSharedLibrary")
+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')
-# Create environment from which all Windows variants derive.
-windows_env = base_env.Clone(tools = ['target_platform_windows'])
-windows_env.Replace(
+ 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 = '$MAIN_DIR/../third_party/cygwin',
+ CYGWIN_DIR = 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 = [
@@ -254,104 +222,113 @@ windows_env.Replace(
'$PLATFORMSDK_VISTA/files/Include',
'$PLATFORMSDK_VISTA/files/VC/INCLUDE',
'$VISUAL_STUDIO/VC/atlmfc/include',
- '$MAIN_DIR/..',
],
LIBS = [
- 'advapi32',
- 'comdlg32',
- 'gdi32',
- 'kernel32',
- 'msimg32',
- 'odbc32',
- 'odbccp32',
- 'ole32',
- 'oleaut32',
- 'psapi',
- 'shell32',
- 'user32',
- 'usp10',
- 'uuid',
- 'version',
- 'wininet',
- 'winspool',
- 'ws2_32',
-
- 'DelayImp',
+ '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',
],
LINKFLAGS = [
'/nologo',
'/DEBUG',
],
+
ICU_LIBS = ['icu'],
)
-windows_env.Append(
+ env.Append(
LIBPATH = [
'$PLATFORMSDK_VISTA/files/Lib',
'$PLATFORMSDK_VISTA/files/VC/LIB',
'$VISUAL_STUDIO/VC/atlmfc/lib',
],
-)
-
-# Remove manifest gunk for now.
-windows_env['LINKCOM'] = windows_env['LINKCOM'][0]
-windows_env['SHLINKCOM'] = windows_env['SHLINKCOM'][0]
-
-# 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',
-)
-
-
-#-----------------------------------------------------------------------
-
+ )
+ # 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]}',
+ )
-excluded_warnings = [
+ 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: 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
-]
-
-# 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'],
+ '-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'],
# We have several cases where archives depend on each other in a cyclic
# fashion. (V8Bindings, libport and WebCore being the most significant
@@ -370,131 +347,101 @@ linux_env.Replace(
'-Wl,--start-group $_LIBFLAGS -Wl,--end-group'),
# We need rt for clock_gettime.
- 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)}'),
-)
-
-# 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',
- ],
-)
-
-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'],
-)
-
-# 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',
-)
-
-
-
-
-#-----------------------------------------------------------------------
-
+ LIBS = ['rt'],
+ 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)}'),
-# 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',
+ 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'],
+ )
- 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',
- ],
+else:
- FRAMEWORKPATH = [
- '/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks',
- ],
- FRAMEWORKS = [
- 'AppKit',
- 'ApplicationServices',
- 'Foundation',
- ],
- ICU_LIBS = ['icui18n', 'icuuc', 'icudata'],
-)
+ print "Unsupported SCons $PLATFORM value %s" % repr(env['PLATFORM'])
+ Exit(1)
-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',
- ],
-)
+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 ...'
# Add --clobber (for the buildbot).
@@ -502,73 +449,141 @@ mac_env.Append(
AddOption('--clobber', action='store_true', dest='clobber', default=False,
help='Delete build directory before building.')
if GetOption('clobber'):
- 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'],
-)
+ shutil.rmtree(env.Dir('$TARGET_ROOT').abspath, True)
-# 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)
-#-----------------------------------------------------------------------
-# By default, the Hammer modules execute the tests to capture test
-# output, but do it from a location that doesn't (yet) work for us.
-# Replace the Hammer defaults with Chromium's.
-Default(None)
Import('build_component')
-Default(Alias(build_component))
-
-# TODO: Get to the point of using Hammer's aliases.
-#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)
-
-#-----------------------------------------------------------------------
-
-# 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)
+Default(build_component)
diff --git a/build/SConscript.v8 b/build/SConscript.v8
index 7820f16..8eeef09 100644
--- a/build/SConscript.v8
+++ b/build/SConscript.v8
@@ -2,9 +2,6 @@
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
-
-import os
-
Import('env')
# Grab the -j flag from the outer environment, if available.
@@ -25,16 +22,13 @@ env = env.Clone(
'--warn=no-no-parallel-support' + cpu_flag),
)
-if env['PLATFORM'] == 'win32':
- env['ENV']['ProgramFiles'] = os.environ['ProgramFiles']
-
# Rather than build v8 with our own commands, we just shell out to v8's
# own SCons-based build, since their build system is complicated.
# This SConscript just declares dependencies on the outputs of that build.
mksnapshot_exe = env.File('$V8_MODE_DIR/mksnapshot${PROGSUFFIX}')
-libraries_empty_obj = env.File('$V8_MODE_DIR/libraries-empty${OBJSUFFIX}')
libraries_obj = env.File('$V8_MODE_DIR/libraries${OBJSUFFIX}')
+libraries_empty_obj = env.File('$V8_MODE_DIR/libraries-empty${OBJSUFFIX}')
snapshot_obj = env.File('$V8_MODE_DIR/snapshot${OBJSUFFIX}')
snapshot_empty_obj = env.File('$V8_MODE_DIR/snapshot-empty${OBJSUFFIX}')
v8_bin = env.File('$V8_SRC_DIR/shell${PROGSUFFIX}')
@@ -70,13 +64,20 @@ env.AlwaysBuild(v8)
# rebuild them (thereby causing us to always rebuild their dependents).
env.Precious(v8)
+env.Install('$V8_DIR', v8)
+
+
+i = env.Install('$LIBS_DIR', v8_lib)
+env.Alias('webkit', i)
+
+i = env.Install('$TARGET_ROOT', v8_bin)
+env.Alias('chrome', i)
-# TODO(bradnelson): remove if we confirm we no longer need this.
# To satisfy tests expecting the following .exe name.
-#if env['PLATFORM'] == 'win32':
-# # TODO(evanm): this may be necessary on other platforms(?)
-# i = env.InstallAs('$TARGET_ROOT/v8_shell_sample${PROGSUFFIX}', v8_bin)
-# env.Alias('chrome', i)
+if env['PLATFORM'] == 'win32':
+ # TODO(evanm): this may be necessary on other platforms(?)
+ i = env.InstallAs('$TARGET_ROOT/v8_shell_sample${PROGSUFFIX}', v8_bin)
+ env.Alias('chrome', i)
env.ChromeStaticLibrary('v8_snapshot',
[libraries_empty_obj, snapshot_obj])