summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbradnelson@chromium.org <bradnelson@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2008-10-17 23:44:26 +0000
committerbradnelson@chromium.org <bradnelson@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2008-10-17 23:44:26 +0000
commitdfcec23417f5ac504a257f1c740404df69826792 (patch)
tree2939b84952c63d2de47d2aaeaa4d469ab17cef79
parent63c2f1af4de7286e8f8b19f4921870a00fae64df (diff)
downloadchromium_src-dfcec23417f5ac504a257f1c740404df69826792.zip
chromium_src-dfcec23417f5ac504a257f1c740404df69826792.tar.gz
chromium_src-dfcec23417f5ac504a257f1c740404df69826792.tar.bz2
Applying software construction toolkit patterns in scons build.
Review URL: http://codereview.chromium.org/6569 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@3578 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, 509 insertions, 534 deletions
diff --git a/base/SConscript b/base/SConscript
index 2d7e8a7..ef462d9 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.ChromeTestProgram('debug_message', ['debug_message.cc'])
+ env_tests.ChromeProgram('debug_message', ['debug_message.cc'])
test_files.extend([
'directory_watcher_unittest.cc',
@@ -336,8 +336,9 @@ if env['PLATFORM'] == 'darwin':
base_unittests = env_tests.ChromeTestProgram('base_unittests', test_files)
-# Install up a level to allow unit test path assumptions to be valid.
-installed_base_unittests = env.Install('$TARGET_ROOT', base_unittests)
+# 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')
sconscript_dirs = [
diff --git a/base/gfx/SConscript b/base/gfx/SConscript
index c862193..57d1b54 100644
--- a/base/gfx/SConscript
+++ b/base/gfx/SConscript
@@ -6,10 +6,12 @@ Import('env')
env = env.Clone()
-# 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('..')
+# This path causing linux to grab the wrong time.h
+env.FilterOut(
+ CPPPATH = [
+ '$MAIN_DIR/..',
+ ],
+)
env.Prepend(
CPPPATH = [
@@ -20,7 +22,6 @@ env.Prepend(
'$LIBPNG_DIR',
'$ICU38_DIR/public/common',
'$ICU38_DIR/public/i18n',
- '../..',
],
CPPDEFINES = [
'PNG_USER_CONFIG',
@@ -62,6 +63,7 @@ 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',
@@ -74,4 +76,3 @@ elif env['PLATFORM'] == 'posix':
])
env.ChromeStaticLibrary('base_gfx', input_files)
-
diff --git a/build/SConscript.googleurl b/build/SConscript.googleurl
index 11ca7c7..4407afc 100644
--- a/build/SConscript.googleurl
+++ b/build/SConscript.googleurl
@@ -28,34 +28,25 @@ if env['PLATFORM'] == 'win32':
)
lib_input_files = [
- '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',
+ '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',
]
-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.ChromeStaticLibrary('googleurl', lib_input_files)
env_tests = env.Clone()
@@ -75,21 +66,20 @@ env_tests.Append(
)
test_files = [
- 'gurl_unittest.cc',
- 'url_canon_unittest.cc',
- 'url_parse_unittest.cc',
- 'url_util_unittest.cc',
+ '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'),
]
-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.
-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)
+gurl_unittests = env_tests.ChromeTestProgram('googleurl_unittests', test_files)
-installed_gurl_unittests = env.Install('$TARGET_ROOT', gurl_unittests)
+installed_gurl_unittests = env.Replicate('$MAIN_DIR/Hammer', gurl_unittests)
env.Alias('googleurl', installed_gurl_unittests)
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)
diff --git a/build/SConscript.v8 b/build/SConscript.v8
index 8eeef09..7820f16 100644
--- a/build/SConscript.v8
+++ b/build/SConscript.v8
@@ -2,6 +2,9 @@
# 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.
@@ -22,13 +25,16 @@ 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_obj = env.File('$V8_MODE_DIR/libraries${OBJSUFFIX}')
libraries_empty_obj = env.File('$V8_MODE_DIR/libraries-empty${OBJSUFFIX}')
+libraries_obj = env.File('$V8_MODE_DIR/libraries${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}')
@@ -64,20 +70,13 @@ 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 dd84b36..4afcb75 100644
--- a/chrome/SConstruct
+++ b/chrome/SConstruct
@@ -5,4 +5,3 @@
build_component = 'chrome'
SConscript('../build/SConscript.main',
exports=['build_component'])
-
diff --git a/net/SConscript b/net/SConscript
index 37d6c18..b862b91 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,6 +221,9 @@ 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',
@@ -244,7 +247,6 @@ 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',
@@ -254,6 +256,7 @@ 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':
@@ -286,12 +289,12 @@ if env['PLATFORM'] in ('posix', 'win32'):
net_perftests = env_tests.ChromeTestProgram(
'net_perftests',
- ['disk_cache/disk_cache_test_util.cc',
- 'disk_cache/disk_cache_perftest.cc',
+ ['disk_cache/disk_cache_perftest.cc',
+ disk_cache_test_util,
'base/cookie_monster_perftest.cc',
# TODO(sgk): avoid using .cc from base directly
- '$BASE_DIR/run_all_perftests$OBJSUFFIX',
- '$BASE_DIR/perftimer$OBJSUFFIX']
+ '$OBJ_ROOT/base/run_all_perftests$OBJSUFFIX',
+ '$OBJ_ROOT/base/perftimer$OBJSUFFIX']
)
install_targets.extend([
@@ -302,13 +305,13 @@ if env['PLATFORM'] == 'win32':
stress_cache = env_tests.ChromeTestProgram(
'stress_cache',
['disk_cache/stress_cache.cc',
- 'disk_cache/disk_cache_test_util.cc']
+ disk_cache_test_util],
)
crash_cache = env_tests.ChromeTestProgram(
'crash_cache',
['tools/crash_cache/crash_cache.cc',
- 'disk_cache/disk_cache_test_util.cc']
+ disk_cache_test_util],
)
install_targets.extend([
@@ -317,14 +320,14 @@ if env['PLATFORM'] == 'win32':
])
-# Create install of tests.
-installed_tests = env.Install('$TARGET_ROOT', install_targets)
+# Install tests where the buildbot expects them.
+installed_tests = env.Install('$MAIN_DIR/Hammer', install_targets)
if env['PLATFORM'] == 'win32':
- env_res.Append(
+ env_res.Prepend(
CPPPATH = [
- '..',
+ '$ROOT_DIR',
],
RCFLAGS = [
['/l', '0x409'],
diff --git a/net/tools/tld_cleanup/SConscript b/net/tools/tld_cleanup/SConscript
index 5ab7e82..415bef7 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,4 +49,3 @@ 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 8914ba2..961257b 100644
--- a/sandbox/src/SConscript
+++ b/sandbox/src/SConscript
@@ -10,6 +10,7 @@ env = env.Clone()
# in the base env here, not just in env_tests.
env.Prepend(
CPPPATH = [
+ '$ROOT_DIR',
'$GTEST_DIR/include',
'$GTEST_DIR',
'../..',
@@ -27,8 +28,10 @@ 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',
@@ -158,6 +161,8 @@ 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')
@@ -201,6 +206,8 @@ 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')
@@ -233,7 +240,8 @@ 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',
@@ -249,11 +257,10 @@ validation_tests = env_validation_tests.ChromeTestProgram(
)
-# Install tests to a path where they can find their inputs.
-installed_tests = env.Install('$OBJ_ROOT',
+# Install tests to where the buildbot expects them for now.
+installed_tests = env.Install('$MAIN_DIR/Hammer',
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 e1408c8..176f29f 100644
--- a/third_party/bsdiff/SConscript
+++ b/third_party/bsdiff/SConscript
@@ -34,7 +34,7 @@ env = env.Clone()
env.Prepend(
CPPPATH = [
- '../bspatch',
+ '$BSPATCH_DIR',
]
)
diff --git a/webkit/SConscript b/webkit/SConscript
index 519e809..3ea66af 100644
--- a/webkit/SConscript
+++ b/webkit/SConscript
@@ -81,7 +81,9 @@ 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',
@@ -91,8 +93,8 @@ env.Prepend(
'$SKIA_DIR/platform',
'$NPAPI_DIR',
'$V8_DIR/include',
- '$WEBKIT_DIR/V8Bindings/DerivedSources',
- '$WEBKIT_DIR/V8Bindings/SharedSources',
+ '$DERIVED_DIR',
+ '$SHARED_DIR',
'$WEBKIT_DIR/port/bindings/v8',
'$WEBKIT_DIR/WebCore',
'$WEBKIT_DIR/WebCore/JavaScriptHeaders',
@@ -144,10 +146,13 @@ 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",
@@ -159,8 +164,8 @@ env.Append(
PCRE_DIR = "$JAVASCRIPTCORE_DIR/pcre",
V8BINDINGS_DIR = "$WEBKIT_DIR/V8Bindings",
- DERIVED_DIR = env.Dir("$WEBKIT_DIR/V8Bindings/DerivedSources"),
- SHARED_DIR = env.Dir("$WEBKIT_DIR/V8Bindings/SharedSources"),
+ DERIVED_DIR = "$WEBKIT_DIR/V8Bindings/DerivedSources",
+ SHARED_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
@@ -280,4 +285,3 @@ 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 cf235e6..bf2c5fc2 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,4 +41,3 @@ input_files = [
]
env.ChromeStaticLibrary('activex_shim', input_files)
-
diff --git a/webkit/activex_shim_dll/SConscript b/webkit/activex_shim_dll/SConscript
index a4dc1b2..29d4092 100644
--- a/webkit/activex_shim_dll/SConscript
+++ b/webkit/activex_shim_dll/SConscript
@@ -44,6 +44,5 @@ input_files = [
]
dll = env.ChromeSharedLibrary('npaxshim', input_files)
-i = env.Install('$TARGET_ROOT', dll)
+i = env.Replicate('$MAIN_DIR/Hammer', dll[0])
env.Alias('webkit', i)
-
diff --git a/webkit/build/port/SConscript b/webkit/build/port/SConscript
index b1e27e2..7a9de8f 100644
--- a/webkit/build/port/SConscript
+++ b/webkit/build/port/SConscript
@@ -16,7 +16,6 @@ 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):
@@ -477,7 +476,7 @@ idl_files = [
]
for subdir in set([os.path.dirname(n) for n in idl_files]):
- dir = env.Dir('#/$BUILD_TYPE/webkit/port/' + subdir)
+ dir = env.Dir('$OBJ_ROOT/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 571e64d..2cad465 100644
--- a/webkit/default_plugin/SConscript
+++ b/webkit/default_plugin/SConscript
@@ -14,6 +14,8 @@ env.Prepend(
'#/../third_party/libxml/include',
'#/../third_party/npapi',
'#/..',
+# TODO(bradnelson): this might be needed?
+# '$OBJ_ROOT/webkit/build/localized_strings',
],
)
@@ -51,4 +53,3 @@ 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 3e90365..bfdc821 100644
--- a/webkit/glue/plugins/test/SConscript
+++ b/webkit/glue/plugins/test/SConscript
@@ -69,18 +69,7 @@ if env['PLATFORM'] == 'win32':
],
)
- dll = env.ChromeSharedLibrary([
- 'npapi_test_plugin',
- 'npapi_test_plugin.lib',
- 'npapi_test_plugin.ilk',
- 'npapi_test_plugin.pdb'
- ], input_files)
+dll = env.ChromeSharedLibrary('npapi_test_plugin', input_files)
- # 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)
+i = env.Replicate('$MAIN_DIR/Hammer', dll[0])
env.Alias('webkit', i)
-
diff --git a/webkit/tools/npapi_layout_test_plugin/SConscript b/webkit/tools/npapi_layout_test_plugin/SConscript
index 4b2da51..329fb92 100644
--- a/webkit/tools/npapi_layout_test_plugin/SConscript
+++ b/webkit/tools/npapi_layout_test_plugin/SConscript
@@ -45,23 +45,7 @@ if env['PLATFORM'] == 'win32':
],
)
-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)
+ dll = env.ChromeSharedLibrary('npapi_layout_test_plugin', input_files)
-i = env.Install('$TARGET_ROOT/plugins', dll)
+i = env.Install('$MAIN_DIR/Hammer', dll[0])
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 1fd70e631..03d5c3f 100644
--- a/webkit/tools/test_shell/SConscript
+++ b/webkit/tools/test_shell/SConscript
@@ -25,6 +25,7 @@ env.Append(
'$WEBKIT_DIR/glue',
'$GTEST_DIR/include',
],
+ LIBPATH = ['$V8_DIR'],
LIBS = [
'test_shell',
'glue',
@@ -92,12 +93,16 @@ elif env['PLATFORM'] in ('posix', 'darwin'):
]
)
-input_files = [
+common_objs = [env.ChromeObject(i) for i in [
'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',
@@ -128,13 +133,13 @@ if env['PLATFORM'] == 'win32':
# TODO(port): figure out what to do with resources.
resources = [
env_res.RES('resources/test_shell.rc'),
- '$NET_DIR/net_resources.res',
+ '$OBJ_ROOT/net/net_resources.res',
'$WEBKIT_DIR/build/localized_strings/webkit_strings_en-US.res',
]
exe_input_files = [
'test_shell_main.cc',
- '$V8_DIR/snapshot-empty$OBJSUFFIX'
+ '$V8_DIR/obj/release/snapshot-empty$OBJSUFFIX'
]
elif env['PLATFORM'] == 'posix':
exe_input_files = [
@@ -150,33 +155,52 @@ if env['PLATFORM'] == 'win32':
env.Depends(test_shell, '$V8_DIR/vc80.pdb')
test_files = [
- 'run_all_tests.cc',
+ 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',
]
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',
@@ -200,11 +224,10 @@ 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/snapshot-empty$OBJSUFFIX',
+ '$V8_DIR/obj/release/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)
-