summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--build/SConscript.v873
-rw-r--r--chrome/SConscript24
2 files changed, 55 insertions, 42 deletions
diff --git a/build/SConscript.v8 b/build/SConscript.v8
index b89da2a..ddf5cea 100644
--- a/build/SConscript.v8
+++ b/build/SConscript.v8
@@ -4,61 +4,48 @@
Import('env')
-# Grab the -j flag from the outer environment, if available.
-try:
- cpus = env.GetOption('num_jobs')
- cpu_flag = ' -j%d' % cpus
-except AttributeError:
- cpu_flag = ''
+env = env.Clone()
-env = env.Clone(
- V8_MODE = 'release',
- V8_SRC_DIR = '#/../v8',
- V8_MODE_DIR = '$V8_SRC_DIR/obj/$V8_MODE',
- SCONS='../third_party/scons/scons.py',
- SCONSFLAGS = ('-Q '
- '--warn=no-deprecated '
- '--warn=no-no-parallel-support' + cpu_flag),
-)
-
-# 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.
+# Rather than build v8 here, 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}')
-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}')
-v8_lib = env.File('$V8_SRC_DIR/${LIBPREFIX}v8${LIBSUFFIX}'),
+mksnapshot_bin = env.File('#/../v8/obj/release/mksnapshot${PROGSUFFIX}')
+v8_bin = env.File('#/../v8/shell${PROGSUFFIX}')
+v8_lib = env.File('#/../v8/${LIBPREFIX}v8${LIBSUFFIX}'),
v8_scons_targets = [
- mksnapshot_exe,
- libraries_obj,
- libraries_empty_obj,
- snapshot_obj,
- snapshot_empty_obj,
- v8_bin,
- v8_lib,
+ mksnapshot_bin,
+ v8_bin,
+ v8_lib,
]
if env['PLATFORM'] == 'win32':
- v8_scons_targets.extend([
- env.File('#/../v8/vc80.pdb')
+ v8_scons_targets.append([
+ env.File('#/../v8/obj/release/snapshot-empty.obj'),
+ env.File('#/../v8/vc80.pdb')
])
+# Grab the -j flag from the outer environment, if available.
+try:
+ cpus = env.GetOption('num_jobs')
+ cpu_flag = ' -j%d' % cpus
+except AttributeError:
+ cpu_flag = ''
+
v8 = env.Command(v8_scons_targets,
[],
- 'cd ../v8 && $PYTHON $SCONS $SCONSFLAGS $V8FLAGS',
- V8FLAGS='mode=$V8_MODE snapshot=off sample=shell')
+ 'cd ../v8 && $PYTHON $SCONS $SCONSFLAGS snapshot=on ' +
+ 'sample=shell',
+ SCONS='../third_party/scons/scons.py',
+ SCONSFLAGS=('-Q '
+ '--warn=no-deprecated '
+ '--warn=no-no-parallel-support' + cpu_flag))
env.AlwaysBuild(v8)
env.Install('$V8_DIR', v8)
-# Tell our SCons invocation to *not* delete v8.lib and the other targets
-# before building them, so the subsidiary v8 SCons call doesn't always
-# rebuild them (thereby causing us to always rebuild their dependents).
-env.Precious(v8)
+i = env.Install('$TARGET_ROOT', mksnapshot_bin)
+env.Alias('webkit', i)
i = env.Install('$LIBS_DIR', v8_lib)
env.Alias('webkit', i)
@@ -72,5 +59,7 @@ if env['PLATFORM'] == 'win32':
i = env.InstallAs('$TARGET_ROOT/v8_shell_sample${PROGSUFFIX}', v8_bin)
env.Alias('chrome', i)
-env.ChromeStaticLibrary('v8_snapshot',
- [libraries_empty_obj, snapshot_obj])
+# Tell our SCons invocation to *not* delete v8.lib and the other targets
+# before building them, so the subsidiary v8 SCons call doesn't always
+# rebuild them (thereby causing us to always rebuild their dependents).
+env.Precious(v8)
diff --git a/chrome/SConscript b/chrome/SConscript
index 69554d8..331b1bd 100644
--- a/chrome/SConscript
+++ b/chrome/SConscript
@@ -359,6 +359,30 @@ if env['PLATFORM'] == 'win32':
# '$PYTHON tools/build/win/dependencies.py $(TargetPath) chrome.exe.deps')
+ env_snapshot = env.Clone()
+
+ env_snapshot.Prepend(
+ CPPPATH = [
+ '$V8_DIR/src',
+ '$V8_DIR/src/pcre/jscre',
+ '..',
+ ],
+ CPPDEFINES = [
+ 'ENABLE_DISASSEMBLER',
+ ],
+ CCFLAGS = [
+ '/wd4099',
+ '/wd4355',
+ '/wd4800',
+ ],
+ )
+
+ env_snapshot.ChromeStaticLibrary('snapshotv8', 'snapshot.cc')
+
+ env_snapshot.Command('snapshot.cc', '#/../v8/bin/debug/mksnapshot.exe',
+ '$SOURCE $TARGET')
+
+
env_flat = env.Clone(
BROWSER_RESOURCES = Dir('browser_resources'),