summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbradnelson@chromium.org <bradnelson@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2008-10-18 00:30:22 +0000
committerbradnelson@chromium.org <bradnelson@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2008-10-18 00:30:22 +0000
commit012adff3836f208288c09323c0de2f93117c13c9 (patch)
treed1af9d7e64632c7b79a774015cc0377f0801010c
parent5ab78644f9d8237553aab6c0b6b97463ecd67bda (diff)
downloadchromium_src-012adff3836f208288c09323c0de2f93117c13c9.zip
chromium_src-012adff3836f208288c09323c0de2f93117c13c9.tar.gz
chromium_src-012adff3836f208288c09323c0de2f93117c13c9.tar.bz2
Rolling back CL 3578, discovered hammer.bat had not been updated yet.
Review URL: http://codereview.chromium.org/7507 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@3582 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--base/SConscript11
-rw-r--r--base/gfx/SConscript13
-rw-r--r--build/SConscript.googleurl64
-rw-r--r--build/SConscript.main752
-rw-r--r--build/SConscript.v825
-rw-r--r--chrome/SConstruct1
-rw-r--r--net/SConscript29
-rw-r--r--net/tools/tld_cleanup/SConscript3
-rw-r--r--sandbox/src/SConscript17
-rw-r--r--third_party/bsdiff/SConscript2
-rw-r--r--webkit/SConscript16
-rw-r--r--webkit/activex_shim/SConscript3
-rw-r--r--webkit/activex_shim_dll/SConscript3
-rw-r--r--webkit/build/port/SConscript3
-rw-r--r--webkit/default_plugin/SConscript3
-rw-r--r--webkit/glue/plugins/test/SConscript15
-rw-r--r--webkit/tools/npapi_layout_test_plugin/SConscript20
-rw-r--r--webkit/tools/test_shell/SConscript63
18 files changed, 534 insertions, 509 deletions
diff --git a/base/SConscript b/base/SConscript
index ef462d9..2d7e8a7 100644
--- a/base/SConscript
+++ b/base/SConscript
@@ -11,7 +11,7 @@ env.Prepend(
CPPPATH = [
'$ICU38_DIR/public/common',
'$ICU38_DIR/public/i18n',
- '$ROOT_DIR',
+ '..',
],
CPPDEFINES = [
'U_STATIC_IMPLEMENTATION',
@@ -191,7 +191,7 @@ env_tests.Prepend(
'$LIBPNG_DIR',
'$ICU38_DIR/public/common',
'$ICU38_DIR/public/i18n',
- '$ROOT_DIR',
+ '..',
],
CPPDEFINES = [
'UNIT_TEST',
@@ -304,7 +304,7 @@ test_files = [
if env['PLATFORM'] == 'win32':
# These tests aren't really Windows-specific, they're just here until
# we have the port versions working.
- env_tests.ChromeProgram('debug_message', ['debug_message.cc'])
+ env_tests.ChromeTestProgram('debug_message', ['debug_message.cc'])
test_files.extend([
'directory_watcher_unittest.cc',
@@ -336,9 +336,8 @@ if env['PLATFORM'] == 'darwin':
base_unittests = env_tests.ChromeTestProgram('base_unittests', test_files)
-# Temporarily put things where the buildbot expects them.
-installed_base_unittests = env.Replicate('$MAIN_DIR/Hammer', base_unittests)
-env.Requires(installed_base_unittests, '$MAIN_DIR/Hammer/icudt38.dll')
+# Install up a level to allow unit test path assumptions to be valid.
+installed_base_unittests = env.Install('$TARGET_ROOT', base_unittests)
sconscript_dirs = [
diff --git a/base/gfx/SConscript b/base/gfx/SConscript
index 57d1b54..c862193 100644
--- a/base/gfx/SConscript
+++ b/base/gfx/SConscript
@@ -6,12 +6,10 @@ Import('env')
env = env.Clone()
-# This path causing linux to grab the wrong time.h
-env.FilterOut(
- CPPPATH = [
- '$MAIN_DIR/..',
- ],
-)
+# Remove an inherited relative path that doesn't make sense anymore. This
+# makes sure we don't pull in the wrong version of time.h when building on
+# linux.
+env['CPPPATH'].remove('..')
env.Prepend(
CPPPATH = [
@@ -22,6 +20,7 @@ env.Prepend(
'$LIBPNG_DIR',
'$ICU38_DIR/public/common',
'$ICU38_DIR/public/i18n',
+ '../..',
],
CPPDEFINES = [
'PNG_USER_CONFIG',
@@ -63,7 +62,6 @@ if env['PLATFORM'] == 'win32':
if env['PLATFORM'] == 'win32':
input_files.extend([
- 'gdi_util.cc',
'bitmap_platform_device_win.cc',
'platform_canvas_win.cc',
'platform_device_win.cc',
@@ -76,3 +74,4 @@ elif env['PLATFORM'] == 'posix':
])
env.ChromeStaticLibrary('base_gfx', input_files)
+
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 43477b2..275df6d3 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 = '$OBJ_ROOT/third_party',
- V8_DIR = '$ROOT_DIR/v8',
- WEBKIT_DIR = '$OBJ_ROOT/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,230 +222,209 @@ 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 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).
@@ -485,66 +432,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'],
-)
-
-# 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',
-)
+ shutil.rmtree(env.Dir('$TARGET_ROOT').abspath, True)
+# 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')
-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
-""")
-
-
-#-----------------------------------------------------------------------
+# Overlay things from a layer below.
+env.Dir('$TARGET_ROOT').addRepository(Dir('..'))
-# 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,
-]
+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))
-# For each variant in the environment_list, build the SConscript files in its
-# BUILD_SCONSCRIPTS variable.
-BuildComponents(environment_list)
+ Help(help_fmt % components)
-#-----------------------------------------------------------------------
-# 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)
+Import('build_component')
+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])
diff --git a/chrome/SConstruct b/chrome/SConstruct
index 4afcb75..dd84b36 100644
--- a/chrome/SConstruct
+++ b/chrome/SConstruct
@@ -5,3 +5,4 @@
build_component = 'chrome'
SConscript('../build/SConscript.main',
exports=['build_component'])
+
diff --git a/net/SConscript b/net/SConscript
index b862b91..37d6c18 100644
--- a/net/SConscript
+++ b/net/SConscript
@@ -14,7 +14,7 @@ env.Prepend(
'$ICU38_DIR/public/common',
'$ICU38_DIR/public/i18n',
'$SDCH_DIR/open-vcdiff/src',
- '$ROOT_DIR',
+ '..',
],
)
@@ -166,7 +166,7 @@ env.ChromeStaticLibrary('net', input_files)
env_tests.Prepend(
CPPPATH = [
- '$ROOT_DIR',
+ '..',
],
CPPDEFINES = [
'UNIT_TEST',
@@ -221,9 +221,6 @@ if env['PLATFORM'] in ('posix', 'darwin'):
)
-disk_cache_test_util = env.ChromeObject('disk_cache/disk_cache_test_util.cc')
-
-
unittest_files = [
'base/auth_cache_unittest.cc',
'base/base64_unittest.cc',
@@ -247,6 +244,7 @@ unittest_files = [
'disk_cache/backend_unittest.cc',
'disk_cache/block_files_unittest.cc',
'disk_cache/disk_cache_test_base.cc',
+ 'disk_cache/disk_cache_test_util.cc',
'disk_cache/entry_unittest.cc',
'disk_cache/mapped_file_unittest.cc',
'disk_cache/storage_block_unittest.cc',
@@ -256,7 +254,6 @@ unittest_files = [
'http/http_chunked_decoder_unittest.cc',
'http/http_response_headers_unittest.cc',
'http/http_vary_data_unittest.cc',
- disk_cache_test_util,
]
if env['PLATFORM'] == 'win32':
@@ -289,12 +286,12 @@ if env['PLATFORM'] in ('posix', 'win32'):
net_perftests = env_tests.ChromeTestProgram(
'net_perftests',
- ['disk_cache/disk_cache_perftest.cc',
- disk_cache_test_util,
+ ['disk_cache/disk_cache_test_util.cc',
+ 'disk_cache/disk_cache_perftest.cc',
'base/cookie_monster_perftest.cc',
# TODO(sgk): avoid using .cc from base directly
- '$OBJ_ROOT/base/run_all_perftests$OBJSUFFIX',
- '$OBJ_ROOT/base/perftimer$OBJSUFFIX']
+ '$BASE_DIR/run_all_perftests$OBJSUFFIX',
+ '$BASE_DIR/perftimer$OBJSUFFIX']
)
install_targets.extend([
@@ -305,13 +302,13 @@ if env['PLATFORM'] == 'win32':
stress_cache = env_tests.ChromeTestProgram(
'stress_cache',
['disk_cache/stress_cache.cc',
- disk_cache_test_util],
+ 'disk_cache/disk_cache_test_util.cc']
)
crash_cache = env_tests.ChromeTestProgram(
'crash_cache',
['tools/crash_cache/crash_cache.cc',
- disk_cache_test_util],
+ 'disk_cache/disk_cache_test_util.cc']
)
install_targets.extend([
@@ -320,14 +317,14 @@ if env['PLATFORM'] == 'win32':
])
-# Install tests where the buildbot expects them.
-installed_tests = env.Install('$MAIN_DIR/Hammer', install_targets)
+# Create install of tests.
+installed_tests = env.Install('$TARGET_ROOT', install_targets)
if env['PLATFORM'] == 'win32':
- env_res.Prepend(
+ env_res.Append(
CPPPATH = [
- '$ROOT_DIR',
+ '..',
],
RCFLAGS = [
['/l', '0x409'],
diff --git a/net/tools/tld_cleanup/SConscript b/net/tools/tld_cleanup/SConscript
index 415bef7..5ab7e82 100644
--- a/net/tools/tld_cleanup/SConscript
+++ b/net/tools/tld_cleanup/SConscript
@@ -8,7 +8,7 @@ env = env.Clone()
env.Prepend(
CPPPATH = [
- '$ROOT_DIR',
+ '../../..',
],
LIBS = [
'googleurl',
@@ -49,3 +49,4 @@ i = env.Install('$TARGET_ROOT', exe_targets)
env.Alias('net', i)
env.Install('$TARGET_ROOT', exe_targets)
+
diff --git a/sandbox/src/SConscript b/sandbox/src/SConscript
index 961257b..8914ba2 100644
--- a/sandbox/src/SConscript
+++ b/sandbox/src/SConscript
@@ -10,7 +10,6 @@ env = env.Clone()
# in the base env here, not just in env_tests.
env.Prepend(
CPPPATH = [
- '$ROOT_DIR',
'$GTEST_DIR/include',
'$GTEST_DIR',
'../..',
@@ -28,10 +27,8 @@ env.Append(
],
)
-env.Dir('$OBJ_ROOT/sandbox/src').addRepository(env.Dir('$ROOT_DIR/sandbox'))
-
env_tests = env.Clone(
- TESTS_DIR = 'tests',
+ TESTS_DIR = '../tests',
INTEGRATION_TESTS_DIR = '$TESTS_DIR/integration_tests',
UNIT_TESTS_DIR = '$TESTS_DIR/unit_tests',
VALIDATION_TESTS_DIR = '$TESTS_DIR/validation_tests',
@@ -161,8 +158,6 @@ unit_test_files = [
# TODO(bradnelson): This step generates unittests_tests.pch.ib_tag
# SCons doesn't know.
env_p = env_unit_tests.Clone()
-# TODO(bradnelson): Make this automatic.
-env_p['COMPONENT_PLATFORM_SETUP'](env_p, 'ComponentTestProgram')
pch, obj = env_p.PCH(['$UNIT_TESTS_DIR/unit_tests.pch',
'$UNIT_TESTS_DIR/unit_tests.obj'],
'$UNIT_TESTS_DIR/unit_tests.cc')
@@ -206,8 +201,6 @@ integration_test_files = [
# TODO(bradnelson): This step generates integration_tests.pch.ib_tag
# SCons doesn't know.
env_p = env_integration_tests.Clone()
-# TODO(bradnelson): Make this automatic.
-env_p['COMPONENT_PLATFORM_SETUP'](env_p, 'ComponentTestProgram')
pch, obj = env_p.PCH(['$INTEGRATION_TESTS_DIR/integration_tests.pch',
'$INTEGRATION_TESTS_DIR/integration_tests.obj'],
'$INTEGRATION_TESTS_DIR/integration_tests.cc')
@@ -240,8 +233,7 @@ validation_test_files = [
]
env_p = env_validation_tests.Clone()
-# TODO(bradnelson): Make this automatic.
-env_p['COMPONENT_PLATFORM_SETUP'](env_p, 'ComponentTestProgram')
+
# TODO(bradnelson): This step generates unittests_tests.pch.ib_tag
# SCons doesn't know.
pch, obj = env_p.PCH(['$VALIDATION_TESTS_DIR/unit_tests.pch',
@@ -257,10 +249,11 @@ validation_tests = env_validation_tests.ChromeTestProgram(
)
-# Install tests to where the buildbot expects them for now.
-installed_tests = env.Install('$MAIN_DIR/Hammer',
+# Install tests to a path where they can find their inputs.
+installed_tests = env.Install('$OBJ_ROOT',
unit_tests + validation_tests + integration_tests)
# Setup alias for sandbox related targets.
env.Alias('sandbox', ['.', installed_tests])
+
diff --git a/third_party/bsdiff/SConscript b/third_party/bsdiff/SConscript
index 176f29f..e1408c8 100644
--- a/third_party/bsdiff/SConscript
+++ b/third_party/bsdiff/SConscript
@@ -34,7 +34,7 @@ env = env.Clone()
env.Prepend(
CPPPATH = [
- '$BSPATCH_DIR',
+ '../bspatch',
]
)
diff --git a/webkit/SConscript b/webkit/SConscript
index 3ea66af..519e809 100644
--- a/webkit/SConscript
+++ b/webkit/SConscript
@@ -81,9 +81,7 @@ env.Prepend(
'$ZLIB_DIR',
'$LIBPNG_DIR',
'$LIBJPEG_DIR',
- '$LIBXSLT_DIR/scons',
'$LIBXSLT_DIR',
- '$LIBXML_DIR/scons/include',
'$LIBXML_DIR/include',
'$LIBXML_DIR/DerivedSources/include',
'$ICU38_DIR/public/common',
@@ -93,8 +91,8 @@ env.Prepend(
'$SKIA_DIR/platform',
'$NPAPI_DIR',
'$V8_DIR/include',
- '$DERIVED_DIR',
- '$SHARED_DIR',
+ '$WEBKIT_DIR/V8Bindings/DerivedSources',
+ '$WEBKIT_DIR/V8Bindings/SharedSources',
'$WEBKIT_DIR/port/bindings/v8',
'$WEBKIT_DIR/WebCore',
'$WEBKIT_DIR/WebCore/JavaScriptHeaders',
@@ -146,13 +144,10 @@ env.Prepend(
'$WEBKIT_DIR/port/svg/animation',
'$WEBKIT_DIR/port/svg/graphics/filters',
- '$ROOT_DIR',
+ '#/..',
],
)
-if env.Bit('windows'):
- env.Append(CPPPATH = ['$WEBKIT_DIR/port/page/win'])
-
env.Append(
WEBCORE_DIR = "$THIRD_PARTY_WEBKIT_DIR/WebCore",
PENDING_DIR = "$WEBKIT_DIR/pending",
@@ -164,8 +159,8 @@ env.Append(
PCRE_DIR = "$JAVASCRIPTCORE_DIR/pcre",
V8BINDINGS_DIR = "$WEBKIT_DIR/V8Bindings",
- DERIVED_DIR = "$WEBKIT_DIR/V8Bindings/DerivedSources",
- SHARED_DIR = "$WEBKIT_DIR/V8Bindings/SharedSources",
+ DERIVED_DIR = env.Dir("$WEBKIT_DIR/V8Bindings/DerivedSources"),
+ SHARED_DIR = env.Dir("$WEBKIT_DIR/V8Bindings/SharedSources"),
# This is a stop gap to get linux building in time for the webkit
# merge. The true fix is to move the above CPPPATH prepend under this
@@ -285,3 +280,4 @@ version = env.Command('$WEBKIT_DIR/build/WebCore/webkit_version.h',
'#/../webkit/build/webkit_version.py'],
"$PYTHON ${SOURCES[1]} ${SOURCES[0]} ${TARGET.dir}")
env.AlwaysBuild(version)
+
diff --git a/webkit/activex_shim/SConscript b/webkit/activex_shim/SConscript
index bf2c5fc2..cf235e6 100644
--- a/webkit/activex_shim/SConscript
+++ b/webkit/activex_shim/SConscript
@@ -9,7 +9,7 @@ env = env.Clone()
env.Prepend(
CPPPATH = [
'$NPAPI_DIR',
- '$ROOT_DIR',
+ '#/..',
],
)
@@ -41,3 +41,4 @@ input_files = [
]
env.ChromeStaticLibrary('activex_shim', input_files)
+
diff --git a/webkit/activex_shim_dll/SConscript b/webkit/activex_shim_dll/SConscript
index 29d4092..a4dc1b2 100644
--- a/webkit/activex_shim_dll/SConscript
+++ b/webkit/activex_shim_dll/SConscript
@@ -44,5 +44,6 @@ input_files = [
]
dll = env.ChromeSharedLibrary('npaxshim', input_files)
-i = env.Replicate('$MAIN_DIR/Hammer', dll[0])
+i = env.Install('$TARGET_ROOT', dll)
env.Alias('webkit', i)
+
diff --git a/webkit/build/port/SConscript b/webkit/build/port/SConscript
index 7a9de8f..b1e27e2 100644
--- a/webkit/build/port/SConscript
+++ b/webkit/build/port/SConscript
@@ -16,6 +16,7 @@ cygwin_posix = cygwin.abspath.replace('\\', '/')
pending = env.Dir('#../webkit/pending')
portroot = env.Dir('#../webkit/port')
webkit_build = env.Dir('#../webkit/build')
+bindings_output_dir = env.Dir('#/../webkit/$BUILD_TYPE/scons/V8Bindings')
def PosixIncludes(env, prefix, files, suffix):
@@ -476,7 +477,7 @@ idl_files = [
]
for subdir in set([os.path.dirname(n) for n in idl_files]):
- dir = env.Dir('$OBJ_ROOT/webkit/port/' + subdir)
+ dir = env.Dir('#/$BUILD_TYPE/webkit/port/' + subdir)
dir.addRepository(env.Dir('#/../webkit/pending'))
dir.addRepository(env.Dir('#/../webkit/port/' + subdir))
diff --git a/webkit/default_plugin/SConscript b/webkit/default_plugin/SConscript
index 2cad465..571e64d 100644
--- a/webkit/default_plugin/SConscript
+++ b/webkit/default_plugin/SConscript
@@ -14,8 +14,6 @@ env.Prepend(
'#/../third_party/libxml/include',
'#/../third_party/npapi',
'#/..',
-# TODO(bradnelson): this might be needed?
-# '$OBJ_ROOT/webkit/build/localized_strings',
],
)
@@ -53,3 +51,4 @@ if env['PLATFORM'] == 'win32':
])
env.ChromeStaticLibrary('default_plugin', input_files)
+
diff --git a/webkit/glue/plugins/test/SConscript b/webkit/glue/plugins/test/SConscript
index bfdc821..3e90365 100644
--- a/webkit/glue/plugins/test/SConscript
+++ b/webkit/glue/plugins/test/SConscript
@@ -69,7 +69,18 @@ if env['PLATFORM'] == 'win32':
],
)
-dll = env.ChromeSharedLibrary('npapi_test_plugin', input_files)
+ dll = env.ChromeSharedLibrary([
+ 'npapi_test_plugin',
+ 'npapi_test_plugin.lib',
+ 'npapi_test_plugin.ilk',
+ 'npapi_test_plugin.pdb'
+ ], input_files)
-i = env.Replicate('$MAIN_DIR/Hammer', dll[0])
+ # TODO(sgk): goes away once ChromeSharedLibrary does this for us.
+ env.Install('$LIBS_DIR', dll[1])
+else:
+ dll = env.ChromeSharedLibrary(['npapi_test_plugin'], input_files)
+
+i = env.Install('$TARGET_ROOT', dll)
env.Alias('webkit', i)
+
diff --git a/webkit/tools/npapi_layout_test_plugin/SConscript b/webkit/tools/npapi_layout_test_plugin/SConscript
index 329fb92..4b2da51 100644
--- a/webkit/tools/npapi_layout_test_plugin/SConscript
+++ b/webkit/tools/npapi_layout_test_plugin/SConscript
@@ -45,7 +45,23 @@ if env['PLATFORM'] == 'win32':
],
)
- dll = env.ChromeSharedLibrary('npapi_layout_test_plugin', input_files)
+if env['PLATFORM'] == 'win32':
+ dll = env.ChromeSharedLibrary([
+ 'npapi_layout_test_plugin',
+ 'npapi_layout_test_plugin.lib',
+ 'npapi_layout_test_plugin.ilk',
+ 'npapi_layout_test_plugin.pdb'
+ ], input_files)
+
+ # TODO(sgk): goes away when env.ChromeSharedLibrary() knows how
+ # to do this for us.
+ env.Install('$LIBS_DIR', dll[1])
+else:
+ dll = env.ChromeSharedLibrary(['npapi_layout_test_plugin'], input_files)
-i = env.Install('$MAIN_DIR/Hammer', dll[0])
+i = env.Install('$TARGET_ROOT/plugins', dll)
env.Alias('webkit', i)
+
+i = env.Install('$TARGET_ROOT', dll)
+env.Alias('webkit', i)
+
diff --git a/webkit/tools/test_shell/SConscript b/webkit/tools/test_shell/SConscript
index 03d5c3f..1fd70e631 100644
--- a/webkit/tools/test_shell/SConscript
+++ b/webkit/tools/test_shell/SConscript
@@ -25,7 +25,6 @@ env.Append(
'$WEBKIT_DIR/glue',
'$GTEST_DIR/include',
],
- LIBPATH = ['$V8_DIR'],
LIBS = [
'test_shell',
'glue',
@@ -93,16 +92,12 @@ elif env['PLATFORM'] in ('posix', 'darwin'):
]
)
-common_objs = [env.ChromeObject(i) for i in [
+input_files = [
'test_navigation_controller.cc',
'test_shell_switches.cc',
-]]
-
-
-input_files = [
- common_objs,
]
if env['PLATFORM'] == 'win32':
+ # TODO(port): put portable files in above test_files declaration.
input_files.extend([
'drag_delegate.cc',
'drop_delegate.cc',
@@ -133,13 +128,13 @@ if env['PLATFORM'] == 'win32':
# TODO(port): figure out what to do with resources.
resources = [
env_res.RES('resources/test_shell.rc'),
- '$OBJ_ROOT/net/net_resources.res',
+ '$NET_DIR/net_resources.res',
'$WEBKIT_DIR/build/localized_strings/webkit_strings_en-US.res',
]
exe_input_files = [
'test_shell_main.cc',
- '$V8_DIR/obj/release/snapshot-empty$OBJSUFFIX'
+ '$V8_DIR/snapshot-empty$OBJSUFFIX'
]
elif env['PLATFORM'] == 'posix':
exe_input_files = [
@@ -155,52 +150,33 @@ if env['PLATFORM'] == 'win32':
env.Depends(test_shell, '$V8_DIR/vc80.pdb')
test_files = [
- common_objs,
- 'image_decoder_unittest.cc',
- 'keyboard_unittest.cc',
- 'layout_test_controller_unittest.cc',
- 'node_leak_test.cc',
- 'plugin_tests.cc',
- 'run_all_tests.cc',
- 'test_shell_test.cc',
- 'text_input_controller_unittest.cc',
- '$WEBKIT_DIR/glue/autocomplete_input_listener_unittest.cc',
- '$WEBKIT_DIR/glue/bookmarklet_unittest.cc',
- '$WEBKIT_DIR/glue/context_menu_unittest.cc',
- '$WEBKIT_DIR/glue/cpp_bound_class_unittest.cc',
- '$WEBKIT_DIR/glue/cpp_variant_unittest.cc',
- '$WEBKIT_DIR/glue/dom_operations_unittest.cc',
- '$WEBKIT_DIR/glue/dom_serializer_unittest.cc',
- '$WEBKIT_DIR/glue/glue_serialize_unittest.cc',
- '$WEBKIT_DIR/glue/iframe_redirect_unittest.cc',
- '$WEBKIT_DIR/glue/mimetype_unittest.cc',
- '$WEBKIT_DIR/glue/multipart_response_delegate_unittest.cc',
- '$WEBKIT_DIR/glue/password_autocomplete_listener_unittest.cc',
- '$WEBKIT_DIR/glue/regular_expression_unittest.cc',
- '$WEBKIT_DIR/glue/resource_fetcher_unittest.cc',
- # Commented out until a regression is fixed and this file is restored.
- #'$WEBKIT_DIR/glue/stringimpl_unittest.cc',
- '$WEBKIT_DIR/glue/webframe_unittest.cc',
- '$WEBKIT_DIR/glue/webplugin_impl_unittest.cc',
- '$WEBKIT_DIR/port/platform/GKURL_unittest.cpp',
- '$WEBKIT_DIR/port/platform/image-decoders/bmp/BMPImageDecoder_unittest.cpp',
- '$WEBKIT_DIR/port/platform/image-decoders/ico/ICOImageDecoder_unittest.cpp',
- '$WEBKIT_DIR/port/platform/image-decoders/xbm/XBMImageDecoder_unittest.cpp',
-
- '$V8_DIR/obj/release/snapshot-empty$OBJSUFFIX',
+ 'run_all_tests.cc',
]
if env['PLATFORM'] == 'win32':
# TODO(port): put portable files in above test_files declaration.
test_files.extend([
+ 'drag_delegate.cc',
+ 'drop_delegate.cc',
+ 'event_sending_controller.cc',
'image_decoder_unittest.cc',
'keyboard_unittest.cc',
+ 'layout_test_controller.cc',
'layout_test_controller_unittest.cc',
'node_leak_test.cc',
'plugin_tests.cc',
'run_all_tests.cc',
+ 'simple_resource_loader_bridge.cc',
+ 'test_navigation_controller.cc',
+ 'test_shell.cc',
+ 'test_shell_request_context.cc',
+ 'test_shell_switches.cc',
'test_shell_test.cc',
+ 'test_webview_delegate.cc',
+ 'text_input_controller.cc',
'text_input_controller_unittest.cc',
+ 'webview_host.cc',
+ 'webwidget_host.cc',
'$WEBKIT_DIR/glue/autocomplete_input_listener_unittest.cc',
'$WEBKIT_DIR/glue/bookmarklet_unittest.cc',
'$WEBKIT_DIR/glue/context_menu_unittest.cc',
@@ -224,10 +200,11 @@ if env['PLATFORM'] == 'win32':
'$WEBKIT_DIR/port/platform/image-decoders/ico/ICOImageDecoder_unittest.cpp',
'$WEBKIT_DIR/port/platform/image-decoders/xbm/XBMImageDecoder_unittest.cpp',
- '$V8_DIR/obj/release/snapshot-empty$OBJSUFFIX'
+ '$V8_DIR/snapshot-empty$OBJSUFFIX',
])
test_shell_tests = env.ChromeTestProgram('test_shell_tests',
resources + test_files)
i = env.Install('$TARGET_ROOT', test_shell_tests)
env.Alias('webkit', i)
+