diff options
author | bradnelson@chromium.org <bradnelson@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-10-20 23:29:20 +0000 |
---|---|---|
committer | bradnelson@chromium.org <bradnelson@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-10-20 23:29:20 +0000 |
commit | 1bdfd82cea4f30a5751a19c8283b05f34612a818 (patch) | |
tree | d41f92852dc4b90c2bf4b469252e535761e27152 | |
parent | 126a6c706d0db79f5af75b1f019b831cf9680e70 (diff) | |
download | chromium_src-1bdfd82cea4f30a5751a19c8283b05f34612a818.zip chromium_src-1bdfd82cea4f30a5751a19c8283b05f34612a818.tar.gz chromium_src-1bdfd82cea4f30a5751a19c8283b05f34612a818.tar.bz2 |
Rolling back switch to hammer patterns again.
Review URL: http://codereview.chromium.org/7530
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@3637 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | base/SConscript | 16 | ||||
-rw-r--r-- | base/gfx/SConscript | 13 | ||||
-rw-r--r-- | build/SConscript.googleurl | 64 | ||||
-rw-r--r-- | build/SConscript.main | 759 | ||||
-rw-r--r-- | build/SConscript.v8 | 25 | ||||
-rw-r--r-- | net/SConscript | 29 | ||||
-rw-r--r-- | net/tools/tld_cleanup/SConscript | 3 | ||||
-rw-r--r-- | sandbox/src/SConscript | 17 | ||||
-rw-r--r-- | third_party/bsdiff/SConscript | 2 | ||||
-rw-r--r-- | webkit/SConscript | 16 | ||||
-rw-r--r-- | webkit/activex_shim/SConscript | 3 | ||||
-rw-r--r-- | webkit/activex_shim_dll/SConscript | 3 | ||||
-rw-r--r-- | webkit/build/port/SConscript | 3 | ||||
-rw-r--r-- | webkit/default_plugin/SConscript | 3 | ||||
-rw-r--r-- | webkit/glue/plugins/test/SConscript | 15 | ||||
-rw-r--r-- | webkit/tools/npapi_layout_test_plugin/SConscript | 20 | ||||
-rw-r--r-- | webkit/tools/test_shell/SConscript | 63 |
17 files changed, 533 insertions, 521 deletions
diff --git a/base/SConscript b/base/SConscript index 1248f71..fbb0516 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', @@ -192,7 +192,7 @@ env_tests.Prepend( '$LIBPNG_DIR', '$ICU38_DIR/public/common', '$ICU38_DIR/public/i18n', - '$ROOT_DIR', + '..', ], CPPDEFINES = [ 'UNIT_TEST', @@ -306,7 +306,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', @@ -338,14 +338,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) -if env['PLATFORM'] == 'win32': - icu_data = '$OBJ_ROOT/icudt38.dll' -else: - icu_data = '$OBJ_ROOT/icudt38l.dat' -icu_data = env.Replicate('$MAIN_DIR/Hammer', icu_data) -env.Requires(installed_base_unittests, icu_data) +# 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 6a7da71..72b8004 100644 --- a/build/SConscript.main +++ b/build/SConscript.main @@ -7,27 +7,6 @@ import shutil import sys - -# Overlay things from a layer below. -Dir('base').addRepository(Dir('../base')) -Dir('breakpad').addRepository(Dir('../breakpad')) -Dir('gears').addRepository(Dir('../gears')) -Dir('net').addRepository(Dir('../net')) -Dir('rlz').addRepository(Dir('../rlz')) -Dir('sandbox').addRepository(Dir('../sandbox')) -Dir('skia').addRepository(Dir('../skia')) -Dir('sdch').addRepository(Dir('../sdch')) -Dir('testing').addRepository(Dir('../testing')) -Dir('third_party').addRepository(Dir('../third_party')) -Dir('webkit').addRepository(Dir('../webkit')) - -# This one is somewhat special. -Dir('../build').addRepository(Dir('../googleurl')) - - -#----------------------------------------------------------------------- - - p = ARGUMENTS.get('PROGRESS') if p == 'spinner': Progress(['/\r', '|\r', '\\\r', '-\r'], interval=5, file=open('con', 'w')) @@ -46,17 +25,18 @@ else: load = [] -base_env = Environment(tools = ['component_setup']) -base_env.Replace( - # $MAIN_DIR refers to the directory in which the SConstruct lives. - # $ROOT_DIR is src/ - ROOT_DIR = '$MAIN_DIR/..', +env = Environment( + BUILD_TYPE = ARGUMENTS.get('BUILD_TYPE', 'Hammer'), + TARGET_ROOT = '#/$BUILD_TYPE', + OBJ_ROOT = '$TARGET_ROOT', + + LIBS_DIR = '#/$BUILD_TYPE/Libs', - BASE_DIR = '$ROOT_DIR/base', - BREAKPAD_DIR = '$ROOT_DIR/breakpad', - CHROME_DIR = '$ROOT_DIR/chrome', - GEARS_DIR = '$ROOT_DIR/gears', - GOOGLE_UPDATE_DIR = '$ROOT_DIR/google_update', + BASE_DIR = '#/$BUILD_TYPE/base', + BREAKPAD_DIR = '#/$BUILD_TYPE/breakpad', + CHROME_DIR = '#/$BUILD_TYPE/chrome', + GEARS_DIR = '#/$BUILD_TYPE/gears', + GOOGLE_UPDATE_DIR = '#/$BUILD_TYPE/google_update', # Work around a limitation (bug?) in SCons in that, when we build # from a different directory, it forces the build targets defined @@ -65,18 +45,18 @@ base_env.Replace( # the SConstruct directory from which SCons was launched. When # we roll forward to a version of SCons that fixes this, we'll # need to revert to the $BUILD_TYPE definition of GOOGLEURL_DIR. - - GOOGLEURL_DIR = '$ROOT_DIR/build/googleurl', - - NET_DIR = '$ROOT_DIR/net', - RLZ_DIR = '$ROOT_DIR/rlz', - SANDBOX_DIR = '$ROOT_DIR/sandbox', - SDCH_DIR = '$ROOT_DIR/sdch', - SKIA_DIR = '$ROOT_DIR/skia', - TESTING_DIR = '$ROOT_DIR/testing', - THIRD_PARTY_DIR = '$ROOT_DIR/third_party', - V8_DIR = '$ROOT_DIR/v8', - WEBKIT_DIR = '$ROOT_DIR/webkit', + #GOOGLEURL_DIR = '#/$BUILD_TYPE/googleurl', + GOOGLEURL_DIR = '#/../build/googleurl', + + NET_DIR = '#/$BUILD_TYPE/net', + RLZ_DIR = '#/$BUILD_TYPE/rlz', + SANDBOX_DIR = '#/$BUILD_TYPE/sandbox', + SDCH_DIR = '#/$BUILD_TYPE/sdch', + SKIA_DIR = '#/$BUILD_TYPE/skia', + TESTING_DIR = '#/$BUILD_TYPE/testing', + THIRD_PARTY_DIR = '#/$BUILD_TYPE/third_party', + V8_DIR = '#/$BUILD_TYPE/v8', + WEBKIT_DIR = '#/$BUILD_TYPE/webkit', GTEST_DIR = '$TESTING_DIR/gtest', @@ -91,51 +71,14 @@ base_env.Replace( LIBXSLT_DIR = '$THIRD_PARTY_DIR/libxslt', LZMA_SDK_DIR = '$THIRD_PARTY_DIR/lzma_sdk', MODP_B64_DIR = '$THIRD_PARTY_DIR/modp_b64', - NPAPI_DIR = '$ROOT_DIR/third_party/npapi', + NPAPI_DIR = '$THIRD_PARTY_DIR/npapi', ZLIB_DIR = '$THIRD_PARTY_DIR/zlib', - THIRD_PARTY_WEBKIT_DIR = '$ROOT_DIR/third_party/WebKit', + THIRD_PARTY_WEBKIT_DIR = '$THIRD_PARTY_DIR/WebKit', PYTHON=sys.executable, - # This is temporarily in flux. - # Currently these are all relative to src/build, with the additional, - # wrinkle that several addRepository lines at the top of this file cause - # everything in src to be conceptually underlayed in src/build. - # Thus things like src/SConscript.googleurl are listed directly, - # but things like base/SConscript are down a layer. - # Some of this will hopefully get cleaner if we move the SConstruct up a - # layer. - BUILD_SCONSCRIPTS = [ - 'base/SConscript', - 'breakpad/SConscript', - #'chrome/SConscript', - #'gears/SConscript', - #'google_update_dir/SConscript', - 'SConscript.googleurl', - 'net/SConscript', - 'rlz/SConscript', - 'sandbox/src/SConscript', - 'sdch/SConscript', - 'skia/SConscript', - - 'testing/SConscript.gtest', - - 'third_party/bsdiff/SConscript', - 'third_party/bzip2/SConscript', - 'third_party/icu38/SConscript', - 'third_party/libpng/SConscript', - 'third_party/lzma_sdk/SConscript', - 'third_party/modp_b64/SConscript', - 'third_party/zlib/SConscript', - - 'third_party/libjpeg/SConscript', - 'third_party/libxml/SConscript', - 'third_party/libxslt/SConscript', - - 'SConscript.v8', - 'webkit/SConscript', - ], + LIBPATH = ['$LIBS_DIR'], PERL = 'perl', PERL_INCLUDE_FLAG = '-I ', @@ -146,62 +89,87 @@ base_env.Replace( '__env__, RDirs, TARGET, SOURCE)}'), ) +def AddPdbToTarget(args): + """Add the windows pdb file to the build target. + + Arguments: + args is a tuple passed to ChromeProgram or ChromeTestProgram + Returns: + A tuple to pass on to Environment.Program.""" + # Only add .pdb to the target if the target was only a string. We can't + # blindly add foo.pdb because chrome.exe and chrome.dll use chrome_exe.pdb + # and chrome_dll.pdb. + if not isinstance(args[0], str): + return args + + mutable_args = list(args) + mutable_args[0] = [args[0], args[0] + '.pdb'] + return tuple(mutable_args) + def ChromeProgram(env, *args, **kw): - return env.ComponentProgram(*args, **kw) -base_env.AddMethod(ChromeProgram) + if env['PLATFORM'] == 'win32': + # TODO(tc): We should handle kw['target'] too. + args = AddPdbToTarget(args) + return env.Program(*args, **kw) +env.AddMethod(ChromeProgram, "ChromeProgram") def ChromeTestProgram(env, *args, **kw): - return env.ComponentTestProgram(*args, **kw) -base_env.AddMethod(ChromeTestProgram) + if env['PLATFORM'] == 'win32': + # TODO(tc): We should handle kw['target'] too. + args = AddPdbToTarget(args) + return env.Program(*args, **kw) +env.AddMethod(ChromeTestProgram, "ChromeTestProgram") def ChromeStaticLibrary(env, *args, **kw): - kw['COMPONENT_STATIC'] = True - return env.ComponentLibrary(*args, **kw) -base_env.AddMethod(ChromeStaticLibrary) + result = env.StaticLibrary(*args, **kw) + if env['PLATFORM'] == 'win32': + # TODO(sgk): + # We'd like to do this with env.Install() like we do on other systems, + # but this causes problems on Windows when the Python copy of the file + # in one thread prevents a linker spawned by another thread from + # opening the copied .lib, despite the fact that the copy has + # successfully concluded before the spawn occurs. Work around the + # underlying problem (whatever it is) by calling the external Windows + # xcopy utility. + env.Command('$LIBS_DIR/${RESULT.name}', '$RESULT', + "xcopy /q /y $SOURCE ${TARGET.dir}", + RESULT=result[0]) + else: + env.Install('$LIBS_DIR', result) + return result +env.AddMethod(ChromeStaticLibrary, "ChromeStaticLibrary") def ChromeSharedLibrary(env, *args, **kw): - kw['COMPONENT_STATIC'] = False - return env.ComponentLibrary(*args, **kw) -base_env.AddMethod(ChromeSharedLibrary) - -def ChromeObject(env, *args, **kw): - return env.ComponentObject(*args, **kw) -base_env.AddMethod(ChromeObject) - - -if ARGUMENTS.get('VERBOSE') in (None, '0'): - base_env['CCCOMSTR'] = 'Compiling $TARGET ...' - base_env['CXXCOMSTR'] = 'Compiling $TARGET ...' - base_env['SHCCCOMSTR'] = 'Compiling $TARGET ...' - base_env['SHCXXCOMSTR'] = 'Compiling $TARGET ...' - base_env['ARCOMSTR'] = 'Archiving $TARGET ...' - base_env['LINKCOMSTR'] = 'Linking $TARGET ...' - base_env['BINDINGSCOMSTR'] = 'Building bindings in $TARGET ...' - - - - + return env.SharedLibrary(*args, **kw) +env.AddMethod(ChromeSharedLibrary, "ChromeSharedLibrary") +if env['PLATFORM'] == 'win32': + processors = int(os.environ.get('NUMBER_OF_PROCESSORS', 1)) + SetOption('num_jobs', processors + 1) -#----------------------------------------------------------------------- - + msvs_env = Environment(tools=['msvc', 'mslink', 'msvs'])['ENV'] + # Use the absolute path for MSVC because it might not be on the same drive + # as our source checkout. + visual_studio_path = (msvs_env['PATH'][0] + + ':/Program Files/Microsoft Visual Studio 8') -# Create environment from which all Windows variants derive. -windows_env = base_env.Clone(tools = ['target_platform_windows']) -windows_env.Replace( + env.Replace( CSCRIPT = 'c:\\Windows\\System32\\cscript', PLATFORMSDK_VISTA_REL = '../third_party/platformsdk_vista_6_0', PLATFORMSDK_VISTA = '#/$PLATFORMSDK_VISTA_REL', + VISUAL_STUDIO = visual_studio_path, - CYGWIN_DIR = '$MAIN_DIR/../third_party/cygwin', + CYGWIN_DIR = Dir('#../third_party/cygwin'), CYGWIN_BIN_DIR = '$CYGWIN_DIR/bin', PERL = '$CYGWIN_BIN_DIR/perl.exe', + MSVS_ENV = msvs_env, + YACC = '$CYGWIN_BIN_DIR/bison.exe', ARFLAGS = [ @@ -254,104 +222,113 @@ windows_env.Replace( '$PLATFORMSDK_VISTA/files/Include', '$PLATFORMSDK_VISTA/files/VC/INCLUDE', '$VISUAL_STUDIO/VC/atlmfc/include', - '$MAIN_DIR/..', ], LIBS = [ - 'advapi32', - 'comdlg32', - 'gdi32', - 'kernel32', - 'msimg32', - 'odbc32', - 'odbccp32', - 'ole32', - 'oleaut32', - 'psapi', - 'shell32', - 'user32', - 'usp10', - 'uuid', - 'version', - 'wininet', - 'winspool', - 'ws2_32', - - 'DelayImp', + 'advapi32.lib', + 'comdlg32.lib', + 'gdi32.lib', + 'kernel32.lib', + 'msimg32.lib', + 'odbc32.lib', + 'odbccp32.lib', + 'ole32.lib', + 'oleaut32.lib', + 'psapi.lib', + 'shell32.lib', + 'user32.lib', + 'usp10.lib', + 'uuid.lib', + 'version.lib', + 'wininet.lib', + 'winspool.lib', + 'ws2_32.lib', + + 'DelayImp.lib', ], LINKFLAGS = [ '/nologo', '/DEBUG', ], + ICU_LIBS = ['icu'], ) -windows_env.Append( + env.Append( LIBPATH = [ '$PLATFORMSDK_VISTA/files/Lib', '$PLATFORMSDK_VISTA/files/VC/LIB', '$VISUAL_STUDIO/VC/atlmfc/lib', ], -) - -# Remove manifest gunk for now. -windows_env['LINKCOM'] = windows_env['LINKCOM'][0] -windows_env['SHLINKCOM'] = windows_env['SHLINKCOM'][0] - -# TODO(sgk): find a more elegant way of doing this. -if base_env['PLATFORM'] == 'win32': - msvs_env = Environment(tools=['msvc', 'mslink', 'msvs'])['ENV'] - windows_env['VISUAL_STUDIO'] = (msvs_env['PATH'][0] + - ':/Program Files/Microsoft Visual Studio 8') - -# TODO(bradnelson): find a cleaner way of doing this. -# Force scons to handle long include lines correctly. -pchcom_fixed = windows_env['PCHCOM'] -pchcom_fixed = pchcom_fixed.replace('${TARGETS[0]}', '$TARGET') -pchcom_fixed = pchcom_fixed.replace('${TARGETS[1]}', '$TARGETS1') - -windows_env.Replace( - CCCOM = "${TEMPFILE('%s')}" % windows_env['CCCOM'], - CXXCOM = "${TEMPFILE('%s')}" % windows_env['CXXCOM'], - SHCCCOM = "${TEMPFILE('%s')}" % windows_env['SHCCCOM'], - SHCXXCOM = "${TEMPFILE('%s')}" % windows_env['SHCXXCOM'], - PCHCOM = "${TEMPFILE('%s')}" % pchcom_fixed, - TARGETS1 = '${TARGETS[1]}', -) - -# Create a debug windows variant. -debug_win_env = windows_env.Clone(tools = ['target_debug']) -debug_win_env.Replace( - BUILD_TYPE = 'debug-win', - BUILD_TYPE_DESCRIPTION = 'Windows debug variant', - BUILD_GROUPS = ['default'], -) - -# Create an optimized windows variant. -release_win_env = windows_env.Clone(tools = ['target_optimized']) -release_win_env.Replace( - BUILD_TYPE = 'release-win', - BUILD_TYPE_DESCRIPTION = 'Windows release variant', -) - - -#----------------------------------------------------------------------- - + ) + # TODO(sgk): remove once we upgrade to SCons 0.98.4 + for var in ['INCLUDE', 'LIB', 'PATH']: + msvs_env[var] = msvs_env[var].split('|', 1)[0] + env['ENV'][var] = env['ENV'][var].split('|', 1)[0] + + # Force scons to handle long include lines correctly. + pchcom_fixed = env['PCHCOM'] + pchcom_fixed = pchcom_fixed.replace('${TARGETS[0]}', '$TARGET') + pchcom_fixed = pchcom_fixed.replace('${TARGETS[1]}', '$TARGETS1') + + env.Replace( + CCCOM = "${TEMPFILE('%s')}" % env['CCCOM'], + CXXCOM = "${TEMPFILE('%s')}" % env['CXXCOM'], + SHCCCOM = "${TEMPFILE('%s')}" % env['SHCCCOM'], + SHCXXCOM = "${TEMPFILE('%s')}" % env['SHCXXCOM'], + PCHCOM = "${TEMPFILE('%s')}" % pchcom_fixed, + TARGETS1 = '${TARGETS[1]}', + ) -excluded_warnings = [ + env['ENV']['PROGRAMFILES'] = os.environ['PROGRAMFILES'] + env['ENV']['SystemDrive'] = os.environ['SystemDrive'] + env['ENV']['USERPROFILE'] = os.environ['USERPROFILE'] + + env.AppendENVPath('PATH', ';C:\\WINDOWS\\system32') + +elif env['PLATFORM'] == 'posix': + + # Copy some environment variables from the outer environment if they exist. + for envvar in ['CC', 'CXX']: + if envvar in os.environ: + env[envvar] = os.environ[envvar] + # Provide $HOME when compiling so distcc can find its lock file. + env['ENV']['HOME'] = os.environ['HOME'] + if 'DISTCC_HOSTS' in os.environ: + env['ENV']['DISTCC_HOSTS'] = os.environ['DISTCC_HOSTS'] + + # TODO(evanm): this is Linux-specific, not posix. + # Parse /proc/cpuinfo for processor count. + cpus = len([l for l in open('/proc/cpuinfo') if l.startswith('processor\t')]) + SetOption('num_jobs', cpus + 1) + + # For now, linux only loads the components we know work on Linux, by default. + load = [ + 'base', + 'breakpad', + 'chrome', + 'googleurl', + 'net', + 'sdch', + 'skia', + 'testing', + 'third_party', + 'v8', + 'webkit', + ] + + excluded_warnings = [ # TODO: Clean up uses of ext/hash_map and remove this. # (see unordered_map and base/hash_tables.h) - '-Wno-deprecated' # Needed for using ext/hash_map on GCC 4.3 -] - -# Create the base linux environment. -linux_env = base_env.Clone(tools = ['target_platform_linux']) -linux_env.Replace( - CCFLAGS = ['-m32', '-g', '-pthread'], - CXXFLAGS = ['-Wall', '-Werror'] + excluded_warnings, - LINKFLAGS = ['-m32', '-pthread'], + '-Wno-deprecated', # Needed for using ext/hash_map on GCC 4.3 + '-Wno-unknown-pragmas', # In wtf's ref counting system + ] + env.Replace( + CCFLAGS = ['-m32', '-g', '-pthread'], + CXXFLAGS = ['-Wall', '-Werror'] + excluded_warnings, + LINKFLAGS = ['-m32', '-pthread'], # We have several cases where archives depend on each other in a cyclic # fashion. (V8Bindings, libport and WebCore being the most significant @@ -370,131 +347,101 @@ linux_env.Replace( '-Wl,--start-group $_LIBFLAGS -Wl,--end-group'), # We need rt for clock_gettime. - LIBS = ['rt'], - ICU_LIBS = ['icu'], - - PERL = '/usr/bin/perl', - PERL_INCLUDE_FLAG = '-I ', - PERL_INCLUDE_SUFFIX = '', - _PERL_INCLUDE_FLAGS = ('${_concat(PERL_INCLUDE_FLAG, ' - 'PERL_INCLUDE_PATH, ' - 'PERL_INCLUDE_SUFFIX,' - '__env__, RDirs, TARGET, SOURCE)}'), -) - -# This conflicts with build_config.h -linux_env.FilterOut(CPPDEFINES= ['OS_LINUX=OS_LINUX']) - -linux_env.FilterOut( - BUILD_SCONSCRIPTS = [ - 'sandbox/src/SConscript', - 'third_party/libjpeg/SConscript', - 'third_party/libxml/SConscript', - 'third_party/libxslt/SConscript', - 'third_party/bspatch/SConscript', - 'webkit/SConscript', - ], -) - -linux_env.Append( - BUILD_SCONSCRIPTS = [ - 'third_party/libevent/SConscript', - ], -) - -# Build with support for gcov when COVERAGE=1. -if ARGUMENTS.get('COVERAGE') == '1': - linux_env.Append(CCFLAGS=['-fprofile-arcs', '-ftest-coverage']) - linux_env.Append(LINKFLAGS=['-fprofile-arcs']) - -# Build with system-provided NSS -if base_env['PLATFORM'] in ['posix', 'linux', 'linux2']: - linux_env.ParseConfig('pkg-config --cflags --libs nss') - linux_env.ParseConfig('pkg-config --cflags --libs glib-2.0') - linux_env.ParseConfig('pkg-config --cflags --libs gtk+-2.0') - -# Create a debug linux variant. -debug_linux_env = linux_env.Clone(tools = ['target_debug']) -debug_linux_env.Replace( - BUILD_TYPE = 'debug-linux', - BUILD_TYPE_DESCRIPTION = 'Linux debug variant', - BUILD_GROUPS = ['default'], -) - -# Create a optimized linux variant. -release_linux_env = linux_env.Clone(tools = ['target_optimized']) -release_linux_env.Replace( - BUILD_TYPE = 'release-linux', - BUILD_TYPE_DESCRIPTION = 'Linux release variant', -) - - - - -#----------------------------------------------------------------------- - + LIBS = ['rt'], + PERL = '/usr/bin/perl', + PERL_INCLUDE_FLAG = '-I ', + PERL_INCLUDE_SUFFIX = '', + _PERL_INCLUDE_FLAGS = ('${_concat(PERL_INCLUDE_FLAG, ' + 'PERL_INCLUDE_PATH, ' + 'PERL_INCLUDE_SUFFIX,' + '__env__, RDirs, TARGET, SOURCE)}'), -# Create the base environment for the mac variant. -mac_env = base_env.Clone(tools = ['target_platform_mac']) -mac_env.Replace( - # Reproduce XCode's behavior of using gcc even to link C++, - # and distinguishing it the -x c++ option. - CC = 'gcc-4.2', - CXX = 'g++-4.2', - LINK = '$CXX', + ICU_LIBS = ['icu'], + ) + # Build with support for gcov when COVERAGE=1. + if ARGUMENTS.get('COVERAGE') == '1': + env.Append(CCFLAGS=['-fprofile-arcs', '-ftest-coverage']) + env.Append(LINKFLAGS=['-fprofile-arcs']) + + # Build with system-provided NSS and GTK. + env.ParseConfig('pkg-config --cflags --libs nss') + env.ParseConfig('pkg-config --cflags --libs gtk+-2.0') + +elif env['PLATFORM'] == 'darwin': + + # For now, mac only loads the components we know work on Mac, by default. + load = [ + 'base', + #'breakpad', + 'googleurl', + 'net', + 'sdch', + 'skia', + 'testing', + 'third_party', + #'webkit', + ] + + env.Replace( + # Reproduce XCode's behavior of using gcc even to link C++, + # and distinguishing it the -x c++ option. + CC = 'gcc-4.2', + CXX = 'g++-4.2', + LINK = '$CXX', + + CFLAGS = [ + '-std=c99', + ], + CXXFLAGS = [ + '-fvisibility-inlines-hidden', + '${str(SOURCE).endswith(".mm") and "-fobjc-gc" or ""}', + ], + CCFLAGS = [ + '-fmessage-length=0', + '-pipe', + '-O0', + '-mdynamic-no-pic', + '-Werror', + '-Wnewline-eof', + '-fvisibility=hidden', + '-gdwarf-2', + '-Wall', + '-Wendif-labels', + '-fstack-protector', + '-fstack-protector-all', + ], + CPPDEFINES = [ + 'DEBUG', + ], + + FRAMEWORKPATH = [ + env.Dir('${TARGET_ROOT}'), + '/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks', + ], + FRAMEWORKS = [ + 'AppKit', + 'ApplicationServices', + 'Foundation', + ], + + ICU_LIBS = ['icui18n', 'icuuc', 'icudata'], + ) - CFLAGS = [ - '-std=c99', - ], - CXXFLAGS = [ - '-fvisibility-inlines-hidden', - '${str(SOURCE).endswith(".mm") and "-fobjc-gc" or ""}', - ], - CCFLAGS = [ - '-fmessage-length=0', - '-pipe', - '-O0', - '-mdynamic-no-pic', - '-Werror', - '-Wnewline-eof', - '-fvisibility=hidden', - '-gdwarf-2', - '-Wall', - '-Wendif-labels', - '-fstack-protector', - '-fstack-protector-all', - ], - CPPDEFINES = [ - 'DEBUG', - ], +else: - FRAMEWORKPATH = [ - '/System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks', - ], - FRAMEWORKS = [ - 'AppKit', - 'ApplicationServices', - 'Foundation', - ], - ICU_LIBS = ['icui18n', 'icuuc', 'icudata'], -) + print "Unsupported SCons $PLATFORM value %s" % repr(env['PLATFORM']) + Exit(1) -mac_env.FilterOut( - BUILD_SCONSCRIPTS = [ - 'third_party/libjpeg/SConscript', - 'third_party/libxml/SConscript', - 'third_party/libxslt/SConscript', - 'third_party/bspatch/SConscript', - 'webkit/SConscript', - ], -) -mac_env.Append( - BUILD_SCONSCRIPTS = [ - 'third_party/libevent/SConscript', - ], -) +if ARGUMENTS.get('VERBOSE') in (None, '0'): + env['CCCOMSTR'] = 'Compiling $TARGET ...' + env['CXXCOMSTR'] = 'Compiling $TARGET ...' + env['SHCCCOMSTR'] = 'Compiling $TARGET ...' + env['SHCXXCOMSTR'] = 'Compiling $TARGET ...' + env['ARCOMSTR'] = 'Archiving $TARGET ...' + env['LINKCOMSTR'] = 'Linking $TARGET ...' + env['BINDINGSCOMSTR'] = 'Building bindings in $TARGET ...' # Add --clobber (for the buildbot). @@ -502,73 +449,141 @@ mac_env.Append( AddOption('--clobber', action='store_true', dest='clobber', default=False, help='Delete build directory before building.') if GetOption('clobber'): - shutil.rmtree(base_env.Dir('$DESTINATION_ROOT').abspath, True) - -# Create a mac debug variant. -debug_mac_env = mac_env.Clone(tools = ['target_debug']) -debug_mac_env.Replace( - BUILD_TYPE = 'debug-mac', - BUILD_TYPE_DESCRIPTION = 'Mac debug variant', - BUILD_GROUPS = ['default'], -) + shutil.rmtree(env.Dir('$TARGET_ROOT').abspath, True) -# Create a mac opt variant. -release_mac_env = mac_env.Clone(tools = ['target_optimized']) -release_mac_env.Replace( - BUILD_TYPE = 'release-mac', - BUILD_TYPE_DESCRIPTION = 'Mac release variant', -) +# Place the .sconsign.dblite in the build directory. +target_dir = env.Dir('$TARGET_ROOT') +if not os.path.exists(target_dir.abspath): + Execute(Mkdir(target_dir)) +SConsignFile(target_dir.File('.sconsign').abspath) +# Use timestamps change, followed by MD5 for speed +env.Decider('MD5-timestamp') -#----------------------------------------------------------------------- +# Overlay things from a layer below. +env.Dir('$TARGET_ROOT').addRepository(Dir('..')) -Help(""" -PROGRESS=type Display a progress indicator: - name: print each evaluated target name - spinner: print a spinner every 5 targets -VERBOSE=1 Display full command lines -""") +included = [c for c in load if not c.startswith('-')] +excluded = [c[1:] for c in load if c.startswith('-')] +if not included: + included = ['all'] + +components = ['all'] + +def LoadComponent(c): + components.append(c) + return (not GetOption('help') and + c in included or + ('all' in included and not c in excluded)) + +sconscripts = [] + +if LoadComponent('base'): + sconscripts.append('$BASE_DIR/SConscript') + +if LoadComponent('breakpad'): + sconscripts.append('$BREAKPAD_DIR/SConscript') + +if LoadComponent('chrome'): + sconscripts.append('$CHROME_DIR/SConscript') + +if LoadComponent('gears'): + sconscripts.append('$GEARS_DIR/SConscript') + +if LoadComponent('google_update'): + sconscripts.append('$GOOGLE_UPDATE_DIR/SConscript') + +if LoadComponent('googleurl'): + # googleurl comes from a different repository so we provide the SConscript + # file. + sconscripts.append('SConscript.googleurl') + +if LoadComponent('net'): + sconscripts.append('$NET_DIR/SConscript') + +if LoadComponent('rlz'): + sconscripts.append('$RLZ_DIR/SConscript') + +if LoadComponent('sandbox'): + sconscripts.append('$SANDBOX_DIR/src/SConscript') + +if LoadComponent('sdch'): + sconscripts.append('$SDCH_DIR/SConscript') + +if LoadComponent('skia'): + sconscripts.append('$SKIA_DIR/SConscript') + +if LoadComponent('testing'): + sconscripts.append('$TESTING_DIR/SConscript.gtest') + +if LoadComponent('third_party'): + sconscripts.extend([ + '$BSDIFF_DIR/SConscript', + '$BZIP2_DIR/SConscript', + '$ICU38_DIR/SConscript', + '$LIBPNG_DIR/SConscript', + '$LZMA_SDK_DIR/SConscript', + '$MODP_B64_DIR/SConscript', + '$ZLIB_DIR/SConscript', + ]) + # Temporary until we get these building on Mac. + if env['PLATFORM'] != 'darwin': + sconscripts.extend([ + '$LIBJPEG_DIR/SConscript', + '$LIBXML_DIR/SConscript', + '$LIBXSLT_DIR/SConscript', + ]) + if env['PLATFORM'] in ('posix', 'darwin'): + sconscripts.extend([ + '$LIBEVENT_DIR/SConscript', + ]) + # This is temporary until we get this lib to build on other platforms. + if env['PLATFORM'] == 'win32': + sconscripts.extend([ + '$BSPATCH_DIR/SConscript', + ]) + +if LoadComponent('v8') and env.Dir('#/../v8').exists(): + env.SConscript('SConscript.v8', + exports=['env']) + +if LoadComponent('webkit'): + sconscripts.append('$WEBKIT_DIR/SConscript') + +env.SConscript(sconscripts, exports=['env']) + + +help_fmt = """ +Usage: hammer [SCONS_OPTIONS] [VARIABLES] [TARGET] ... + +Supported build variables: + + BUILD_TYPE=type Build type. Also used as the subdirectory name + in which the build occurs. + LOAD=[module,...] Comma-separated list of components to load in the + dependency graph ('-' prefix excludes): +%s + PROGRESS=type Display a progress indicator: + name: print each evaluated target name + spinner: print a spinner every 5 targets + VERBOSE=1 Display full command lines +""" + +if GetOption('help'): + import textwrap + tw = textwrap.TextWrapper( + width = 78, + initial_indent = ' '*32, + subsequent_indent = ' '*32, + ) + components = tw.fill(', '.join(components)) + + Help(help_fmt % components) -#----------------------------------------------------------------------- -# By default, the Hammer modules execute the tests to capture test -# output, but do it from a location that doesn't (yet) work for us. -# Replace the Hammer defaults with Chromium's. -Default(None) Import('build_component') -Default(Alias(build_component)) - -# TODO: Get to the point of using Hammer's aliases. -#Default([base_env.Alias('all_programs'), -# base_env.Alias('all_libraries')]) - -# Create a list of all variants that are buildable. -environment_list = [ - debug_mac_env, - release_mac_env, - debug_win_env, - release_win_env, - debug_linux_env, - release_linux_env, -] - -# For each variant in the environment_list, build the SConscript files in its -# BUILD_SCONSCRIPTS variable. -BuildComponents(environment_list) - -#----------------------------------------------------------------------- - -# Generate a solution, defer to the end. -solution_env = base_env.Clone(tools = ['visual_studio_solution']) -solution = solution_env.Solution( - 'chrome_hammer', environment_list, - exclude_pattern = '.*third_party.*', - extra_build_targets = { - 'Firefox': 'c:/Program Files/Mozilla FireFox/firefox.exe', - }, -) -solution_env.Alias('solution', solution) +Default(build_component) diff --git a/build/SConscript.v8 b/build/SConscript.v8 index 7820f16..8eeef09 100644 --- a/build/SConscript.v8 +++ b/build/SConscript.v8 @@ -2,9 +2,6 @@ # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. - -import os - Import('env') # Grab the -j flag from the outer environment, if available. @@ -25,16 +22,13 @@ env = env.Clone( '--warn=no-no-parallel-support' + cpu_flag), ) -if env['PLATFORM'] == 'win32': - env['ENV']['ProgramFiles'] = os.environ['ProgramFiles'] - # Rather than build v8 with our own commands, we just shell out to v8's # own SCons-based build, since their build system is complicated. # This SConscript just declares dependencies on the outputs of that build. mksnapshot_exe = env.File('$V8_MODE_DIR/mksnapshot${PROGSUFFIX}') -libraries_empty_obj = env.File('$V8_MODE_DIR/libraries-empty${OBJSUFFIX}') libraries_obj = env.File('$V8_MODE_DIR/libraries${OBJSUFFIX}') +libraries_empty_obj = env.File('$V8_MODE_DIR/libraries-empty${OBJSUFFIX}') snapshot_obj = env.File('$V8_MODE_DIR/snapshot${OBJSUFFIX}') snapshot_empty_obj = env.File('$V8_MODE_DIR/snapshot-empty${OBJSUFFIX}') v8_bin = env.File('$V8_SRC_DIR/shell${PROGSUFFIX}') @@ -70,13 +64,20 @@ env.AlwaysBuild(v8) # rebuild them (thereby causing us to always rebuild their dependents). env.Precious(v8) +env.Install('$V8_DIR', v8) + + +i = env.Install('$LIBS_DIR', v8_lib) +env.Alias('webkit', i) + +i = env.Install('$TARGET_ROOT', v8_bin) +env.Alias('chrome', i) -# TODO(bradnelson): remove if we confirm we no longer need this. # To satisfy tests expecting the following .exe name. -#if env['PLATFORM'] == 'win32': -# # TODO(evanm): this may be necessary on other platforms(?) -# i = env.InstallAs('$TARGET_ROOT/v8_shell_sample${PROGSUFFIX}', v8_bin) -# env.Alias('chrome', i) +if env['PLATFORM'] == 'win32': + # TODO(evanm): this may be necessary on other platforms(?) + i = env.InstallAs('$TARGET_ROOT/v8_shell_sample${PROGSUFFIX}', v8_bin) + env.Alias('chrome', i) env.ChromeStaticLibrary('v8_snapshot', [libraries_empty_obj, snapshot_obj]) diff --git a/net/SConscript b/net/SConscript index adb0b68..8a0b85c 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 e932784..7e3fc34 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', @@ -147,13 +145,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", @@ -165,8 +160,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 @@ -286,3 +281,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 9068be2..d57e7b2 100644 --- a/webkit/glue/plugins/test/SConscript +++ b/webkit/glue/plugins/test/SConscript @@ -70,7 +70,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) + |