summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorerg@google.com <erg@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-08-19 22:47:45 +0000
committererg@google.com <erg@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-08-19 22:47:45 +0000
commitb05c90f8107464ca18d888a251cea7dd7c1b0776 (patch)
tree829061330ac1f6256e7221272ff33e04830ee0d5
parent5cca3a55b3f1c25c5b3a19c3b42227aae34e4abf (diff)
downloadchromium_src-b05c90f8107464ca18d888a251cea7dd7c1b0776.zip
chromium_src-b05c90f8107464ca18d888a251cea7dd7c1b0776.tar.gz
chromium_src-b05c90f8107464ca18d888a251cea7dd7c1b0776.tar.bz2
Get JSConfig and JavaScriptCore/libWTF.a building under linux.
- Mainly separating out windows options into env['PLATFROM'] sections. - Fix for case sensitive filesystems. git-svn-id: svn://svn.chromium.org/chrome/trunk/src@1064 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--build/SConscript.main3
-rw-r--r--webkit/SConscript33
-rw-r--r--webkit/build/JSConfig/SConscript20
-rwxr-xr-xwebkit/build/JSConfig/create-config.sh2
-rw-r--r--webkit/build/JavaScriptCore/SConscript54
-rw-r--r--webkit/build/WebCore/SConscript48
6 files changed, 96 insertions, 64 deletions
diff --git a/build/SConscript.main b/build/SConscript.main
index eb18a5f..14b8035 100644
--- a/build/SConscript.main
+++ b/build/SConscript.main
@@ -96,7 +96,7 @@ env = Environment(
NPAPI_DIR = '$THIRD_PARTY_DIR/npapi',
ZLIB_DIR = '$THIRD_PARTY_DIR/zlib',
- THIRD_PARTY_WEBKIT_DIR = '$THIRD_PARTY_DIR/webkit',
+ THIRD_PARTY_WEBKIT_DIR = '$THIRD_PARTY_DIR/WebKit',
PYTHON=sys.executable,
@@ -329,6 +329,7 @@ elif env['PLATFORM'] == 'posix':
'skia',
'testing',
'third_party',
+ 'webkit',
]
env.Replace(
diff --git a/webkit/SConscript b/webkit/SConscript
index 55ceb83..cbf3ed7 100644
--- a/webkit/SConscript
+++ b/webkit/SConscript
@@ -135,12 +135,8 @@ env.Append(
CPPDEFINES = [
'U_STATIC_IMPLEMENTATION'
- '_CRT_SECURE_NO_DEPRECATE',
- '_CRT_NONSTDC_NO_WARNINGS',
- '_CRT_NONSTDC_NO_DEPRECATE',
'_SCL_SECURE_NO_DEPRECATE',
'_SCL_SECURE_NO_WARNINGS',
- ['CRASH', '__debugbreak'],
['ENABLE_CROSS_DOCUMENT_MESSAGING', '1'],
['ENABLE_XSLT', '1'],
['ENABLE_XPATH', '1'],
@@ -153,9 +149,6 @@ env.Append(
['WEBCORE_NAVIGATOR_PLATFORM', '"\\"Win32\\""'],
'USE_GOOGLE_URL_LIBRARY',
- '_WIN32_WINNT=0x0600',
- 'WINVER=0x0600',
-
'LIBXSLT_STATIC',
'LIBXML_STATIC',
'PNG_USER_CONFIG',
@@ -168,8 +161,8 @@ env.Append(
],
)
-
-sconscript_dirs = [
+if env['PLATFORM'] == 'win32':
+ sconscript_dirs = [
'SConscript.port',
'SConscript.javascriptcore_pcre',
'activex_shim/SConscript',
@@ -186,8 +179,26 @@ sconscript_dirs = [
'tools/npapi_layout_test_plugin/SConscript',
'tools/test_shell/SConscript',
'tools/test_shell/resources/fonts/SConscript',
-]
-
+ ]
+
+ env.Append(
+ CPPDEFINES = [
+ '_CRT_SECURE_NO_DEPRECATE',
+ '_CRT_NONSTDC_NO_WARNINGS',
+ '_CRT_NONSTDC_NO_DEPRECATE',
+ ['CRASH', '__debugbreak'],
+ '_WIN32_WINNT=0x0600',
+ 'WINVER=0x0600',
+ ])
+else:
+ sconscript_dirs = [
+# TODO(erg): For now, only JavaScriptCore compiles and links; the rest is next.
+# 'SConscript.port',
+# 'SConscript.javascriptcore_pcre',
+ 'build/JSConfig/SConscript',
+ 'build/JavaScriptCore/SConscript',
+# 'build/WebCore/SConscript',
+ ]
env.SConscript(sconscript_dirs, exports=['env', 'env_res'])
# Setup alias for all webkit related targets.
diff --git a/webkit/build/JSConfig/SConscript b/webkit/build/JSConfig/SConscript
index e3a15cf..7e896af 100644
--- a/webkit/build/JSConfig/SConscript
+++ b/webkit/build/JSConfig/SConscript
@@ -31,9 +31,17 @@ Import('env')
env = env.Clone()
-# TODO(bradnelson): very bad, calls batch, calls sh, deps all wrong
-env.Append(ENV = {"OS" : "Windows_NT"})
-env.Command("obj/WebCore/config.h",
- ["prebuild.bat", "../../config.h.in"],
- "cd ${SOURCE.dir} && ${SOURCE.file} ${JSCONFIG_DIR.abspath} v8",
- JSCONFIG_DIR = env.Dir('$WEBKIT_DIR/build/JSConfig'))
+
+if env['PLATFORM'] == 'posix':
+ # TODO(erg): adding to the badness.
+ env.Command("obj/WebCore/config.h",
+ ["create-config.sh", "../../config.h.in"],
+ "cd ${SOURCE.dir} && /bin/bash -x ${SOURCE.file} ${JSCONFIG_DIR.abspath} v8",
+ JSCONFIG_DIR = env.Dir('$WEBKIT_DIR/build/JSConfig'))
+else:
+ # TODO(bradnelson): very bad, calls batch, calls sh, deps all wrong
+ env.Append(ENV = {"OS" : "Windows_NT"})
+ env.Command("obj/WebCore/config.h",
+ ["prebuild.bat", "../../config.h.in"],
+ "cd ${SOURCE.dir} && ${SOURCE.file} ${JSCONFIG_DIR.abspath} v8",
+ JSCONFIG_DIR = env.Dir('$WEBKIT_DIR/build/JSConfig'))
diff --git a/webkit/build/JSConfig/create-config.sh b/webkit/build/JSConfig/create-config.sh
index 4d07f35..e79d2a1 100755
--- a/webkit/build/JSConfig/create-config.sh
+++ b/webkit/build/JSConfig/create-config.sh
@@ -91,7 +91,7 @@ then
$CP $JavaScriptCoreSrcDir/bindings/npruntime_priv.h $JSHeadersDir
$CP $JavaScriptCoreSrcDir/bindings/runtime.h $JSHeadersDir/JavaScriptCore
- $CP $JavaScriptCoreSrcDir/bindings/np_jsobject.h $JSHeadersDir/JavaScriptCore
+ $CP $JavaScriptCoreSrcDir/bindings/NP_jsobject.h $JSHeadersDir/JavaScriptCore
$CP $JavaScriptCoreSrcDir/bindings/runtime_object.h $JSHeadersDir/JavaScriptCore
$CP $JavaScriptCoreSrcDir/bindings/runtime_root.h $JSHeadersDir/JavaScriptCore
diff --git a/webkit/build/JavaScriptCore/SConscript b/webkit/build/JavaScriptCore/SConscript
index c00c092..6608ebe 100644
--- a/webkit/build/JavaScriptCore/SConscript
+++ b/webkit/build/JavaScriptCore/SConscript
@@ -41,7 +41,7 @@ hash_table_cmd = '$PERL $CREATE_HASH_TABLE $SOURCE $CREATE_HASH_TABLE_FLAGS > $T
env.Replace(
CREATE_HASH_TABLE_COM = hash_table_cmd,
- CREATE_HASH_TABLE = env.File('#/../third_party/WebKit/JavascriptCore/kjs/create_hash_table'),
+ CREATE_HASH_TABLE = env.File('#/../third_party/WebKit/JavaScriptCore/kjs/create_hash_table'),
CREATE_HASH_TABLE_FLAGS = '-i',
)
@@ -95,7 +95,7 @@ copies = [
'API/JavaScriptCore.h',
'bindings/npruntime.h',
'bindings/runtime.h',
- 'bindings/np_jsobject.h',
+ 'bindings/NP_jsobject.h',
'bindings/npruntime_internal.h',
'bindings/npruntime_impl.h',
'bindings/runtime_object.h',
@@ -118,9 +118,7 @@ env.Alias('webkit', i)
# Stuff for WTF
env = env.Clone(
CPPPATH = [
- '$WEBKIT_DIR/build/JavaScriptCore',
'$JAVASCRIPTCORE_DIR',
- '$JAVASCRIPTCORE_DIR/os-win32',
'$JAVASCRIPTCORE_DIR/kjs',
'$WTF_DIR',
'$JAVASCRIPTCORE_DIR/API',
@@ -140,25 +138,37 @@ env.Append(
CPPDEFINES = [
'HAVE_CONFIG_H',
'__STD_C',
- 'CRASH=__debugbreak',
'U_STATIC_IMPLEMENTATION',
- '_WIN32_WINNT=0x0600',
- 'WINVER=0x0600',
- ],
- CCFLAGS = [
- '/TP',
-
- '/WX',
- '/Wp64',
-
- '/wd4127',
- '/wd4355',
- '/wd4510',
- '/wd4512',
- '/wd4610',
- '/wd4706',
- ],
-)
+ ]
+ )
+
+if env['PLATFORM'] == 'win32':
+ env.Append(
+ CPPPATH = [
+ # Windows workarounds to not having pthread.h and sched.h
+ '$WEBKIT_DIR/build/JavaScriptCore',
+ # Windows workarounds to not having stdint.h
+ '$JAVASCRIPTCORE_DIR/os-win32',
+ ],
+ CPPDEFINES = [
+ 'CRASH=__debugbreak',
+ '_WIN32_WINNT=0x0600',
+ 'WINVER=0x0600',
+ ],
+ CCFLAGS = [
+ '/TP',
+
+ '/WX',
+ '/Wp64',
+
+ '/wd4127',
+ '/wd4355',
+ '/wd4510',
+ '/wd4512',
+ '/wd4610',
+ '/wd4706',
+ ],
+ )
wtf_inputs = [
'$WTF_DIR/Assertions.cpp',
diff --git a/webkit/build/WebCore/SConscript b/webkit/build/WebCore/SConscript
index a421e6b..ab7a703 100644
--- a/webkit/build/WebCore/SConscript
+++ b/webkit/build/WebCore/SConscript
@@ -31,28 +31,20 @@ Import('env')
env = env.Clone()
-env.Append(
- CCFLAGS = [
- '/TP',
-
- '/wd4138',
- '/wd4244',
- '/wd4291',
- '/wd4305',
- '/wd4521',
- '/wd4099',
- '/wd4800',
- ],
-)
-
-
-env_p = env.Clone()
-env_p.Append(CCFLAGS='/Ylwebcore')
-pch, obj = env_p.PCH('../precompiled_webkit.cc')
-env['PCH'] = pch
-env['PCHSTOP'] = 'precompiled_webkit.h'
-env.Append(CCPCHFLAGS = ['/FIprecompiled_webkit.h'])
-
+if env['PLATFORM'] == 'win32':
+ env.Append(
+ CCFLAGS = [
+ '/TP',
+
+ '/wd4138',
+ '/wd4244',
+ '/wd4291',
+ '/wd4305',
+ '/wd4521',
+ '/wd4099',
+ '/wd4800',
+ ],
+ )
input_files = [
'$PENDING_DIR/JSSVGLazyEventListener.cpp',
@@ -699,4 +691,14 @@ input_files = [
'$WEBCORE_DIR/xml/XSLTUnicodeSort.cpp',
]
-env.ChromeStaticLibrary('WebCore', input_files + [obj])
+# Precompiled headers only work under MSVC in scons.
+if env['PLATFORM'] == 'win32':
+ env_p = env.Clone()
+ env_p.Append(CCFLAGS='/Ylwebcore')
+ pch, obj = env_p.PCH('../precompiled_webkit.cc')
+ env['PCH'] = pch
+ env['PCHSTOP'] = 'precompiled_webkit.h'
+ env.Append(CCPCHFLAGS = ['/FIprecompiled_webkit.h'])
+ input_files += [obj]
+
+env.ChromeStaticLibrary('WebCore', input_files)