summaryrefslogtreecommitdiffstats
path: root/src/v8/v8.pri
diff options
context:
space:
mode:
Diffstat (limited to 'src/v8/v8.pri')
-rw-r--r--src/v8/v8.pri307
1 files changed, 307 insertions, 0 deletions
diff --git a/src/v8/v8.pri b/src/v8/v8.pri
new file mode 100644
index 0000000..530b2a7
--- /dev/null
+++ b/src/v8/v8.pri
@@ -0,0 +1,307 @@
+isEmpty(QT_ARCH) {
+ # We're most likely being parsed in a fromfile() call, in which case the
+ # QMake environment isn't complete. Load qt_config in an attempt to set
+ # the variables we need (QT_ARCH and CONFIG, in particular).
+ load(qt_config)
+}
+
+isEmpty(V8_TARGET_ARCH) {
+ # Detect target
+ equals(QT_ARCH, x86_64)|contains(CONFIG, x86_64):V8_TARGET_ARCH = x64
+ else:equals(QT_ARCH, "i386"): V8_TARGET_ARCH = ia32
+ else:equals(QT_ARCH, "mips"): V8_TARGET_ARCH = mips
+ else:equals(QT_ARCH, "arm"): V8_TARGET_ARCH = arm
+ else:equals(QMAKE_HOST.arch, armv7l): V8_TARGET_ARCH = arm
+ else:equals(QMAKE_HOST.arch, armv5tel): V8_TARGET_ARCH = arm
+ else:equals(QMAKE_HOST.arch, x86_64): V8_TARGET_ARCH = x64
+ else:equals(QMAKE_HOST.arch, x86): V8_TARGET_ARCH = ia32
+ else:equals(QMAKE_HOST.arch, i386): V8_TARGET_ARCH = ia32
+ else:equals(QMAKE_HOST.arch, i686): V8_TARGET_ARCH = ia32
+ else:error("Couldn't detect supported v8 architecture ($$QMAKE_HOST.arch/$$QT_ARCH). Currently supported architectures are: x64, x86 and arm")
+}
+
+include($$PWD/v8base.pri)
+
+# In debug-and-release builds, generated sources must not go to the same
+# directory, or they could clobber each other in highly parallelized builds
+CONFIG(debug, debug|release):V8_GENERATED_SOURCES_DIR = generated-debug
+else: V8_GENERATED_SOURCES_DIR = generated-release
+
+# this maybe removed in future
+DEFINES += ENABLE_DEBUGGER_SUPPORT
+
+# this is needed by crankshaft ( http://code.google.com/p/v8/issues/detail?id=1271 )
+DEFINES += ENABLE_VMSTATE_TRACKING ENABLE_LOGGING_AND_PROFILING
+
+CONFIG(debug, debug|release) {
+ DEFINES += DEBUG V8_ENABLE_CHECKS OBJECT_PRINT ENABLE_DISASSEMBLER
+} else {
+ DEFINES += NDEBUG
+}
+
+V8SRC = $$V8DIR/src
+
+INCLUDEPATH += \
+ $$V8SRC
+
+SOURCES += \
+ $$V8SRC/accessors.cc \
+ $$V8SRC/allocation.cc \
+ $$V8SRC/api.cc \
+ $$V8SRC/assembler.cc \
+ $$V8SRC/ast.cc \
+ $$V8SRC/atomicops_internals_x86_gcc.cc \
+ $$V8SRC/bignum.cc \
+ $$V8SRC/bignum-dtoa.cc \
+ $$V8SRC/bootstrapper.cc \
+ $$V8SRC/builtins.cc \
+ $$V8SRC/cached-powers.cc \
+ $$V8SRC/checks.cc \
+ $$V8SRC/circular-queue.cc \
+ $$V8SRC/code-stubs.cc \
+ $$V8SRC/codegen.cc \
+ $$V8SRC/compilation-cache.cc \
+ $$V8SRC/compiler.cc \
+ $$V8SRC/contexts.cc \
+ $$V8SRC/conversions.cc \
+ $$V8SRC/counters.cc \
+ $$V8SRC/cpu-profiler.cc \
+ $$V8SRC/data-flow.cc \
+ $$V8SRC/dateparser.cc \
+ $$V8SRC/debug-agent.cc \
+ $$V8SRC/debug.cc \
+ $$V8SRC/deoptimizer.cc \
+ $$V8SRC/disassembler.cc \
+ $$V8SRC/diy-fp.cc \
+ $$V8SRC/dtoa.cc \
+ $$V8SRC/elements.cc \
+ $$V8SRC/execution.cc \
+ $$V8SRC/factory.cc \
+ $$V8SRC/flags.cc \
+ $$V8SRC/frames.cc \
+ $$V8SRC/full-codegen.cc \
+ $$V8SRC/func-name-inferrer.cc \
+ $$V8SRC/gdb-jit.cc \
+ $$V8SRC/global-handles.cc \
+ $$V8SRC/fast-dtoa.cc \
+ $$V8SRC/fixed-dtoa.cc \
+ $$V8SRC/handles.cc \
+ $$V8SRC/hashmap.cc \
+ $$V8SRC/heap-profiler.cc \
+ $$V8SRC/heap.cc \
+ $$V8SRC/hydrogen.cc \
+ $$V8SRC/hydrogen-instructions.cc \
+ $$V8SRC/ic.cc \
+ $$V8SRC/incremental-marking.cc \
+ $$V8SRC/inspector.cc \
+ $$V8SRC/interpreter-irregexp.cc \
+ $$V8SRC/isolate.cc \
+ $$V8SRC/jsregexp.cc \
+ $$V8SRC/lithium-allocator.cc \
+ $$V8SRC/lithium.cc \
+ $$V8SRC/liveedit.cc \
+ $$V8SRC/liveobjectlist.cc \
+ $$V8SRC/log-utils.cc \
+ $$V8SRC/log.cc \
+ $$V8SRC/mark-compact.cc \
+ $$V8SRC/messages.cc \
+ $$V8SRC/objects.cc \
+ $$V8SRC/objects-printer.cc \
+ $$V8SRC/objects-visiting.cc \
+ $$V8SRC/parser.cc \
+ $$V8SRC/preparser.cc \
+ $$V8SRC/preparse-data.cc \
+ $$V8SRC/profile-generator.cc \
+ $$V8SRC/property.cc \
+ $$V8SRC/regexp-macro-assembler-irregexp.cc \
+ $$V8SRC/regexp-macro-assembler.cc \
+ $$V8SRC/regexp-stack.cc \
+ $$V8SRC/rewriter.cc \
+ $$V8SRC/runtime.cc \
+ $$V8SRC/runtime-profiler.cc \
+ $$V8SRC/safepoint-table.cc \
+ $$V8SRC/scanner.cc \
+ $$V8SRC/scanner-character-streams.cc \
+ $$V8SRC/scopeinfo.cc \
+ $$V8SRC/scopes.cc \
+ $$V8SRC/serialize.cc \
+ $$V8SRC/snapshot-common.cc \
+ $$V8SRC/spaces.cc \
+ $$V8SRC/string-search.cc \
+ $$V8SRC/string-stream.cc \
+ $$V8SRC/strtod.cc \
+ $$V8SRC/stub-cache.cc \
+ $$V8SRC/token.cc \
+ $$V8SRC/type-info.cc \
+ $$V8SRC/unicode.cc \
+ $$V8SRC/utils.cc \
+ $$V8SRC/v8-counters.cc \
+ $$V8SRC/v8.cc \
+ $$V8SRC/v8conversions.cc \
+ $$V8SRC/v8threads.cc \
+ $$V8SRC/v8utils.cc \
+ $$V8SRC/variables.cc \
+ $$V8SRC/version.cc \
+ $$V8SRC/store-buffer.cc \
+ $$V8SRC/zone.cc \
+ $$V8SRC/extensions/gc-extension.cc \
+ $$V8SRC/extensions/externalize-string-extension.cc
+
+equals(V8_TARGET_ARCH, arm) {
+DEFINES += V8_TARGET_ARCH_ARM
+DEFINES += USE_EABI_HARDFLOAT=1 CAN_USE_VFP_INSTRUCTIONS
+SOURCES += \
+ $$V8SRC/arm/builtins-arm.cc \
+ $$V8SRC/arm/code-stubs-arm.cc \
+ $$V8SRC/arm/codegen-arm.cc \
+ $$V8SRC/arm/constants-arm.cc \
+ $$V8SRC/arm/cpu-arm.cc \
+ $$V8SRC/arm/debug-arm.cc \
+ $$V8SRC/arm/deoptimizer-arm.cc \
+ $$V8SRC/arm/disasm-arm.cc \
+ $$V8SRC/arm/frames-arm.cc \
+ $$V8SRC/arm/full-codegen-arm.cc \
+ $$V8SRC/arm/ic-arm.cc \
+ $$V8SRC/arm/lithium-arm.cc \
+ $$V8SRC/arm/lithium-codegen-arm.cc \
+ $$V8SRC/arm/lithium-gap-resolver-arm.cc \
+ $$V8SRC/arm/macro-assembler-arm.cc \
+ $$V8SRC/arm/regexp-macro-assembler-arm.cc \
+ $$V8SRC/arm/stub-cache-arm.cc \
+ $$V8SRC/arm/assembler-arm.cc
+} else:equals(V8_TARGET_ARCH, ia32) {
+DEFINES += V8_TARGET_ARCH_IA32
+SOURCES += \
+ $$V8SRC/ia32/assembler-ia32.cc \
+ $$V8SRC/ia32/builtins-ia32.cc \
+ $$V8SRC/ia32/code-stubs-ia32.cc \
+ $$V8SRC/ia32/codegen-ia32.cc \
+ $$V8SRC/ia32/cpu-ia32.cc \
+ $$V8SRC/ia32/debug-ia32.cc \
+ $$V8SRC/ia32/deoptimizer-ia32.cc \
+ $$V8SRC/ia32/disasm-ia32.cc \
+ $$V8SRC/ia32/frames-ia32.cc \
+ $$V8SRC/ia32/full-codegen-ia32.cc \
+ $$V8SRC/ia32/ic-ia32.cc \
+ $$V8SRC/ia32/lithium-codegen-ia32.cc \
+ $$V8SRC/ia32/lithium-gap-resolver-ia32.cc \
+ $$V8SRC/ia32/lithium-ia32.cc \
+ $$V8SRC/ia32/macro-assembler-ia32.cc \
+ $$V8SRC/ia32/regexp-macro-assembler-ia32.cc \
+ $$V8SRC/ia32/stub-cache-ia32.cc
+} else:equals(V8_TARGET_ARCH, x64) {
+# FIXME What about 32-bit Macs?
+DEFINES += V8_TARGET_ARCH_X64
+SOURCES += \
+ $$V8SRC/x64/assembler-x64.cc \
+ $$V8SRC/x64/builtins-x64.cc \
+ $$V8SRC/x64/code-stubs-x64.cc \
+ $$V8SRC/x64/codegen-x64.cc \
+ $$V8SRC/x64/cpu-x64.cc \
+ $$V8SRC/x64/debug-x64.cc \
+ $$V8SRC/x64/deoptimizer-x64.cc \
+ $$V8SRC/x64/disasm-x64.cc \
+ $$V8SRC/x64/frames-x64.cc \
+ $$V8SRC/x64/full-codegen-x64.cc \
+ $$V8SRC/x64/ic-x64.cc \
+ $$V8SRC/x64/lithium-codegen-x64.cc \
+ $$V8SRC/x64/lithium-gap-resolver-x64.cc \
+ $$V8SRC/x64/lithium-x64.cc \
+ $$V8SRC/x64/macro-assembler-x64.cc \
+ $$V8SRC/x64/regexp-macro-assembler-x64.cc \
+ $$V8SRC/x64/stub-cache-x64.cc
+} else:equals(V8_TARGET_ARCH, mips) {
+DEFINES += V8_TARGET_MIPS
+SOURCES += \
+ $$V8SRC/mips/assembler-mips.cc \
+ $$V8SRC/mips/builtins-mips.cc \
+ $$V8SRC/mips/codegen-mips.cc \
+ $$V8SRC/mips/code-stubs-mips.cc \
+ $$V8SRC/mips/constants-mips.cc \
+ $$V8SRC/mips/cpu-mips.cc \
+ $$V8SRC/mips/debug-mips.cc \
+ $$V8SRC/mips/deoptimizer-mips.cc \
+ $$V8SRC/mips/disasm-mips.cc \
+ $$V8SRC/mips/frames-mips.cc \
+ $$V8SRC/mips/full-codegen-mips.cc \
+ $$V8SRC/mips/ic-mips.cc \
+ $$V8SRC/mips/macro-assembler-mips.cc \
+ $$V8SRC/mips/regexp-macro-assembler-mips.cc \
+ $$V8SRC/mips/simulator-mips.cc \
+ $$V8SRC/mips/stub-cache-mips.cc
+}
+
+#os:macos
+macx {
+SOURCES += \
+ $$V8SRC/platform-macos.cc \
+ $$V8SRC/platform-posix.cc
+} else:freebsd-* {
+SOURCES += \
+ $$V8SRC/platform-freebsd.cc \
+ $$V8SRC/platform-posix.cc
+LIBS += -lexecinfo
+} else:unix:!symbian {
+SOURCES += \
+ $$V8SRC/platform-linux.cc \
+ $$V8SRC/platform-posix.cc
+}
+
+win32 {
+SOURCES += \
+ $$V8SRC/platform-win32.cc \
+ $$V8SRC/win32-math.cc
+LIBS += -lWs2_32 -lWinmm
+win32-msvc*: QMAKE_CXXFLAGS += -wd4100 -wd 4291 -wd4351 -wd4355 -wd4800
+win32-msvc*:arch_i386: DEFINES += _USE_32BIT_TIME_T
+}
+
+#mode:debug
+CONFIG(debug) {
+ SOURCES += \
+ $$V8SRC/objects-debug.cc \
+ $$V8SRC/prettyprinter.cc \
+ $$V8SRC/regexp-macro-assembler-tracer.cc
+}
+
+V8_LIBRARY_FILES = \
+ $$V8SRC/runtime.js \
+ $$V8SRC/v8natives.js \
+ $$V8SRC/array.js \
+ $$V8SRC/string.js \
+ $$V8SRC/uri.js \
+ $$V8SRC/math.js \
+ $$V8SRC/messages.js \
+ $$V8SRC/apinatives.js \
+ $$V8SRC/date.js \
+ $$V8SRC/regexp.js \
+ $$V8SRC/json.js \
+ $$V8SRC/liveedit-debugger.js \
+ $$V8SRC/mirror-debugger.js \
+ $$V8SRC/debug-debugger.js
+
+V8_EXPERIMENTAL_LIBRARY_FILES = \
+ $$V8SRC/proxy.js \
+
+v8_js2c.commands = python $$V8DIR/tools/js2c.py $$V8_GENERATED_SOURCES_DIR/libraries.cpp CORE off
+v8_js2c.commands += $$V8SRC/macros.py ${QMAKE_FILE_IN}
+v8_js2c.output = $$V8_GENERATED_SOURCES_DIR/libraries.cpp
+v8_js2c.input = V8_LIBRARY_FILES
+v8_js2c.variable_out = SOURCES
+v8_js2c.dependency_type = TYPE_C
+v8_js2c.depends = $$V8DIR/tools/js2c.py $$V8SRC/macros.py
+v8_js2c.CONFIG += combine
+v8_js2c.name = generating[v8] ${QMAKE_FILE_IN}
+silent:v8_js2c.commands = @echo generating[v8] ${QMAKE_FILE_IN} && $$v8_js2c.commands
+
+v8_js2c_experimental.commands = python $$V8DIR/tools/js2c.py $$V8_GENERATED_SOURCES_DIR/experimental-libraries.cpp EXPERIMENTAL off
+v8_js2c_experimental.commands += $$V8SRC/macros.py ${QMAKE_FILE_IN}
+v8_js2c_experimental.output = $$V8_GENERATED_SOURCES_DIR/experimental-libraries.cpp
+v8_js2c_experimental.input = V8_EXPERIMENTAL_LIBRARY_FILES
+v8_js2c_experimental.variable_out = SOURCES
+v8_js2c_experimental.dependency_type = TYPE_C
+v8_js2c_experimental.depends = $$V8DIR/tools/js2c.py $$V8SRC/macros.py
+v8_js2c_experimental.CONFIG += combine
+v8_js2c_experimental.name = generating[v8] ${QMAKE_FILE_IN}
+
+QMAKE_EXTRA_COMPILERS += v8_js2c v8_js2c_experimental