summaryrefslogtreecommitdiffstats
path: root/Source/JavaScriptCore/gyp
diff options
context:
space:
mode:
Diffstat (limited to 'Source/JavaScriptCore/gyp')
-rw-r--r--Source/JavaScriptCore/gyp/JavaScriptCore.gyp168
-rwxr-xr-xSource/JavaScriptCore/gyp/generate-dtrace-header.sh9
-rwxr-xr-xSource/JavaScriptCore/gyp/run-if-exists.sh5
-rwxr-xr-xSource/JavaScriptCore/gyp/update-info-plist.sh4
4 files changed, 108 insertions, 78 deletions
diff --git a/Source/JavaScriptCore/gyp/JavaScriptCore.gyp b/Source/JavaScriptCore/gyp/JavaScriptCore.gyp
index 1e46094..a520344 100644
--- a/Source/JavaScriptCore/gyp/JavaScriptCore.gyp
+++ b/Source/JavaScriptCore/gyp/JavaScriptCore.gyp
@@ -3,30 +3,43 @@
'../../gyp/common.gypi',
'../JavaScriptCore.gypi',
],
- 'xcode_config_file': '<(DEPTH)/JavaScriptCore/Configurations/DebugRelease.xcconfig',
+ 'configurations': {
+ 'Production': {
+ 'xcode_config_file': '<(project_dir)/Configurations/Base.xcconfig',
+ },
+ 'Profiling': {
+ 'xcode_config_file': '<(project_dir)/Configurations/DebugRelease.xcconfig',
+ 'xcode_settings': {
+ 'STRIP_INSTALLED_PRODUCT': 'NO',
+ },
+ },
+ 'Release': {
+ 'xcode_config_file': '<(project_dir)/Configurations/DebugRelease.xcconfig',
+ 'xcode_settings': {
+ 'STRIP_INSTALLED_PRODUCT': 'NO',
+ },
+ },
+ 'Debug': {
+ 'xcode_config_file': '<(project_dir)/Configurations/DebugRelease.xcconfig',
+ 'xcode_settings': {
+ 'DEAD_CODE_STRIPPING': '$(DEAD_CODE_STRIPPING_debug)',
+ 'DEBUG_DEFINES': '$(DEBUG_DEFINES_debug)',
+ 'GCC_OPTIMIZATION_LEVEL': '$(GCC_OPTIMIZATION_LEVEL_debug)',
+ 'STRIP_INSTALLED_PRODUCT': '$(STRIP_INSTALLED_PRODUCT_debug)',
+ },
+ },
+ },
'variables': {
- # FIXME: We should use a header map instead of listing these explicitly.
'javascriptcore_include_dirs': [
- '<(DEPTH)', # Some paths in API include JavaScriptCore/
- '<(DEPTH)/JavaScriptCore',
- '<(DEPTH)/JavaScriptCore/ForwardingHeaders',
- '<(DEPTH)/JavaScriptCore/API',
- '<(DEPTH)/JavaScriptCore/assembler',
- '<(DEPTH)/JavaScriptCore/collector/handles',
- '<(DEPTH)/JavaScriptCore/bytecode',
- '<(DEPTH)/JavaScriptCore/bytecompiler',
- '<(DEPTH)/JavaScriptCore/debugger',
- '<(DEPTH)/JavaScriptCore/icu',
- '<(DEPTH)/JavaScriptCore/interpreter',
- '<(DEPTH)/JavaScriptCore/jit',
- '<(DEPTH)/JavaScriptCore/parser',
- '<(DEPTH)/JavaScriptCore/profiler',
- '<(DEPTH)/JavaScriptCore/runtime',
- '<(DEPTH)/JavaScriptCore/wtf',
- '<(DEPTH)/JavaScriptCore/wtf/unicode',
- '<(PRODUCT_DIR)/DerivedSources/JavaScriptCore',
+ '<(project_dir)',
+ '<(project_dir)/icu',
],
},
+ 'target_defaults': {
+ 'configurations': {
+ 'Profiling': {},
+ },
+ },
'targets': [
{
'target_name': 'JavaScriptCore',
@@ -37,15 +50,22 @@
],
'include_dirs': [
'<@(javascriptcore_include_dirs)',
+ '<(PRODUCT_DIR)/DerivedSources/JavaScriptCore',
],
+ 'configurations': {
+ 'Production': {
+ 'INSTALL_PATH': '$(BUILT_PRODUCTS_DIR)',
+ },
+ },
'sources': [
'<@(javascriptcore_files)',
'<@(javascriptcore_publicheader_files)',
'<@(javascriptcore_privateheader_files)',
+ '<@(javascriptcore_derived_source_files)',
'$(SDKROOT)/System/Library/Frameworks/CoreFoundation.framework',
'$(SDKROOT)/System/Library/Frameworks/Foundation.framework',
- 'libicucore.dylib',
- 'libobjc.dylib',
+ '/usr/lib/libicucore.dylib',
+ '/usr/lib/libobjc.dylib',
],
'mac_framework_headers': [
'<@(javascriptcore_publicheader_files)',
@@ -53,47 +73,41 @@
'mac_framework_private_headers': [
'<@(javascriptcore_privateheader_files)',
],
- 'xcode_config_file': '<(DEPTH)/JavaScriptCore/Configurations/JavaScriptCore.xcconfig',
+ 'xcode_config_file': '<(project_dir)/Configurations/JavaScriptCore.xcconfig',
'sources/': [
- ['exclude', 'qt'],
- ['exclude', 'os-win32'],
- ['exclude', 'wtf/android'],
- ['exclude', 'wtf/brew'],
- ['exclude', 'wtf/efl'],
- ['exclude', 'wtf/gtk'],
- ['exclude', 'wtf/qt'],
- ['exclude', 'wtf/haiku'],
- ['exclude', 'API/tests'],
- ['exclude', 'wtf/url'],
- ['exclude', 'wtf/wince'],
- ['exclude', 'wtf/wx'],
- ['exclude', 'wtf/unicode/brew'],
- ['exclude', 'wtf/unicode/wince'],
- ['exclude', 'wtf/unicode/glib'],
- ['exclude', 'wtf/unicode/qt4'],
+ ['exclude', 'API/tests/'],
+ ['exclude', 'ForwardingHeaders/'],
+ ['exclude', '(?<!unicode)/icu/'],
+ ['exclude', 'os-win32/'],
+ ['exclude', 'qt/'],
+ ['exclude', 'wtf/(android|brew|efl|gtk|haiku|qt|wince|wx)/'],
+ ['exclude', 'wtf/unicode/brew/'],
+ ['exclude', 'wtf/unicode/glib/'],
+ ['exclude', 'wtf/unicode/qt4/'],
+ ['exclude', 'wtf/unicode/wince/'],
+ ['exclude', 'wtf/url/'],
['exclude', '/(gtk|glib|gobject)/.*\\.(cpp|h)$'],
['exclude', '(Default|Gtk|Chromium|None|Qt|Win|Wx|Symbian)\\.(cpp|mm|h)$'],
- ['exclude', 'GCActivityCallback\.cpp'],
- ['exclude', '.*BSTR.*$'],
- ['exclude', 'jsc.cpp$'],
+ ['exclude', 'GCActivityCallback\.cpp$'],
+ ['exclude', 'BSTR[^/]*$'],
],
'postbuilds': [
{
'postbuild_name': 'Check For Global Initializers',
'action': [
- 'sh', '<(DEPTH)/gyp/run-if-exists.sh', '<(DEPTH)/../Tools/Scripts/check-for-global-initializers'
+ 'sh', '<(project_dir)/gyp/run-if-exists.sh', '<(DEPTH)/../Tools/Scripts/check-for-global-initializers'
],
},
{
'postbuild_name': 'Check For Exit Time Destructors',
'action': [
- 'sh', '<(DEPTH)/gyp/run-if-exists.sh', '<(DEPTH)/../Tools/Scripts/check-for-exit-time-destructors'
+ 'sh', '<(project_dir)/gyp/run-if-exists.sh', '<(DEPTH)/../Tools/Scripts/check-for-exit-time-destructors'
],
},
{
'postbuild_name': 'Check For Weak VTables and Externals',
'action': [
- 'sh', '<(DEPTH)/gyp/run-if-exists.sh', '<(DEPTH)/../Tools/Scripts/check-for-weak-vtables-and-externals'
+ 'sh', '<(project_dir)/gyp/run-if-exists.sh', '<(DEPTH)/../Tools/Scripts/check-for-weak-vtables-and-externals'
],
},
],
@@ -103,29 +117,8 @@
'xcode_settings': {
# FIXME: Remove these overrides once JavaScriptCore.xcconfig is
# used only by this project.
- 'GCC_PREFIX_HEADER': '<(DEPTH)/JavaScriptCore/JavaScriptCorePrefix.h',
- 'INFOPLIST_FILE': '<(DEPTH)/JavaScriptCore/Info.plist',
- # This setting mirrors the setting in Base.xcconfig, with
- # one difference noted below.
- 'WARNING_CFLAGS_BASE': [
- '-Wall',
- '-Wextra',
- '-Wcast-qual',
- '-Wchar-subscripts',
- '-Wextra-tokens',
- '-Wformat=2',
- '-Winit-self',
- # FIXME: For some reason, -Wmissing-format-attribute causes a
- # build error in Assertions.cpp in the GYP build but not in the
- # non-GYP build.
- # '-Wmissing-format-attribute',
- '-Wmissing-noreturn',
- '-Wpacked',
- '-Wpointer-arith',
- '-Wredundant-decls',
- '-Wundef',
- '-Wwrite-strings',
- ],
+ 'GCC_PREFIX_HEADER': '<(project_dir)/JavaScriptCorePrefix.h',
+ 'INFOPLIST_FILE': '<(project_dir)/Info.plist',
},
}],
],
@@ -133,14 +126,26 @@
{
'target_name': 'Derived Sources',
'type': 'none',
- 'actions': [{
- 'action_name': 'Generate Derived Sources',
- 'inputs': [],
- 'outputs': [],
- 'action': [
- 'sh', 'generate-derived-sources.sh',
- ],
- }],
+ 'actions': [
+ {
+ 'action_name': 'Generate Derived Sources',
+ 'inputs': [],
+ 'outputs': [
+ '<@(javascriptcore_derived_source_files)',
+ ],
+ 'action': [
+ 'sh', 'generate-derived-sources.sh'
+ ],
+ },
+ {
+ 'action_name': 'Generate DTrace Header',
+ 'inputs': [],
+ 'outputs': [],
+ 'action': [
+ 'sh', '<(project_dir)/gyp/generate-dtrace-header.sh', '<(project_dir)'
+ ]
+ }
+ ],
},
{
'target_name': 'Update Version',
@@ -150,7 +155,7 @@
'inputs': [],
'outputs': [],
'action': [
- 'sh', '<(DEPTH)/gyp/update-info-plist.sh', '<(DEPTH)/JavaScriptCore/Info.plist'
+ 'sh', '<(project_dir)/gyp/update-info-plist.sh', '<(project_dir)/Info.plist'
]
}],
},
@@ -206,10 +211,17 @@
'include_dirs': [
'<@(javascriptcore_include_dirs)',
],
+ 'configurations': {
+ 'Production': {
+ 'xcode_settings': {
+ 'INSTALL_PATH': '$(JAVASCRIPTCORE_FRAMEWORKS_DIR)/JavaScriptCore.framework/Resources',
+ },
+ },
+ },
'sources': [
'<@(jsc_files)',
'$(SDKROOT)/System/Library/Frameworks/CoreFoundation.framework',
- 'libedit.dylib',
+ '/usr/lib/libedit.dylib',
],
},
], # targets
diff --git a/Source/JavaScriptCore/gyp/generate-dtrace-header.sh b/Source/JavaScriptCore/gyp/generate-dtrace-header.sh
new file mode 100755
index 0000000..a3c31dd
--- /dev/null
+++ b/Source/JavaScriptCore/gyp/generate-dtrace-header.sh
@@ -0,0 +1,9 @@
+#!/bin/sh
+
+TRACING_D="$1/runtime/Tracing.d";
+TRACING_H="$BUILT_PRODUCTS_DIR/DerivedSources/JavaScriptCore/TracingDtrace.h";
+
+if [[ "${HAVE_DTRACE}" = "1" && "${TRACING_D}" -nt "${TRACING_H}" ]]; then
+ dtrace -h -o "${TRACING_H}" -s "${TRACING_D}";
+fi;
+
diff --git a/Source/JavaScriptCore/gyp/run-if-exists.sh b/Source/JavaScriptCore/gyp/run-if-exists.sh
new file mode 100755
index 0000000..242ffc8
--- /dev/null
+++ b/Source/JavaScriptCore/gyp/run-if-exists.sh
@@ -0,0 +1,5 @@
+#!/bin/sh
+
+if [ -f $1 ]; then
+ $1 || exit $?;
+fi
diff --git a/Source/JavaScriptCore/gyp/update-info-plist.sh b/Source/JavaScriptCore/gyp/update-info-plist.sh
new file mode 100755
index 0000000..d02ecce
--- /dev/null
+++ b/Source/JavaScriptCore/gyp/update-info-plist.sh
@@ -0,0 +1,4 @@
+# Touch Info.plist to let Xcode know it needs to copy it into the built product
+if [[ "${CONFIGURATION}" != "Production" ]]; then
+ touch "$1";
+fi