therubyracer 0.9.0beta2 → 0.9.0beta3
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of therubyracer might be problematic. Click here for more details.
- data/.gitmodules +3 -0
- data/ext/v8/upstream/Makefile +1 -2
- data/ext/v8/upstream/v8/.gitignore +33 -0
- data/ext/v8/upstream/v8/AUTHORS +42 -0
- data/ext/v8/upstream/v8/ChangeLog +2663 -0
- data/ext/v8/upstream/{3.1.8 → v8}/LICENSE +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/LICENSE.strongtalk +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/LICENSE.v8 +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/LICENSE.valgrind +0 -0
- data/ext/v8/upstream/v8/SConstruct +1473 -0
- data/ext/v8/upstream/{3.1.8 → v8}/build/README.txt +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/build/all.gyp +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/build/armu.gypi +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/build/common.gypi +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/build/gyp_v8 +0 -0
- data/ext/v8/upstream/v8/include/v8-debug.h +394 -0
- data/ext/v8/upstream/v8/include/v8-preparser.h +116 -0
- data/ext/v8/upstream/v8/include/v8-profiler.h +505 -0
- data/ext/v8/upstream/v8/include/v8-testing.h +104 -0
- data/ext/v8/upstream/v8/include/v8.h +4000 -0
- data/ext/v8/upstream/{3.1.8 → v8}/include/v8stdint.h +0 -0
- data/ext/v8/upstream/v8/preparser/SConscript +38 -0
- data/ext/v8/upstream/v8/preparser/preparser-process.cc +169 -0
- data/ext/v8/upstream/v8/src/SConscript +380 -0
- data/ext/v8/upstream/v8/src/accessors.cc +766 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/accessors.h +0 -0
- data/ext/v8/upstream/v8/src/allocation-inl.h +49 -0
- data/ext/v8/upstream/v8/src/allocation.cc +122 -0
- data/ext/v8/upstream/v8/src/allocation.h +143 -0
- data/ext/v8/upstream/v8/src/api.cc +5678 -0
- data/ext/v8/upstream/v8/src/api.h +572 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/apinatives.js +0 -0
- data/ext/v8/upstream/v8/src/apiutils.h +73 -0
- data/ext/v8/upstream/v8/src/arguments.h +116 -0
- data/ext/v8/upstream/v8/src/arm/assembler-arm-inl.h +353 -0
- data/ext/v8/upstream/v8/src/arm/assembler-arm.cc +2877 -0
- data/ext/v8/upstream/v8/src/arm/assembler-arm.h +1382 -0
- data/ext/v8/upstream/v8/src/arm/builtins-arm.cc +1634 -0
- data/ext/v8/upstream/v8/src/arm/code-stubs-arm.cc +6917 -0
- data/ext/v8/upstream/v8/src/arm/code-stubs-arm.h +623 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/codegen-arm-inl.h +0 -0
- data/ext/v8/upstream/v8/src/arm/codegen-arm.cc +7437 -0
- data/ext/v8/upstream/v8/src/arm/codegen-arm.h +595 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/constants-arm.cc +0 -0
- data/ext/v8/upstream/v8/src/arm/constants-arm.h +778 -0
- data/ext/v8/upstream/v8/src/arm/cpu-arm.cc +149 -0
- data/ext/v8/upstream/v8/src/arm/debug-arm.cc +317 -0
- data/ext/v8/upstream/v8/src/arm/deoptimizer-arm.cc +737 -0
- data/ext/v8/upstream/v8/src/arm/disasm-arm.cc +1503 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/frames-arm.cc +0 -0
- data/ext/v8/upstream/v8/src/arm/frames-arm.h +168 -0
- data/ext/v8/upstream/v8/src/arm/full-codegen-arm.cc +4374 -0
- data/ext/v8/upstream/v8/src/arm/ic-arm.cc +1793 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/jump-target-arm.cc +0 -0
- data/ext/v8/upstream/v8/src/arm/lithium-arm.cc +2120 -0
- data/ext/v8/upstream/v8/src/arm/lithium-arm.h +2179 -0
- data/ext/v8/upstream/v8/src/arm/lithium-codegen-arm.cc +4132 -0
- data/ext/v8/upstream/v8/src/arm/lithium-codegen-arm.h +329 -0
- data/ext/v8/upstream/v8/src/arm/lithium-gap-resolver-arm.cc +305 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/lithium-gap-resolver-arm.h +0 -0
- data/ext/v8/upstream/v8/src/arm/macro-assembler-arm.cc +2939 -0
- data/ext/v8/upstream/v8/src/arm/macro-assembler-arm.h +1071 -0
- data/ext/v8/upstream/v8/src/arm/regexp-macro-assembler-arm.cc +1287 -0
- data/ext/v8/upstream/v8/src/arm/regexp-macro-assembler-arm.h +253 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/register-allocator-arm-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/register-allocator-arm.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/register-allocator-arm.h +0 -0
- data/ext/v8/upstream/v8/src/arm/simulator-arm.cc +3288 -0
- data/ext/v8/upstream/v8/src/arm/simulator-arm.h +413 -0
- data/ext/v8/upstream/v8/src/arm/stub-cache-arm.cc +4034 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/virtual-frame-arm-inl.h +0 -0
- data/ext/v8/upstream/v8/src/arm/virtual-frame-arm.cc +843 -0
- data/ext/v8/upstream/v8/src/arm/virtual-frame-arm.h +523 -0
- data/ext/v8/upstream/v8/src/array.js +1249 -0
- data/ext/v8/upstream/v8/src/assembler.cc +1067 -0
- data/ext/v8/upstream/v8/src/assembler.h +823 -0
- data/ext/v8/upstream/v8/src/ast-inl.h +112 -0
- data/ext/v8/upstream/v8/src/ast.cc +1078 -0
- data/ext/v8/upstream/v8/src/ast.h +2234 -0
- data/ext/v8/upstream/v8/src/atomicops.h +167 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/atomicops_internals_arm_gcc.h +0 -0
- data/ext/v8/upstream/v8/src/atomicops_internals_mips_gcc.h +169 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/atomicops_internals_x86_gcc.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/atomicops_internals_x86_gcc.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/atomicops_internals_x86_macosx.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/atomicops_internals_x86_msvc.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/bignum-dtoa.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/bignum-dtoa.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/bignum.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/bignum.h +0 -0
- data/ext/v8/upstream/v8/src/bootstrapper.cc +2138 -0
- data/ext/v8/upstream/v8/src/bootstrapper.h +185 -0
- data/ext/v8/upstream/v8/src/builtins.cc +1708 -0
- data/ext/v8/upstream/v8/src/builtins.h +368 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/bytecodes-irregexp.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/cached-powers.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/cached-powers.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/char-predicates-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/char-predicates.h +0 -0
- data/ext/v8/upstream/v8/src/checks.cc +110 -0
- data/ext/v8/upstream/v8/src/checks.h +296 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/circular-queue-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/circular-queue.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/circular-queue.h +0 -0
- data/ext/v8/upstream/v8/src/code-stubs.cc +240 -0
- data/ext/v8/upstream/v8/src/code-stubs.h +971 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/code.h +0 -0
- data/ext/v8/upstream/v8/src/codegen-inl.h +68 -0
- data/ext/v8/upstream/v8/src/codegen.cc +505 -0
- data/ext/v8/upstream/v8/src/codegen.h +245 -0
- data/ext/v8/upstream/v8/src/compilation-cache.cc +540 -0
- data/ext/v8/upstream/v8/src/compilation-cache.h +287 -0
- data/ext/v8/upstream/v8/src/compiler.cc +792 -0
- data/ext/v8/upstream/v8/src/compiler.h +307 -0
- data/ext/v8/upstream/v8/src/contexts.cc +327 -0
- data/ext/v8/upstream/v8/src/contexts.h +382 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/conversions-inl.h +0 -0
- data/ext/v8/upstream/v8/src/conversions.cc +1125 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/conversions.h +0 -0
- data/ext/v8/upstream/v8/src/counters.cc +93 -0
- data/ext/v8/upstream/v8/src/counters.h +254 -0
- data/ext/v8/upstream/v8/src/cpu-profiler-inl.h +101 -0
- data/ext/v8/upstream/v8/src/cpu-profiler.cc +606 -0
- data/ext/v8/upstream/v8/src/cpu-profiler.h +305 -0
- data/ext/v8/upstream/v8/src/cpu.h +67 -0
- data/ext/v8/upstream/v8/src/d8-debug.cc +367 -0
- data/ext/v8/upstream/v8/src/d8-debug.h +158 -0
- data/ext/v8/upstream/v8/src/d8-posix.cc +695 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/d8-readline.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/d8-windows.cc +0 -0
- data/ext/v8/upstream/v8/src/d8.cc +796 -0
- data/ext/v8/upstream/v8/src/d8.gyp +88 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/d8.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/d8.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/data-flow.cc +0 -0
- data/ext/v8/upstream/v8/src/data-flow.h +379 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/date.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/dateparser-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/dateparser.cc +0 -0
- data/ext/v8/upstream/v8/src/dateparser.h +265 -0
- data/ext/v8/upstream/v8/src/debug-agent.cc +447 -0
- data/ext/v8/upstream/v8/src/debug-agent.h +129 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/debug-debugger.js +0 -0
- data/ext/v8/upstream/v8/src/debug.cc +3188 -0
- data/ext/v8/upstream/v8/src/debug.h +1055 -0
- data/ext/v8/upstream/v8/src/deoptimizer.cc +1296 -0
- data/ext/v8/upstream/v8/src/deoptimizer.h +629 -0
- data/ext/v8/upstream/v8/src/disasm.h +80 -0
- data/ext/v8/upstream/v8/src/disassembler.cc +339 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/disassembler.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/diy-fp.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/diy-fp.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/double.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/dtoa.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/dtoa.h +0 -0
- data/ext/v8/upstream/v8/src/execution.cc +791 -0
- data/ext/v8/upstream/v8/src/execution.h +291 -0
- data/ext/v8/upstream/v8/src/extensions/experimental/break-iterator.cc +250 -0
- data/ext/v8/upstream/v8/src/extensions/experimental/break-iterator.h +89 -0
- data/ext/v8/upstream/v8/src/extensions/experimental/experimental.gyp +55 -0
- data/ext/v8/upstream/v8/src/extensions/experimental/i18n-extension.cc +284 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/extensions/experimental/i18n-extension.h +0 -0
- data/ext/v8/upstream/v8/src/extensions/externalize-string-extension.cc +141 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/extensions/externalize-string-extension.h +0 -0
- data/ext/v8/upstream/v8/src/extensions/gc-extension.cc +58 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/extensions/gc-extension.h +0 -0
- data/ext/v8/upstream/v8/src/factory.cc +1194 -0
- data/ext/v8/upstream/v8/src/factory.h +436 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/fast-dtoa.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/fast-dtoa.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/fixed-dtoa.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/fixed-dtoa.h +0 -0
- data/ext/v8/upstream/v8/src/flag-definitions.h +556 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/flags.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/flags.h +0 -0
- data/ext/v8/upstream/v8/src/frame-element.cc +37 -0
- data/ext/v8/upstream/v8/src/frame-element.h +269 -0
- data/ext/v8/upstream/v8/src/frames-inl.h +236 -0
- data/ext/v8/upstream/v8/src/frames.cc +1273 -0
- data/ext/v8/upstream/v8/src/frames.h +854 -0
- data/ext/v8/upstream/v8/src/full-codegen.cc +1385 -0
- data/ext/v8/upstream/v8/src/full-codegen.h +753 -0
- data/ext/v8/upstream/v8/src/func-name-inferrer.cc +91 -0
- data/ext/v8/upstream/v8/src/func-name-inferrer.h +111 -0
- data/ext/v8/upstream/v8/src/gdb-jit.cc +1548 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/gdb-jit.h +0 -0
- data/ext/v8/upstream/v8/src/global-handles.cc +596 -0
- data/ext/v8/upstream/v8/src/global-handles.h +239 -0
- data/ext/v8/upstream/v8/src/globals.h +325 -0
- data/ext/v8/upstream/v8/src/handles-inl.h +177 -0
- data/ext/v8/upstream/v8/src/handles.cc +965 -0
- data/ext/v8/upstream/v8/src/handles.h +372 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/hashmap.cc +0 -0
- data/ext/v8/upstream/v8/src/hashmap.h +121 -0
- data/ext/v8/upstream/v8/src/heap-inl.h +703 -0
- data/ext/v8/upstream/v8/src/heap-profiler.cc +1173 -0
- data/ext/v8/upstream/v8/src/heap-profiler.h +396 -0
- data/ext/v8/upstream/v8/src/heap.cc +5856 -0
- data/ext/v8/upstream/v8/src/heap.h +2264 -0
- data/ext/v8/upstream/v8/src/hydrogen-instructions.cc +1639 -0
- data/ext/v8/upstream/v8/src/hydrogen-instructions.h +3657 -0
- data/ext/v8/upstream/v8/src/hydrogen.cc +6011 -0
- data/ext/v8/upstream/v8/src/hydrogen.h +1137 -0
- data/ext/v8/upstream/v8/src/ia32/assembler-ia32-inl.h +430 -0
- data/ext/v8/upstream/v8/src/ia32/assembler-ia32.cc +2846 -0
- data/ext/v8/upstream/v8/src/ia32/assembler-ia32.h +1159 -0
- data/ext/v8/upstream/v8/src/ia32/builtins-ia32.cc +1596 -0
- data/ext/v8/upstream/v8/src/ia32/code-stubs-ia32.cc +6549 -0
- data/ext/v8/upstream/v8/src/ia32/code-stubs-ia32.h +495 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/ia32/codegen-ia32-inl.h +0 -0
- data/ext/v8/upstream/v8/src/ia32/codegen-ia32.cc +10385 -0
- data/ext/v8/upstream/v8/src/ia32/codegen-ia32.h +801 -0
- data/ext/v8/upstream/v8/src/ia32/cpu-ia32.cc +88 -0
- data/ext/v8/upstream/v8/src/ia32/debug-ia32.cc +312 -0
- data/ext/v8/upstream/v8/src/ia32/deoptimizer-ia32.cc +774 -0
- data/ext/v8/upstream/v8/src/ia32/disasm-ia32.cc +1620 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/ia32/frames-ia32.cc +0 -0
- data/ext/v8/upstream/v8/src/ia32/frames-ia32.h +140 -0
- data/ext/v8/upstream/v8/src/ia32/full-codegen-ia32.cc +4357 -0
- data/ext/v8/upstream/v8/src/ia32/ic-ia32.cc +1779 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/ia32/jump-target-ia32.cc +0 -0
- data/ext/v8/upstream/v8/src/ia32/lithium-codegen-ia32.cc +4158 -0
- data/ext/v8/upstream/v8/src/ia32/lithium-codegen-ia32.h +318 -0
- data/ext/v8/upstream/v8/src/ia32/lithium-gap-resolver-ia32.cc +466 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/ia32/lithium-gap-resolver-ia32.h +0 -0
- data/ext/v8/upstream/v8/src/ia32/lithium-ia32.cc +2181 -0
- data/ext/v8/upstream/v8/src/ia32/lithium-ia32.h +2235 -0
- data/ext/v8/upstream/v8/src/ia32/macro-assembler-ia32.cc +2056 -0
- data/ext/v8/upstream/v8/src/ia32/macro-assembler-ia32.h +807 -0
- data/ext/v8/upstream/v8/src/ia32/regexp-macro-assembler-ia32.cc +1264 -0
- data/ext/v8/upstream/v8/src/ia32/regexp-macro-assembler-ia32.h +216 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/ia32/register-allocator-ia32-inl.h +0 -0
- data/ext/v8/upstream/v8/src/ia32/register-allocator-ia32.cc +157 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/ia32/register-allocator-ia32.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/ia32/simulator-ia32.cc +0 -0
- data/ext/v8/upstream/v8/src/ia32/simulator-ia32.h +72 -0
- data/ext/v8/upstream/v8/src/ia32/stub-cache-ia32.cc +3711 -0
- data/ext/v8/upstream/v8/src/ia32/virtual-frame-ia32.cc +1366 -0
- data/ext/v8/upstream/v8/src/ia32/virtual-frame-ia32.h +650 -0
- data/ext/v8/upstream/v8/src/ic-inl.h +130 -0
- data/ext/v8/upstream/v8/src/ic.cc +2389 -0
- data/ext/v8/upstream/v8/src/ic.h +675 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/inspector.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/inspector.h +0 -0
- data/ext/v8/upstream/v8/src/interpreter-irregexp.cc +659 -0
- data/ext/v8/upstream/v8/src/interpreter-irregexp.h +49 -0
- data/ext/v8/upstream/v8/src/isolate.cc +883 -0
- data/ext/v8/upstream/v8/src/isolate.h +1306 -0
- data/ext/v8/upstream/v8/src/json.js +342 -0
- data/ext/v8/upstream/v8/src/jsregexp.cc +5371 -0
- data/ext/v8/upstream/v8/src/jsregexp.h +1483 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/jump-target-heavy-inl.h +0 -0
- data/ext/v8/upstream/v8/src/jump-target-heavy.cc +427 -0
- data/ext/v8/upstream/v8/src/jump-target-heavy.h +238 -0
- data/ext/v8/upstream/v8/src/jump-target-inl.h +48 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/jump-target-light-inl.h +0 -0
- data/ext/v8/upstream/v8/src/jump-target-light.cc +111 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/jump-target-light.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/jump-target.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/jump-target.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/list-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/list.h +0 -0
- data/ext/v8/upstream/v8/src/lithium-allocator-inl.h +142 -0
- data/ext/v8/upstream/v8/src/lithium-allocator.cc +2105 -0
- data/ext/v8/upstream/v8/src/lithium-allocator.h +630 -0
- data/ext/v8/upstream/v8/src/lithium.cc +169 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/lithium.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/liveedit-debugger.js +0 -0
- data/ext/v8/upstream/v8/src/liveedit.cc +1693 -0
- data/ext/v8/upstream/v8/src/liveedit.h +179 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/liveobjectlist-inl.h +0 -0
- data/ext/v8/upstream/v8/src/liveobjectlist.cc +2589 -0
- data/ext/v8/upstream/v8/src/liveobjectlist.h +322 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/log-inl.h +0 -0
- data/ext/v8/upstream/v8/src/log-utils.cc +423 -0
- data/ext/v8/upstream/v8/src/log-utils.h +229 -0
- data/ext/v8/upstream/v8/src/log.cc +1666 -0
- data/ext/v8/upstream/v8/src/log.h +446 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/macro-assembler.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/macros.py +0 -0
- data/ext/v8/upstream/v8/src/mark-compact.cc +3092 -0
- data/ext/v8/upstream/v8/src/mark-compact.h +506 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/math.js +0 -0
- data/ext/v8/upstream/v8/src/messages.cc +166 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/messages.h +0 -0
- data/ext/v8/upstream/v8/src/messages.js +1090 -0
- data/ext/v8/upstream/v8/src/mips/assembler-mips-inl.h +335 -0
- data/ext/v8/upstream/v8/src/mips/assembler-mips.cc +2093 -0
- data/ext/v8/upstream/v8/src/mips/assembler-mips.h +1066 -0
- data/ext/v8/upstream/v8/src/mips/builtins-mips.cc +148 -0
- data/ext/v8/upstream/v8/src/mips/code-stubs-mips.cc +752 -0
- data/ext/v8/upstream/v8/src/mips/code-stubs-mips.h +511 -0
- data/ext/v8/upstream/v8/src/mips/codegen-mips-inl.h +64 -0
- data/ext/v8/upstream/v8/src/mips/codegen-mips.cc +1213 -0
- data/ext/v8/upstream/v8/src/mips/codegen-mips.h +633 -0
- data/ext/v8/upstream/v8/src/mips/constants-mips.cc +352 -0
- data/ext/v8/upstream/v8/src/mips/constants-mips.h +723 -0
- data/ext/v8/upstream/v8/src/mips/cpu-mips.cc +90 -0
- data/ext/v8/upstream/v8/src/mips/debug-mips.cc +155 -0
- data/ext/v8/upstream/v8/src/mips/deoptimizer-mips.cc +91 -0
- data/ext/v8/upstream/v8/src/mips/disasm-mips.cc +1023 -0
- data/ext/v8/upstream/v8/src/mips/frames-mips.cc +48 -0
- data/ext/v8/upstream/v8/src/mips/frames-mips.h +179 -0
- data/ext/v8/upstream/v8/src/mips/full-codegen-mips.cc +727 -0
- data/ext/v8/upstream/v8/src/mips/ic-mips.cc +244 -0
- data/ext/v8/upstream/v8/src/mips/jump-target-mips.cc +80 -0
- data/ext/v8/upstream/v8/src/mips/lithium-codegen-mips.h +65 -0
- data/ext/v8/upstream/v8/src/mips/lithium-mips.h +304 -0
- data/ext/v8/upstream/v8/src/mips/macro-assembler-mips.cc +3327 -0
- data/ext/v8/upstream/v8/src/mips/macro-assembler-mips.h +1058 -0
- data/ext/v8/upstream/v8/src/mips/regexp-macro-assembler-mips.cc +478 -0
- data/ext/v8/upstream/v8/src/mips/regexp-macro-assembler-mips.h +250 -0
- data/ext/v8/upstream/v8/src/mips/register-allocator-mips-inl.h +134 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/mips/register-allocator-mips.cc +0 -0
- data/ext/v8/upstream/v8/src/mips/register-allocator-mips.h +47 -0
- data/ext/v8/upstream/v8/src/mips/simulator-mips.cc +2438 -0
- data/ext/v8/upstream/v8/src/mips/simulator-mips.h +394 -0
- data/ext/v8/upstream/v8/src/mips/stub-cache-mips.cc +601 -0
- data/ext/v8/upstream/v8/src/mips/virtual-frame-mips-inl.h +58 -0
- data/ext/v8/upstream/v8/src/mips/virtual-frame-mips.cc +307 -0
- data/ext/v8/upstream/v8/src/mips/virtual-frame-mips.h +530 -0
- data/ext/v8/upstream/v8/src/mirror-debugger.js +2381 -0
- data/ext/v8/upstream/v8/src/mksnapshot.cc +256 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/natives.h +0 -0
- data/ext/v8/upstream/v8/src/objects-debug.cc +722 -0
- data/ext/v8/upstream/v8/src/objects-inl.h +4166 -0
- data/ext/v8/upstream/v8/src/objects-printer.cc +801 -0
- data/ext/v8/upstream/v8/src/objects-visiting.cc +142 -0
- data/ext/v8/upstream/v8/src/objects-visiting.h +422 -0
- data/ext/v8/upstream/v8/src/objects.cc +10296 -0
- data/ext/v8/upstream/v8/src/objects.h +6662 -0
- data/ext/v8/upstream/v8/src/parser.cc +5168 -0
- data/ext/v8/upstream/v8/src/parser.h +823 -0
- data/ext/v8/upstream/v8/src/platform-cygwin.cc +811 -0
- data/ext/v8/upstream/v8/src/platform-freebsd.cc +854 -0
- data/ext/v8/upstream/v8/src/platform-linux.cc +1120 -0
- data/ext/v8/upstream/v8/src/platform-macos.cc +865 -0
- data/ext/v8/upstream/v8/src/platform-nullos.cc +504 -0
- data/ext/v8/upstream/v8/src/platform-openbsd.cc +672 -0
- data/ext/v8/upstream/v8/src/platform-posix.cc +424 -0
- data/ext/v8/upstream/v8/src/platform-solaris.cc +796 -0
- data/ext/v8/upstream/v8/src/platform-tls-mac.h +62 -0
- data/ext/v8/upstream/v8/src/platform-tls-win32.h +62 -0
- data/ext/v8/upstream/v8/src/platform-tls.h +50 -0
- data/ext/v8/upstream/v8/src/platform-win32.cc +2072 -0
- data/ext/v8/upstream/v8/src/platform.h +693 -0
- data/ext/v8/upstream/v8/src/preparse-data.cc +185 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/preparse-data.h +0 -0
- data/ext/v8/upstream/v8/src/preparser-api.cc +219 -0
- data/ext/v8/upstream/v8/src/preparser.cc +1205 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/preparser.h +0 -0
- data/ext/v8/upstream/v8/src/prettyprinter.cc +1530 -0
- data/ext/v8/upstream/v8/src/prettyprinter.h +223 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/profile-generator-inl.h +0 -0
- data/ext/v8/upstream/v8/src/profile-generator.cc +3095 -0
- data/ext/v8/upstream/v8/src/profile-generator.h +1125 -0
- data/ext/v8/upstream/v8/src/property.cc +102 -0
- data/ext/v8/upstream/v8/src/property.h +348 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/regexp-macro-assembler-irregexp-inl.h +0 -0
- data/ext/v8/upstream/v8/src/regexp-macro-assembler-irregexp.cc +470 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/regexp-macro-assembler-irregexp.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/regexp-macro-assembler-tracer.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/regexp-macro-assembler-tracer.h +0 -0
- data/ext/v8/upstream/v8/src/regexp-macro-assembler.cc +266 -0
- data/ext/v8/upstream/v8/src/regexp-macro-assembler.h +236 -0
- data/ext/v8/upstream/v8/src/regexp-stack.cc +111 -0
- data/ext/v8/upstream/v8/src/regexp-stack.h +147 -0
- data/ext/v8/upstream/v8/src/regexp.js +483 -0
- data/ext/v8/upstream/v8/src/register-allocator-inl.h +141 -0
- data/ext/v8/upstream/v8/src/register-allocator.cc +98 -0
- data/ext/v8/upstream/v8/src/register-allocator.h +310 -0
- data/ext/v8/upstream/v8/src/rewriter.cc +1024 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/rewriter.h +0 -0
- data/ext/v8/upstream/v8/src/runtime-profiler.cc +478 -0
- data/ext/v8/upstream/v8/src/runtime-profiler.h +192 -0
- data/ext/v8/upstream/v8/src/runtime.cc +11949 -0
- data/ext/v8/upstream/v8/src/runtime.h +643 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/runtime.js +0 -0
- data/ext/v8/upstream/v8/src/safepoint-table.cc +256 -0
- data/ext/v8/upstream/v8/src/safepoint-table.h +269 -0
- data/ext/v8/upstream/v8/src/scanner-base.cc +964 -0
- data/ext/v8/upstream/v8/src/scanner-base.h +664 -0
- data/ext/v8/upstream/v8/src/scanner.cc +584 -0
- data/ext/v8/upstream/v8/src/scanner.h +196 -0
- data/ext/v8/upstream/v8/src/scopeinfo.cc +631 -0
- data/ext/v8/upstream/v8/src/scopeinfo.h +249 -0
- data/ext/v8/upstream/v8/src/scopes.cc +1093 -0
- data/ext/v8/upstream/v8/src/scopes.h +508 -0
- data/ext/v8/upstream/v8/src/serialize.cc +1574 -0
- data/ext/v8/upstream/v8/src/serialize.h +589 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/shell.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/simulator.h +0 -0
- data/ext/v8/upstream/v8/src/small-pointer-list.h +163 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/smart-pointer.h +0 -0
- data/ext/v8/upstream/v8/src/snapshot-common.cc +82 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/snapshot-empty.cc +0 -0
- data/ext/v8/upstream/v8/src/snapshot.h +73 -0
- data/ext/v8/upstream/v8/src/spaces-inl.h +529 -0
- data/ext/v8/upstream/v8/src/spaces.cc +3147 -0
- data/ext/v8/upstream/v8/src/spaces.h +2368 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/splay-tree-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/splay-tree.h +0 -0
- data/ext/v8/upstream/v8/src/string-search.cc +41 -0
- data/ext/v8/upstream/v8/src/string-search.h +568 -0
- data/ext/v8/upstream/v8/src/string-stream.cc +592 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/string-stream.h +0 -0
- data/ext/v8/upstream/v8/src/string.js +915 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/strtod.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/strtod.h +0 -0
- data/ext/v8/upstream/v8/src/stub-cache.cc +1940 -0
- data/ext/v8/upstream/v8/src/stub-cache.h +866 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/third_party/valgrind/valgrind.h +0 -0
- data/ext/v8/upstream/v8/src/token.cc +63 -0
- data/ext/v8/upstream/v8/src/token.h +288 -0
- data/ext/v8/upstream/v8/src/top.cc +983 -0
- data/ext/v8/upstream/v8/src/type-info.cc +472 -0
- data/ext/v8/upstream/v8/src/type-info.h +290 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/unbound-queue-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/unbound-queue.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/unicode-inl.h +0 -0
- data/ext/v8/upstream/v8/src/unicode.cc +1624 -0
- data/ext/v8/upstream/v8/src/unicode.h +280 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/uri.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/utils.cc +0 -0
- data/ext/v8/upstream/v8/src/utils.h +796 -0
- data/ext/v8/upstream/v8/src/v8-counters.cc +62 -0
- data/ext/v8/upstream/v8/src/v8-counters.h +311 -0
- data/ext/v8/upstream/v8/src/v8.cc +215 -0
- data/ext/v8/upstream/v8/src/v8.h +130 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/v8checks.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/v8dll-main.cc +0 -0
- data/ext/v8/upstream/v8/src/v8globals.h +486 -0
- data/ext/v8/upstream/{3.1.8/src/memory.h → v8/src/v8memory.h} +0 -0
- data/ext/v8/upstream/v8/src/v8natives.js +1293 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/v8preparserdll-main.cc +0 -0
- data/ext/v8/upstream/v8/src/v8threads.cc +453 -0
- data/ext/v8/upstream/v8/src/v8threads.h +164 -0
- data/ext/v8/upstream/v8/src/v8utils.h +317 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/variables.cc +0 -0
- data/ext/v8/upstream/v8/src/variables.h +212 -0
- data/ext/v8/upstream/v8/src/version.cc +116 -0
- data/ext/v8/upstream/v8/src/version.h +68 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/virtual-frame-heavy-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/virtual-frame-heavy.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/virtual-frame-inl.h +0 -0
- data/ext/v8/upstream/v8/src/virtual-frame-light-inl.h +171 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/virtual-frame-light.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/virtual-frame.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/virtual-frame.h +0 -0
- data/ext/v8/upstream/v8/src/vm-state-inl.h +138 -0
- data/ext/v8/upstream/v8/src/vm-state.h +70 -0
- data/ext/v8/upstream/v8/src/win32-headers.h +96 -0
- data/ext/v8/upstream/v8/src/x64/assembler-x64-inl.h +456 -0
- data/ext/v8/upstream/v8/src/x64/assembler-x64.cc +2954 -0
- data/ext/v8/upstream/v8/src/x64/assembler-x64.h +1630 -0
- data/ext/v8/upstream/v8/src/x64/builtins-x64.cc +1493 -0
- data/ext/v8/upstream/v8/src/x64/code-stubs-x64.cc +5132 -0
- data/ext/v8/upstream/v8/src/x64/code-stubs-x64.h +477 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/x64/codegen-x64-inl.h +0 -0
- data/ext/v8/upstream/v8/src/x64/codegen-x64.cc +8843 -0
- data/ext/v8/upstream/v8/src/x64/codegen-x64.h +753 -0
- data/ext/v8/upstream/v8/src/x64/cpu-x64.cc +88 -0
- data/ext/v8/upstream/v8/src/x64/debug-x64.cc +318 -0
- data/ext/v8/upstream/v8/src/x64/deoptimizer-x64.cc +815 -0
- data/ext/v8/upstream/v8/src/x64/disasm-x64.cc +1752 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/x64/frames-x64.cc +0 -0
- data/ext/v8/upstream/v8/src/x64/frames-x64.h +130 -0
- data/ext/v8/upstream/v8/src/x64/full-codegen-x64.cc +4339 -0
- data/ext/v8/upstream/v8/src/x64/ic-x64.cc +1752 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/x64/jump-target-x64.cc +0 -0
- data/ext/v8/upstream/v8/src/x64/lithium-codegen-x64.cc +3970 -0
- data/ext/v8/upstream/v8/src/x64/lithium-codegen-x64.h +318 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/x64/lithium-gap-resolver-x64.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/x64/lithium-gap-resolver-x64.h +0 -0
- data/ext/v8/upstream/v8/src/x64/lithium-x64.cc +2115 -0
- data/ext/v8/upstream/v8/src/x64/lithium-x64.h +2161 -0
- data/ext/v8/upstream/v8/src/x64/macro-assembler-x64.cc +2911 -0
- data/ext/v8/upstream/v8/src/x64/macro-assembler-x64.h +1984 -0
- data/ext/v8/upstream/v8/src/x64/regexp-macro-assembler-x64.cc +1398 -0
- data/ext/v8/upstream/v8/src/x64/regexp-macro-assembler-x64.h +282 -0
- data/ext/v8/upstream/v8/src/x64/register-allocator-x64-inl.h +87 -0
- data/ext/v8/upstream/v8/src/x64/register-allocator-x64.cc +95 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/x64/register-allocator-x64.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/x64/simulator-x64.cc +0 -0
- data/ext/v8/upstream/v8/src/x64/simulator-x64.h +71 -0
- data/ext/v8/upstream/v8/src/x64/stub-cache-x64.cc +3460 -0
- data/ext/v8/upstream/v8/src/x64/virtual-frame-x64.cc +1296 -0
- data/ext/v8/upstream/v8/src/x64/virtual-frame-x64.h +597 -0
- data/ext/v8/upstream/v8/src/zone-inl.h +129 -0
- data/ext/v8/upstream/v8/src/zone.cc +196 -0
- data/ext/v8/upstream/v8/src/zone.h +236 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/codemap.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/consarray.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/csvparser.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/disasm.py +0 -0
- data/ext/v8/upstream/v8/tools/freebsd-tick-processor +10 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/gc-nvp-trace-processor.py +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/generate-ten-powers.scm +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/grokdump.py +0 -0
- data/ext/v8/upstream/v8/tools/gyp/v8.gyp +844 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/js2c.py +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/jsmin.py +0 -0
- data/ext/v8/upstream/v8/tools/linux-tick-processor +35 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/ll_prof.py +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/logreader.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/mac-nm +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/mac-tick-processor +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/oom_dump/README +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/oom_dump/SConstruct +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/oom_dump/oom_dump.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/presubmit.py +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/process-heap-prof.py +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/profile.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/profile_view.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/run-valgrind.py +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/splaytree.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/stats-viewer.py +0 -0
- data/ext/v8/upstream/v8/tools/test.py +1490 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/tickprocessor-driver.js +0 -0
- data/ext/v8/upstream/v8/tools/tickprocessor.js +877 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/utils.py +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/README.txt +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/arm.vsprops +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/common.vsprops +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/d8.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/d8_arm.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/d8_x64.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/d8js2c.cmd +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/debug.vsprops +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/ia32.vsprops +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/js2c.cmd +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/release.vsprops +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8.sln +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_arm.sln +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_arm.vcproj +0 -0
- data/ext/v8/upstream/v8/tools/visual_studio/v8_base.vcproj +1308 -0
- data/ext/v8/upstream/v8/tools/visual_studio/v8_base_arm.vcproj +1238 -0
- data/ext/v8/upstream/v8/tools/visual_studio/v8_base_x64.vcproj +1300 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_cctest.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_cctest_arm.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_cctest_x64.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_mksnapshot.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_mksnapshot_x64.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_process_sample.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_process_sample_arm.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_process_sample_x64.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_shell_sample.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_shell_sample_arm.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_shell_sample_x64.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_snapshot.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_snapshot_cc.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_snapshot_cc_x64.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_snapshot_x64.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_x64.sln +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_x64.vcproj +0 -0
- data/ext/v8/upstream/v8/tools/visual_studio/x64.vsprops +18 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/windows-tick-processor.bat +0 -0
- data/ext/v8/v8_callbacks.cpp +52 -92
- data/ext/v8/v8_date.cpp +2 -3
- data/ext/v8/v8_object.cpp +4 -0
- data/ext/v8/v8_template.cpp +2 -2
- data/ext/v8/v8_try_catch.cpp +8 -38
- data/lib/v8/version.rb +1 -1
- data/spec/ext/ext_spec_helper.rb +2 -20
- data/spec/ext/object_spec.rb +0 -12
- data/spec/ext/try_catch_spec.rb +29 -1
- data/spec/spec_helper.rb +1 -0
- data/spec/v8/portal/proxies_spec.rb +1 -84
- data/specmem/handle_memspec.rb +41 -0
- data/specmem/object_memspec.rb +16 -0
- data/specmem/proxies_memspec.rb +86 -0
- data/specmem/spec_helper.rb +24 -0
- data/therubyracer.gemspec +7 -2
- metadata +564 -541
- data/ext/v8/upstream/3.1.8/.gitignore +0 -31
- data/ext/v8/upstream/3.1.8/AUTHORS +0 -40
- data/ext/v8/upstream/3.1.8/ChangeLog +0 -2566
- data/ext/v8/upstream/3.1.8/SConstruct +0 -1192
- data/ext/v8/upstream/3.1.8/include/v8-debug.h +0 -384
- data/ext/v8/upstream/3.1.8/include/v8-preparser.h +0 -116
- data/ext/v8/upstream/3.1.8/include/v8-profiler.h +0 -426
- data/ext/v8/upstream/3.1.8/include/v8-testing.h +0 -99
- data/ext/v8/upstream/3.1.8/include/v8.h +0 -3846
- data/ext/v8/upstream/3.1.8/preparser/preparser-process.cc +0 -206
- data/ext/v8/upstream/3.1.8/src/SConscript +0 -356
- data/ext/v8/upstream/3.1.8/src/accessors.cc +0 -907
- data/ext/v8/upstream/3.1.8/src/allocation.cc +0 -204
- data/ext/v8/upstream/3.1.8/src/allocation.h +0 -176
- data/ext/v8/upstream/3.1.8/src/api.cc +0 -5191
- data/ext/v8/upstream/3.1.8/src/api.h +0 -508
- data/ext/v8/upstream/3.1.8/src/apiutils.h +0 -80
- data/ext/v8/upstream/3.1.8/src/arguments.h +0 -105
- data/ext/v8/upstream/3.1.8/src/arm/assembler-arm-inl.h +0 -352
- data/ext/v8/upstream/3.1.8/src/arm/assembler-arm.cc +0 -2756
- data/ext/v8/upstream/3.1.8/src/arm/assembler-arm.h +0 -1294
- data/ext/v8/upstream/3.1.8/src/arm/builtins-arm.cc +0 -1628
- data/ext/v8/upstream/3.1.8/src/arm/code-stubs-arm.cc +0 -6783
- data/ext/v8/upstream/3.1.8/src/arm/code-stubs-arm.h +0 -657
- data/ext/v8/upstream/3.1.8/src/arm/codegen-arm.cc +0 -7403
- data/ext/v8/upstream/3.1.8/src/arm/codegen-arm.h +0 -595
- data/ext/v8/upstream/3.1.8/src/arm/constants-arm.h +0 -769
- data/ext/v8/upstream/3.1.8/src/arm/cpu-arm.cc +0 -147
- data/ext/v8/upstream/3.1.8/src/arm/debug-arm.cc +0 -315
- data/ext/v8/upstream/3.1.8/src/arm/deoptimizer-arm.cc +0 -700
- data/ext/v8/upstream/3.1.8/src/arm/disasm-arm.cc +0 -1439
- data/ext/v8/upstream/3.1.8/src/arm/frames-arm.h +0 -168
- data/ext/v8/upstream/3.1.8/src/arm/full-codegen-arm.cc +0 -4230
- data/ext/v8/upstream/3.1.8/src/arm/ic-arm.cc +0 -1799
- data/ext/v8/upstream/3.1.8/src/arm/lithium-arm.cc +0 -2041
- data/ext/v8/upstream/3.1.8/src/arm/lithium-arm.h +0 -2046
- data/ext/v8/upstream/3.1.8/src/arm/lithium-codegen-arm.cc +0 -3822
- data/ext/v8/upstream/3.1.8/src/arm/lithium-codegen-arm.h +0 -312
- data/ext/v8/upstream/3.1.8/src/arm/lithium-gap-resolver-arm.cc +0 -303
- data/ext/v8/upstream/3.1.8/src/arm/macro-assembler-arm.cc +0 -2701
- data/ext/v8/upstream/3.1.8/src/arm/macro-assembler-arm.h +0 -1015
- data/ext/v8/upstream/3.1.8/src/arm/regexp-macro-assembler-arm.cc +0 -1280
- data/ext/v8/upstream/3.1.8/src/arm/regexp-macro-assembler-arm.h +0 -252
- data/ext/v8/upstream/3.1.8/src/arm/simulator-arm.cc +0 -3165
- data/ext/v8/upstream/3.1.8/src/arm/simulator-arm.h +0 -402
- data/ext/v8/upstream/3.1.8/src/arm/stub-cache-arm.cc +0 -4077
- data/ext/v8/upstream/3.1.8/src/arm/virtual-frame-arm.cc +0 -843
- data/ext/v8/upstream/3.1.8/src/arm/virtual-frame-arm.h +0 -520
- data/ext/v8/upstream/3.1.8/src/array.js +0 -1231
- data/ext/v8/upstream/3.1.8/src/assembler.cc +0 -973
- data/ext/v8/upstream/3.1.8/src/assembler.h +0 -787
- data/ext/v8/upstream/3.1.8/src/ast-inl.h +0 -107
- data/ext/v8/upstream/3.1.8/src/ast.cc +0 -1067
- data/ext/v8/upstream/3.1.8/src/ast.h +0 -2177
- data/ext/v8/upstream/3.1.8/src/atomicops.h +0 -165
- data/ext/v8/upstream/3.1.8/src/bootstrapper.cc +0 -1888
- data/ext/v8/upstream/3.1.8/src/bootstrapper.h +0 -118
- data/ext/v8/upstream/3.1.8/src/builtins.cc +0 -1586
- data/ext/v8/upstream/3.1.8/src/builtins.h +0 -339
- data/ext/v8/upstream/3.1.8/src/checks.cc +0 -110
- data/ext/v8/upstream/3.1.8/src/checks.h +0 -292
- data/ext/v8/upstream/3.1.8/src/code-stubs.cc +0 -230
- data/ext/v8/upstream/3.1.8/src/code-stubs.h +0 -950
- data/ext/v8/upstream/3.1.8/src/codegen-inl.h +0 -64
- data/ext/v8/upstream/3.1.8/src/codegen.cc +0 -495
- data/ext/v8/upstream/3.1.8/src/codegen.h +0 -245
- data/ext/v8/upstream/3.1.8/src/compilation-cache.cc +0 -654
- data/ext/v8/upstream/3.1.8/src/compilation-cache.h +0 -112
- data/ext/v8/upstream/3.1.8/src/compiler.cc +0 -806
- data/ext/v8/upstream/3.1.8/src/compiler.h +0 -290
- data/ext/v8/upstream/3.1.8/src/contexts.cc +0 -320
- data/ext/v8/upstream/3.1.8/src/contexts.h +0 -376
- data/ext/v8/upstream/3.1.8/src/conversions.cc +0 -1069
- data/ext/v8/upstream/3.1.8/src/counters.cc +0 -78
- data/ext/v8/upstream/3.1.8/src/counters.h +0 -242
- data/ext/v8/upstream/3.1.8/src/cpu-profiler-inl.h +0 -100
- data/ext/v8/upstream/3.1.8/src/cpu-profiler.cc +0 -554
- data/ext/v8/upstream/3.1.8/src/cpu-profiler.h +0 -291
- data/ext/v8/upstream/3.1.8/src/cpu.h +0 -65
- data/ext/v8/upstream/3.1.8/src/d8-debug.cc +0 -367
- data/ext/v8/upstream/3.1.8/src/d8-debug.h +0 -157
- data/ext/v8/upstream/3.1.8/src/d8-posix.cc +0 -693
- data/ext/v8/upstream/3.1.8/src/d8.cc +0 -792
- data/ext/v8/upstream/3.1.8/src/d8.gyp +0 -85
- data/ext/v8/upstream/3.1.8/src/data-flow.h +0 -379
- data/ext/v8/upstream/3.1.8/src/dateparser.h +0 -263
- data/ext/v8/upstream/3.1.8/src/debug-agent.cc +0 -446
- data/ext/v8/upstream/3.1.8/src/debug-agent.h +0 -131
- data/ext/v8/upstream/3.1.8/src/debug.cc +0 -3085
- data/ext/v8/upstream/3.1.8/src/debug.h +0 -1025
- data/ext/v8/upstream/3.1.8/src/deoptimizer.cc +0 -1185
- data/ext/v8/upstream/3.1.8/src/deoptimizer.h +0 -529
- data/ext/v8/upstream/3.1.8/src/disasm.h +0 -77
- data/ext/v8/upstream/3.1.8/src/disassembler.cc +0 -338
- data/ext/v8/upstream/3.1.8/src/execution.cc +0 -735
- data/ext/v8/upstream/3.1.8/src/execution.h +0 -322
- data/ext/v8/upstream/3.1.8/src/extensions/experimental/experimental.gyp +0 -53
- data/ext/v8/upstream/3.1.8/src/extensions/experimental/i18n-extension.cc +0 -264
- data/ext/v8/upstream/3.1.8/src/extensions/externalize-string-extension.cc +0 -141
- data/ext/v8/upstream/3.1.8/src/extensions/gc-extension.cc +0 -58
- data/ext/v8/upstream/3.1.8/src/factory.cc +0 -1087
- data/ext/v8/upstream/3.1.8/src/factory.h +0 -432
- data/ext/v8/upstream/3.1.8/src/flag-definitions.h +0 -552
- data/ext/v8/upstream/3.1.8/src/frame-element.cc +0 -42
- data/ext/v8/upstream/3.1.8/src/frame-element.h +0 -277
- data/ext/v8/upstream/3.1.8/src/frames-inl.h +0 -210
- data/ext/v8/upstream/3.1.8/src/frames.cc +0 -1232
- data/ext/v8/upstream/3.1.8/src/frames.h +0 -826
- data/ext/v8/upstream/3.1.8/src/full-codegen.cc +0 -1382
- data/ext/v8/upstream/3.1.8/src/full-codegen.h +0 -751
- data/ext/v8/upstream/3.1.8/src/func-name-inferrer.cc +0 -90
- data/ext/v8/upstream/3.1.8/src/func-name-inferrer.h +0 -111
- data/ext/v8/upstream/3.1.8/src/gdb-jit.cc +0 -1547
- data/ext/v8/upstream/3.1.8/src/global-handles.cc +0 -534
- data/ext/v8/upstream/3.1.8/src/global-handles.h +0 -181
- data/ext/v8/upstream/3.1.8/src/globals.h +0 -325
- data/ext/v8/upstream/3.1.8/src/handles-inl.h +0 -80
- data/ext/v8/upstream/3.1.8/src/handles.cc +0 -910
- data/ext/v8/upstream/3.1.8/src/handles.h +0 -424
- data/ext/v8/upstream/3.1.8/src/hashmap.h +0 -121
- data/ext/v8/upstream/3.1.8/src/heap-inl.h +0 -587
- data/ext/v8/upstream/3.1.8/src/heap-profiler.cc +0 -1128
- data/ext/v8/upstream/3.1.8/src/heap-profiler.h +0 -381
- data/ext/v8/upstream/3.1.8/src/heap.cc +0 -5610
- data/ext/v8/upstream/3.1.8/src/heap.h +0 -2218
- data/ext/v8/upstream/3.1.8/src/hydrogen-instructions.cc +0 -1490
- data/ext/v8/upstream/3.1.8/src/hydrogen-instructions.h +0 -3493
- data/ext/v8/upstream/3.1.8/src/hydrogen.cc +0 -6056
- data/ext/v8/upstream/3.1.8/src/hydrogen.h +0 -1091
- data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32-inl.h +0 -429
- data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32.cc +0 -2800
- data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32.h +0 -1093
- data/ext/v8/upstream/3.1.8/src/ia32/builtins-ia32.cc +0 -1590
- data/ext/v8/upstream/3.1.8/src/ia32/code-stubs-ia32.cc +0 -6624
- data/ext/v8/upstream/3.1.8/src/ia32/code-stubs-ia32.h +0 -536
- data/ext/v8/upstream/3.1.8/src/ia32/codegen-ia32.cc +0 -10354
- data/ext/v8/upstream/3.1.8/src/ia32/codegen-ia32.h +0 -798
- data/ext/v8/upstream/3.1.8/src/ia32/cpu-ia32.cc +0 -87
- data/ext/v8/upstream/3.1.8/src/ia32/debug-ia32.cc +0 -309
- data/ext/v8/upstream/3.1.8/src/ia32/deoptimizer-ia32.cc +0 -664
- data/ext/v8/upstream/3.1.8/src/ia32/disasm-ia32.cc +0 -1597
- data/ext/v8/upstream/3.1.8/src/ia32/frames-ia32.h +0 -140
- data/ext/v8/upstream/3.1.8/src/ia32/full-codegen-ia32.cc +0 -4278
- data/ext/v8/upstream/3.1.8/src/ia32/ic-ia32.cc +0 -1786
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-codegen-ia32.cc +0 -3880
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-codegen-ia32.h +0 -309
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-gap-resolver-ia32.cc +0 -460
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-ia32.cc +0 -2095
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-ia32.h +0 -2127
- data/ext/v8/upstream/3.1.8/src/ia32/macro-assembler-ia32.cc +0 -2031
- data/ext/v8/upstream/3.1.8/src/ia32/macro-assembler-ia32.h +0 -798
- data/ext/v8/upstream/3.1.8/src/ia32/regexp-macro-assembler-ia32.cc +0 -1253
- data/ext/v8/upstream/3.1.8/src/ia32/regexp-macro-assembler-ia32.h +0 -215
- data/ext/v8/upstream/3.1.8/src/ia32/register-allocator-ia32.cc +0 -157
- data/ext/v8/upstream/3.1.8/src/ia32/simulator-ia32.h +0 -72
- data/ext/v8/upstream/3.1.8/src/ia32/stub-cache-ia32.cc +0 -3732
- data/ext/v8/upstream/3.1.8/src/ia32/virtual-frame-ia32.cc +0 -1360
- data/ext/v8/upstream/3.1.8/src/ia32/virtual-frame-ia32.h +0 -646
- data/ext/v8/upstream/3.1.8/src/ic-inl.h +0 -129
- data/ext/v8/upstream/3.1.8/src/ic.cc +0 -2333
- data/ext/v8/upstream/3.1.8/src/ic.h +0 -639
- data/ext/v8/upstream/3.1.8/src/interpreter-irregexp.cc +0 -655
- data/ext/v8/upstream/3.1.8/src/interpreter-irregexp.h +0 -48
- data/ext/v8/upstream/3.1.8/src/json.js +0 -342
- data/ext/v8/upstream/3.1.8/src/jsregexp.cc +0 -5340
- data/ext/v8/upstream/3.1.8/src/jsregexp.h +0 -1484
- data/ext/v8/upstream/3.1.8/src/jump-target-heavy.cc +0 -430
- data/ext/v8/upstream/3.1.8/src/jump-target-heavy.h +0 -244
- data/ext/v8/upstream/3.1.8/src/jump-target-inl.h +0 -48
- data/ext/v8/upstream/3.1.8/src/jump-target-light.cc +0 -111
- data/ext/v8/upstream/3.1.8/src/lithium-allocator-inl.h +0 -140
- data/ext/v8/upstream/3.1.8/src/lithium-allocator.cc +0 -2093
- data/ext/v8/upstream/3.1.8/src/lithium-allocator.h +0 -644
- data/ext/v8/upstream/3.1.8/src/lithium.cc +0 -168
- data/ext/v8/upstream/3.1.8/src/liveedit.cc +0 -1650
- data/ext/v8/upstream/3.1.8/src/liveedit.h +0 -174
- data/ext/v8/upstream/3.1.8/src/liveobjectlist.cc +0 -2527
- data/ext/v8/upstream/3.1.8/src/liveobjectlist.h +0 -322
- data/ext/v8/upstream/3.1.8/src/log-utils.cc +0 -336
- data/ext/v8/upstream/3.1.8/src/log-utils.h +0 -232
- data/ext/v8/upstream/3.1.8/src/log.cc +0 -1608
- data/ext/v8/upstream/3.1.8/src/log.h +0 -379
- data/ext/v8/upstream/3.1.8/src/mark-compact.cc +0 -2957
- data/ext/v8/upstream/3.1.8/src/mark-compact.h +0 -433
- data/ext/v8/upstream/3.1.8/src/messages.cc +0 -164
- data/ext/v8/upstream/3.1.8/src/messages.js +0 -1071
- data/ext/v8/upstream/3.1.8/src/mips/assembler-mips-inl.h +0 -215
- data/ext/v8/upstream/3.1.8/src/mips/assembler-mips.cc +0 -1219
- data/ext/v8/upstream/3.1.8/src/mips/assembler-mips.h +0 -667
- data/ext/v8/upstream/3.1.8/src/mips/builtins-mips.cc +0 -205
- data/ext/v8/upstream/3.1.8/src/mips/codegen-mips-inl.h +0 -70
- data/ext/v8/upstream/3.1.8/src/mips/codegen-mips.cc +0 -1437
- data/ext/v8/upstream/3.1.8/src/mips/codegen-mips.h +0 -431
- data/ext/v8/upstream/3.1.8/src/mips/constants-mips.cc +0 -328
- data/ext/v8/upstream/3.1.8/src/mips/constants-mips.h +0 -525
- data/ext/v8/upstream/3.1.8/src/mips/cpu-mips.cc +0 -73
- data/ext/v8/upstream/3.1.8/src/mips/debug-mips.cc +0 -127
- data/ext/v8/upstream/3.1.8/src/mips/disasm-mips.cc +0 -787
- data/ext/v8/upstream/3.1.8/src/mips/fast-codegen-mips.cc +0 -77
- data/ext/v8/upstream/3.1.8/src/mips/frames-mips.cc +0 -96
- data/ext/v8/upstream/3.1.8/src/mips/frames-mips.h +0 -164
- data/ext/v8/upstream/3.1.8/src/mips/full-codegen-mips.cc +0 -277
- data/ext/v8/upstream/3.1.8/src/mips/ic-mips.cc +0 -208
- data/ext/v8/upstream/3.1.8/src/mips/jump-target-mips.cc +0 -175
- data/ext/v8/upstream/3.1.8/src/mips/macro-assembler-mips.cc +0 -1326
- data/ext/v8/upstream/3.1.8/src/mips/macro-assembler-mips.h +0 -461
- data/ext/v8/upstream/3.1.8/src/mips/register-allocator-mips-inl.h +0 -137
- data/ext/v8/upstream/3.1.8/src/mips/register-allocator-mips.h +0 -46
- data/ext/v8/upstream/3.1.8/src/mips/simulator-mips.cc +0 -1650
- data/ext/v8/upstream/3.1.8/src/mips/simulator-mips.h +0 -311
- data/ext/v8/upstream/3.1.8/src/mips/stub-cache-mips.cc +0 -418
- data/ext/v8/upstream/3.1.8/src/mips/virtual-frame-mips.cc +0 -319
- data/ext/v8/upstream/3.1.8/src/mips/virtual-frame-mips.h +0 -548
- data/ext/v8/upstream/3.1.8/src/mirror-debugger.js +0 -2380
- data/ext/v8/upstream/3.1.8/src/mksnapshot.cc +0 -256
- data/ext/v8/upstream/3.1.8/src/objects-debug.cc +0 -722
- data/ext/v8/upstream/3.1.8/src/objects-inl.h +0 -3946
- data/ext/v8/upstream/3.1.8/src/objects-printer.cc +0 -801
- data/ext/v8/upstream/3.1.8/src/objects-visiting.cc +0 -142
- data/ext/v8/upstream/3.1.8/src/objects-visiting.h +0 -401
- data/ext/v8/upstream/3.1.8/src/objects.cc +0 -10044
- data/ext/v8/upstream/3.1.8/src/objects.h +0 -6571
- data/ext/v8/upstream/3.1.8/src/parser.cc +0 -5165
- data/ext/v8/upstream/3.1.8/src/parser.h +0 -802
- data/ext/v8/upstream/3.1.8/src/platform-cygwin.cc +0 -745
- data/ext/v8/upstream/3.1.8/src/platform-freebsd.cc +0 -702
- data/ext/v8/upstream/3.1.8/src/platform-linux.cc +0 -981
- data/ext/v8/upstream/3.1.8/src/platform-macos.cc +0 -732
- data/ext/v8/upstream/3.1.8/src/platform-nullos.cc +0 -498
- data/ext/v8/upstream/3.1.8/src/platform-openbsd.cc +0 -657
- data/ext/v8/upstream/3.1.8/src/platform-posix.cc +0 -399
- data/ext/v8/upstream/3.1.8/src/platform-solaris.cc +0 -714
- data/ext/v8/upstream/3.1.8/src/platform-win32.cc +0 -1974
- data/ext/v8/upstream/3.1.8/src/platform.h +0 -636
- data/ext/v8/upstream/3.1.8/src/preparse-data.cc +0 -183
- data/ext/v8/upstream/3.1.8/src/preparser-api.cc +0 -213
- data/ext/v8/upstream/3.1.8/src/preparser.cc +0 -1205
- data/ext/v8/upstream/3.1.8/src/prettyprinter.cc +0 -1539
- data/ext/v8/upstream/3.1.8/src/prettyprinter.h +0 -223
- data/ext/v8/upstream/3.1.8/src/profile-generator.cc +0 -2899
- data/ext/v8/upstream/3.1.8/src/profile-generator.h +0 -1151
- data/ext/v8/upstream/3.1.8/src/property.cc +0 -96
- data/ext/v8/upstream/3.1.8/src/property.h +0 -337
- data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler-irregexp.cc +0 -470
- data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler.cc +0 -257
- data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler.h +0 -231
- data/ext/v8/upstream/3.1.8/src/regexp-stack.cc +0 -103
- data/ext/v8/upstream/3.1.8/src/regexp-stack.h +0 -123
- data/ext/v8/upstream/3.1.8/src/regexp.js +0 -483
- data/ext/v8/upstream/3.1.8/src/register-allocator-inl.h +0 -141
- data/ext/v8/upstream/3.1.8/src/register-allocator.cc +0 -104
- data/ext/v8/upstream/3.1.8/src/register-allocator.h +0 -320
- data/ext/v8/upstream/3.1.8/src/rewriter.cc +0 -1023
- data/ext/v8/upstream/3.1.8/src/runtime-profiler.cc +0 -443
- data/ext/v8/upstream/3.1.8/src/runtime-profiler.h +0 -77
- data/ext/v8/upstream/3.1.8/src/runtime.cc +0 -11592
- data/ext/v8/upstream/3.1.8/src/runtime.h +0 -582
- data/ext/v8/upstream/3.1.8/src/safepoint-table.cc +0 -253
- data/ext/v8/upstream/3.1.8/src/safepoint-table.h +0 -263
- data/ext/v8/upstream/3.1.8/src/scanner-base.cc +0 -971
- data/ext/v8/upstream/3.1.8/src/scanner-base.h +0 -653
- data/ext/v8/upstream/3.1.8/src/scanner.cc +0 -586
- data/ext/v8/upstream/3.1.8/src/scanner.h +0 -194
- data/ext/v8/upstream/3.1.8/src/scopeinfo.cc +0 -636
- data/ext/v8/upstream/3.1.8/src/scopeinfo.h +0 -238
- data/ext/v8/upstream/3.1.8/src/scopes.cc +0 -1063
- data/ext/v8/upstream/3.1.8/src/scopes.h +0 -494
- data/ext/v8/upstream/3.1.8/src/serialize.cc +0 -1535
- data/ext/v8/upstream/3.1.8/src/serialize.h +0 -584
- data/ext/v8/upstream/3.1.8/src/snapshot-common.cc +0 -82
- data/ext/v8/upstream/3.1.8/src/snapshot.h +0 -71
- data/ext/v8/upstream/3.1.8/src/spaces-inl.h +0 -524
- data/ext/v8/upstream/3.1.8/src/spaces.cc +0 -3254
- data/ext/v8/upstream/3.1.8/src/spaces.h +0 -2362
- data/ext/v8/upstream/3.1.8/src/string-search.cc +0 -40
- data/ext/v8/upstream/3.1.8/src/string-search.h +0 -567
- data/ext/v8/upstream/3.1.8/src/string-stream.cc +0 -584
- data/ext/v8/upstream/3.1.8/src/string.js +0 -915
- data/ext/v8/upstream/3.1.8/src/stub-cache.cc +0 -1878
- data/ext/v8/upstream/3.1.8/src/stub-cache.h +0 -849
- data/ext/v8/upstream/3.1.8/src/token.cc +0 -63
- data/ext/v8/upstream/3.1.8/src/token.h +0 -288
- data/ext/v8/upstream/3.1.8/src/top.cc +0 -1152
- data/ext/v8/upstream/3.1.8/src/top.h +0 -608
- data/ext/v8/upstream/3.1.8/src/type-info.cc +0 -406
- data/ext/v8/upstream/3.1.8/src/type-info.h +0 -283
- data/ext/v8/upstream/3.1.8/src/unicode.cc +0 -1624
- data/ext/v8/upstream/3.1.8/src/unicode.h +0 -280
- data/ext/v8/upstream/3.1.8/src/utils.h +0 -793
- data/ext/v8/upstream/3.1.8/src/v8-counters.cc +0 -55
- data/ext/v8/upstream/3.1.8/src/v8-counters.h +0 -290
- data/ext/v8/upstream/3.1.8/src/v8.cc +0 -270
- data/ext/v8/upstream/3.1.8/src/v8.h +0 -127
- data/ext/v8/upstream/3.1.8/src/v8globals.h +0 -480
- data/ext/v8/upstream/3.1.8/src/v8natives.js +0 -1252
- data/ext/v8/upstream/3.1.8/src/v8threads.cc +0 -440
- data/ext/v8/upstream/3.1.8/src/v8threads.h +0 -157
- data/ext/v8/upstream/3.1.8/src/v8utils.h +0 -354
- data/ext/v8/upstream/3.1.8/src/variables.h +0 -212
- data/ext/v8/upstream/3.1.8/src/version.cc +0 -95
- data/ext/v8/upstream/3.1.8/src/version.h +0 -64
- data/ext/v8/upstream/3.1.8/src/virtual-frame-light-inl.h +0 -170
- data/ext/v8/upstream/3.1.8/src/vm-state-inl.h +0 -134
- data/ext/v8/upstream/3.1.8/src/vm-state.h +0 -68
- data/ext/v8/upstream/3.1.8/src/win32-headers.h +0 -95
- data/ext/v8/upstream/3.1.8/src/x64/assembler-x64-inl.h +0 -455
- data/ext/v8/upstream/3.1.8/src/x64/assembler-x64.cc +0 -3162
- data/ext/v8/upstream/3.1.8/src/x64/assembler-x64.h +0 -1584
- data/ext/v8/upstream/3.1.8/src/x64/builtins-x64.cc +0 -1492
- data/ext/v8/upstream/3.1.8/src/x64/code-stubs-x64.cc +0 -5150
- data/ext/v8/upstream/3.1.8/src/x64/code-stubs-x64.h +0 -519
- data/ext/v8/upstream/3.1.8/src/x64/codegen-x64.cc +0 -8835
- data/ext/v8/upstream/3.1.8/src/x64/codegen-x64.h +0 -750
- data/ext/v8/upstream/3.1.8/src/x64/cpu-x64.cc +0 -86
- data/ext/v8/upstream/3.1.8/src/x64/debug-x64.cc +0 -316
- data/ext/v8/upstream/3.1.8/src/x64/deoptimizer-x64.cc +0 -781
- data/ext/v8/upstream/3.1.8/src/x64/disasm-x64.cc +0 -1737
- data/ext/v8/upstream/3.1.8/src/x64/frames-x64.h +0 -130
- data/ext/v8/upstream/3.1.8/src/x64/full-codegen-x64.cc +0 -3984
- data/ext/v8/upstream/3.1.8/src/x64/ic-x64.cc +0 -1761
- data/ext/v8/upstream/3.1.8/src/x64/lithium-codegen-x64.cc +0 -3639
- data/ext/v8/upstream/3.1.8/src/x64/lithium-codegen-x64.h +0 -305
- data/ext/v8/upstream/3.1.8/src/x64/lithium-x64.cc +0 -2044
- data/ext/v8/upstream/3.1.8/src/x64/lithium-x64.h +0 -2052
- data/ext/v8/upstream/3.1.8/src/x64/macro-assembler-x64.cc +0 -2660
- data/ext/v8/upstream/3.1.8/src/x64/macro-assembler-x64.h +0 -1852
- data/ext/v8/upstream/3.1.8/src/x64/regexp-macro-assembler-x64.cc +0 -1382
- data/ext/v8/upstream/3.1.8/src/x64/regexp-macro-assembler-x64.h +0 -278
- data/ext/v8/upstream/3.1.8/src/x64/register-allocator-x64-inl.h +0 -87
- data/ext/v8/upstream/3.1.8/src/x64/register-allocator-x64.cc +0 -91
- data/ext/v8/upstream/3.1.8/src/x64/simulator-x64.h +0 -71
- data/ext/v8/upstream/3.1.8/src/x64/stub-cache-x64.cc +0 -3509
- data/ext/v8/upstream/3.1.8/src/x64/virtual-frame-x64.cc +0 -1292
- data/ext/v8/upstream/3.1.8/src/x64/virtual-frame-x64.h +0 -593
- data/ext/v8/upstream/3.1.8/src/zone-inl.h +0 -83
- data/ext/v8/upstream/3.1.8/src/zone.cc +0 -195
- data/ext/v8/upstream/3.1.8/src/zone.h +0 -233
- data/ext/v8/upstream/3.1.8/tools/gyp/v8.gyp +0 -869
- data/ext/v8/upstream/3.1.8/tools/linux-tick-processor +0 -33
- data/ext/v8/upstream/3.1.8/tools/tickprocessor.js +0 -863
- data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base.vcproj +0 -1296
- data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base_arm.vcproj +0 -1234
- data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base_x64.vcproj +0 -1296
- data/ext/v8/upstream/3.1.8/tools/visual_studio/x64.vsprops +0 -17
- data/spec/ext/mem_spec.rb +0 -42
@@ -0,0 +1,287 @@
|
|
1
|
+
// Copyright 2008 the V8 project authors. All rights reserved.
|
2
|
+
// Redistribution and use in source and binary forms, with or without
|
3
|
+
// modification, are permitted provided that the following conditions are
|
4
|
+
// met:
|
5
|
+
//
|
6
|
+
// * Redistributions of source code must retain the above copyright
|
7
|
+
// notice, this list of conditions and the following disclaimer.
|
8
|
+
// * Redistributions in binary form must reproduce the above
|
9
|
+
// copyright notice, this list of conditions and the following
|
10
|
+
// disclaimer in the documentation and/or other materials provided
|
11
|
+
// with the distribution.
|
12
|
+
// * Neither the name of Google Inc. nor the names of its
|
13
|
+
// contributors may be used to endorse or promote products derived
|
14
|
+
// from this software without specific prior written permission.
|
15
|
+
//
|
16
|
+
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
17
|
+
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
18
|
+
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
19
|
+
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
20
|
+
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
21
|
+
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
22
|
+
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
23
|
+
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
24
|
+
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
25
|
+
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
26
|
+
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
27
|
+
|
28
|
+
#ifndef V8_COMPILATION_CACHE_H_
|
29
|
+
#define V8_COMPILATION_CACHE_H_
|
30
|
+
|
31
|
+
namespace v8 {
|
32
|
+
namespace internal {
|
33
|
+
|
34
|
+
class HashMap;
|
35
|
+
|
36
|
+
// The compilation cache consists of several generational sub-caches which uses
|
37
|
+
// this class as a base class. A sub-cache contains a compilation cache tables
|
38
|
+
// for each generation of the sub-cache. Since the same source code string has
|
39
|
+
// different compiled code for scripts and evals, we use separate sub-caches
|
40
|
+
// for different compilation modes, to avoid retrieving the wrong result.
|
41
|
+
class CompilationSubCache {
|
42
|
+
public:
|
43
|
+
CompilationSubCache(Isolate* isolate, int generations)
|
44
|
+
: isolate_(isolate),
|
45
|
+
generations_(generations) {
|
46
|
+
tables_ = NewArray<Object*>(generations);
|
47
|
+
}
|
48
|
+
|
49
|
+
~CompilationSubCache() { DeleteArray(tables_); }
|
50
|
+
|
51
|
+
// Index for the first generation in the cache.
|
52
|
+
static const int kFirstGeneration = 0;
|
53
|
+
|
54
|
+
// Get the compilation cache tables for a specific generation.
|
55
|
+
Handle<CompilationCacheTable> GetTable(int generation);
|
56
|
+
|
57
|
+
// Accessors for first generation.
|
58
|
+
Handle<CompilationCacheTable> GetFirstTable() {
|
59
|
+
return GetTable(kFirstGeneration);
|
60
|
+
}
|
61
|
+
void SetFirstTable(Handle<CompilationCacheTable> value) {
|
62
|
+
ASSERT(kFirstGeneration < generations_);
|
63
|
+
tables_[kFirstGeneration] = *value;
|
64
|
+
}
|
65
|
+
|
66
|
+
// Age the sub-cache by evicting the oldest generation and creating a new
|
67
|
+
// young generation.
|
68
|
+
void Age();
|
69
|
+
|
70
|
+
// GC support.
|
71
|
+
void Iterate(ObjectVisitor* v);
|
72
|
+
void IterateFunctions(ObjectVisitor* v);
|
73
|
+
|
74
|
+
// Clear this sub-cache evicting all its content.
|
75
|
+
void Clear();
|
76
|
+
|
77
|
+
// Remove given shared function info from sub-cache.
|
78
|
+
void Remove(Handle<SharedFunctionInfo> function_info);
|
79
|
+
|
80
|
+
// Number of generations in this sub-cache.
|
81
|
+
inline int generations() { return generations_; }
|
82
|
+
|
83
|
+
protected:
|
84
|
+
Isolate* isolate() { return isolate_; }
|
85
|
+
|
86
|
+
private:
|
87
|
+
Isolate* isolate_;
|
88
|
+
int generations_; // Number of generations.
|
89
|
+
Object** tables_; // Compilation cache tables - one for each generation.
|
90
|
+
|
91
|
+
DISALLOW_IMPLICIT_CONSTRUCTORS(CompilationSubCache);
|
92
|
+
};
|
93
|
+
|
94
|
+
|
95
|
+
// Sub-cache for scripts.
|
96
|
+
class CompilationCacheScript : public CompilationSubCache {
|
97
|
+
public:
|
98
|
+
CompilationCacheScript(Isolate* isolate, int generations);
|
99
|
+
|
100
|
+
Handle<SharedFunctionInfo> Lookup(Handle<String> source,
|
101
|
+
Handle<Object> name,
|
102
|
+
int line_offset,
|
103
|
+
int column_offset);
|
104
|
+
void Put(Handle<String> source, Handle<SharedFunctionInfo> function_info);
|
105
|
+
|
106
|
+
private:
|
107
|
+
MUST_USE_RESULT MaybeObject* TryTablePut(
|
108
|
+
Handle<String> source, Handle<SharedFunctionInfo> function_info);
|
109
|
+
|
110
|
+
// Note: Returns a new hash table if operation results in expansion.
|
111
|
+
Handle<CompilationCacheTable> TablePut(
|
112
|
+
Handle<String> source, Handle<SharedFunctionInfo> function_info);
|
113
|
+
|
114
|
+
bool HasOrigin(Handle<SharedFunctionInfo> function_info,
|
115
|
+
Handle<Object> name,
|
116
|
+
int line_offset,
|
117
|
+
int column_offset);
|
118
|
+
|
119
|
+
void* script_histogram_;
|
120
|
+
bool script_histogram_initialized_;
|
121
|
+
|
122
|
+
DISALLOW_IMPLICIT_CONSTRUCTORS(CompilationCacheScript);
|
123
|
+
};
|
124
|
+
|
125
|
+
|
126
|
+
// Sub-cache for eval scripts.
|
127
|
+
class CompilationCacheEval: public CompilationSubCache {
|
128
|
+
public:
|
129
|
+
CompilationCacheEval(Isolate* isolate, int generations)
|
130
|
+
: CompilationSubCache(isolate, generations) { }
|
131
|
+
|
132
|
+
Handle<SharedFunctionInfo> Lookup(Handle<String> source,
|
133
|
+
Handle<Context> context,
|
134
|
+
StrictModeFlag strict_mode);
|
135
|
+
|
136
|
+
void Put(Handle<String> source,
|
137
|
+
Handle<Context> context,
|
138
|
+
Handle<SharedFunctionInfo> function_info);
|
139
|
+
|
140
|
+
private:
|
141
|
+
MUST_USE_RESULT MaybeObject* TryTablePut(
|
142
|
+
Handle<String> source,
|
143
|
+
Handle<Context> context,
|
144
|
+
Handle<SharedFunctionInfo> function_info);
|
145
|
+
|
146
|
+
// Note: Returns a new hash table if operation results in expansion.
|
147
|
+
Handle<CompilationCacheTable> TablePut(
|
148
|
+
Handle<String> source,
|
149
|
+
Handle<Context> context,
|
150
|
+
Handle<SharedFunctionInfo> function_info);
|
151
|
+
|
152
|
+
DISALLOW_IMPLICIT_CONSTRUCTORS(CompilationCacheEval);
|
153
|
+
};
|
154
|
+
|
155
|
+
|
156
|
+
// Sub-cache for regular expressions.
|
157
|
+
class CompilationCacheRegExp: public CompilationSubCache {
|
158
|
+
public:
|
159
|
+
CompilationCacheRegExp(Isolate* isolate, int generations)
|
160
|
+
: CompilationSubCache(isolate, generations) { }
|
161
|
+
|
162
|
+
Handle<FixedArray> Lookup(Handle<String> source, JSRegExp::Flags flags);
|
163
|
+
|
164
|
+
void Put(Handle<String> source,
|
165
|
+
JSRegExp::Flags flags,
|
166
|
+
Handle<FixedArray> data);
|
167
|
+
private:
|
168
|
+
MUST_USE_RESULT MaybeObject* TryTablePut(Handle<String> source,
|
169
|
+
JSRegExp::Flags flags,
|
170
|
+
Handle<FixedArray> data);
|
171
|
+
|
172
|
+
// Note: Returns a new hash table if operation results in expansion.
|
173
|
+
Handle<CompilationCacheTable> TablePut(Handle<String> source,
|
174
|
+
JSRegExp::Flags flags,
|
175
|
+
Handle<FixedArray> data);
|
176
|
+
|
177
|
+
DISALLOW_IMPLICIT_CONSTRUCTORS(CompilationCacheRegExp);
|
178
|
+
};
|
179
|
+
|
180
|
+
|
181
|
+
// The compilation cache keeps shared function infos for compiled
|
182
|
+
// scripts and evals. The shared function infos are looked up using
|
183
|
+
// the source string as the key. For regular expressions the
|
184
|
+
// compilation data is cached.
|
185
|
+
class CompilationCache {
|
186
|
+
public:
|
187
|
+
// Finds the script shared function info for a source
|
188
|
+
// string. Returns an empty handle if the cache doesn't contain a
|
189
|
+
// script for the given source string with the right origin.
|
190
|
+
Handle<SharedFunctionInfo> LookupScript(Handle<String> source,
|
191
|
+
Handle<Object> name,
|
192
|
+
int line_offset,
|
193
|
+
int column_offset);
|
194
|
+
|
195
|
+
// Finds the shared function info for a source string for eval in a
|
196
|
+
// given context. Returns an empty handle if the cache doesn't
|
197
|
+
// contain a script for the given source string.
|
198
|
+
Handle<SharedFunctionInfo> LookupEval(Handle<String> source,
|
199
|
+
Handle<Context> context,
|
200
|
+
bool is_global,
|
201
|
+
StrictModeFlag strict_mode);
|
202
|
+
|
203
|
+
// Returns the regexp data associated with the given regexp if it
|
204
|
+
// is in cache, otherwise an empty handle.
|
205
|
+
Handle<FixedArray> LookupRegExp(Handle<String> source,
|
206
|
+
JSRegExp::Flags flags);
|
207
|
+
|
208
|
+
// Associate the (source, kind) pair to the shared function
|
209
|
+
// info. This may overwrite an existing mapping.
|
210
|
+
void PutScript(Handle<String> source,
|
211
|
+
Handle<SharedFunctionInfo> function_info);
|
212
|
+
|
213
|
+
// Associate the (source, context->closure()->shared(), kind) triple
|
214
|
+
// with the shared function info. This may overwrite an existing mapping.
|
215
|
+
void PutEval(Handle<String> source,
|
216
|
+
Handle<Context> context,
|
217
|
+
bool is_global,
|
218
|
+
Handle<SharedFunctionInfo> function_info);
|
219
|
+
|
220
|
+
// Associate the (source, flags) pair to the given regexp data.
|
221
|
+
// This may overwrite an existing mapping.
|
222
|
+
void PutRegExp(Handle<String> source,
|
223
|
+
JSRegExp::Flags flags,
|
224
|
+
Handle<FixedArray> data);
|
225
|
+
|
226
|
+
// Support for eager optimization tracking.
|
227
|
+
bool ShouldOptimizeEagerly(Handle<JSFunction> function);
|
228
|
+
void MarkForEagerOptimizing(Handle<JSFunction> function);
|
229
|
+
void MarkForLazyOptimizing(Handle<JSFunction> function);
|
230
|
+
|
231
|
+
// Reset the eager optimization tracking data.
|
232
|
+
void ResetEagerOptimizingData();
|
233
|
+
|
234
|
+
// Clear the cache - also used to initialize the cache at startup.
|
235
|
+
void Clear();
|
236
|
+
|
237
|
+
// Remove given shared function info from all caches.
|
238
|
+
void Remove(Handle<SharedFunctionInfo> function_info);
|
239
|
+
|
240
|
+
// GC support.
|
241
|
+
void Iterate(ObjectVisitor* v);
|
242
|
+
void IterateFunctions(ObjectVisitor* v);
|
243
|
+
|
244
|
+
// Notify the cache that a mark-sweep garbage collection is about to
|
245
|
+
// take place. This is used to retire entries from the cache to
|
246
|
+
// avoid keeping them alive too long without using them.
|
247
|
+
void MarkCompactPrologue();
|
248
|
+
|
249
|
+
// Enable/disable compilation cache. Used by debugger to disable compilation
|
250
|
+
// cache during debugging to make sure new scripts are always compiled.
|
251
|
+
void Enable();
|
252
|
+
void Disable();
|
253
|
+
private:
|
254
|
+
explicit CompilationCache(Isolate* isolate);
|
255
|
+
~CompilationCache();
|
256
|
+
|
257
|
+
HashMap* EagerOptimizingSet();
|
258
|
+
|
259
|
+
// The number of sub caches covering the different types to cache.
|
260
|
+
static const int kSubCacheCount = 4;
|
261
|
+
|
262
|
+
bool IsEnabled() { return FLAG_compilation_cache && enabled_; }
|
263
|
+
|
264
|
+
Isolate* isolate() { return isolate_; }
|
265
|
+
|
266
|
+
Isolate* isolate_;
|
267
|
+
|
268
|
+
CompilationCacheScript script_;
|
269
|
+
CompilationCacheEval eval_global_;
|
270
|
+
CompilationCacheEval eval_contextual_;
|
271
|
+
CompilationCacheRegExp reg_exp_;
|
272
|
+
CompilationSubCache* subcaches_[kSubCacheCount];
|
273
|
+
|
274
|
+
// Current enable state of the compilation cache.
|
275
|
+
bool enabled_;
|
276
|
+
|
277
|
+
HashMap* eager_optimizing_set_;
|
278
|
+
|
279
|
+
friend class Isolate;
|
280
|
+
|
281
|
+
DISALLOW_COPY_AND_ASSIGN(CompilationCache);
|
282
|
+
};
|
283
|
+
|
284
|
+
|
285
|
+
} } // namespace v8::internal
|
286
|
+
|
287
|
+
#endif // V8_COMPILATION_CACHE_H_
|
@@ -0,0 +1,792 @@
|
|
1
|
+
// Copyright 2011 the V8 project authors. All rights reserved.
|
2
|
+
// Redistribution and use in source and binary forms, with or without
|
3
|
+
// modification, are permitted provided that the following conditions are
|
4
|
+
// met:
|
5
|
+
//
|
6
|
+
// * Redistributions of source code must retain the above copyright
|
7
|
+
// notice, this list of conditions and the following disclaimer.
|
8
|
+
// * Redistributions in binary form must reproduce the above
|
9
|
+
// copyright notice, this list of conditions and the following
|
10
|
+
// disclaimer in the documentation and/or other materials provided
|
11
|
+
// with the distribution.
|
12
|
+
// * Neither the name of Google Inc. nor the names of its
|
13
|
+
// contributors may be used to endorse or promote products derived
|
14
|
+
// from this software without specific prior written permission.
|
15
|
+
//
|
16
|
+
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
17
|
+
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
18
|
+
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
19
|
+
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
20
|
+
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
21
|
+
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
22
|
+
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
23
|
+
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
24
|
+
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
25
|
+
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
26
|
+
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
27
|
+
|
28
|
+
#include "v8.h"
|
29
|
+
|
30
|
+
#include "compiler.h"
|
31
|
+
|
32
|
+
#include "bootstrapper.h"
|
33
|
+
#include "codegen-inl.h"
|
34
|
+
#include "compilation-cache.h"
|
35
|
+
#include "data-flow.h"
|
36
|
+
#include "debug.h"
|
37
|
+
#include "full-codegen.h"
|
38
|
+
#include "gdb-jit.h"
|
39
|
+
#include "hydrogen.h"
|
40
|
+
#include "lithium.h"
|
41
|
+
#include "liveedit.h"
|
42
|
+
#include "parser.h"
|
43
|
+
#include "rewriter.h"
|
44
|
+
#include "runtime-profiler.h"
|
45
|
+
#include "scopeinfo.h"
|
46
|
+
#include "scopes.h"
|
47
|
+
#include "vm-state-inl.h"
|
48
|
+
|
49
|
+
namespace v8 {
|
50
|
+
namespace internal {
|
51
|
+
|
52
|
+
|
53
|
+
CompilationInfo::CompilationInfo(Handle<Script> script)
|
54
|
+
: isolate_(script->GetIsolate()),
|
55
|
+
flags_(0),
|
56
|
+
function_(NULL),
|
57
|
+
scope_(NULL),
|
58
|
+
script_(script),
|
59
|
+
extension_(NULL),
|
60
|
+
pre_parse_data_(NULL),
|
61
|
+
supports_deoptimization_(false),
|
62
|
+
osr_ast_id_(AstNode::kNoNumber) {
|
63
|
+
Initialize(NONOPT);
|
64
|
+
}
|
65
|
+
|
66
|
+
|
67
|
+
CompilationInfo::CompilationInfo(Handle<SharedFunctionInfo> shared_info)
|
68
|
+
: isolate_(shared_info->GetIsolate()),
|
69
|
+
flags_(IsLazy::encode(true)),
|
70
|
+
function_(NULL),
|
71
|
+
scope_(NULL),
|
72
|
+
shared_info_(shared_info),
|
73
|
+
script_(Handle<Script>(Script::cast(shared_info->script()))),
|
74
|
+
extension_(NULL),
|
75
|
+
pre_parse_data_(NULL),
|
76
|
+
supports_deoptimization_(false),
|
77
|
+
osr_ast_id_(AstNode::kNoNumber) {
|
78
|
+
Initialize(BASE);
|
79
|
+
}
|
80
|
+
|
81
|
+
|
82
|
+
CompilationInfo::CompilationInfo(Handle<JSFunction> closure)
|
83
|
+
: isolate_(closure->GetIsolate()),
|
84
|
+
flags_(IsLazy::encode(true)),
|
85
|
+
function_(NULL),
|
86
|
+
scope_(NULL),
|
87
|
+
closure_(closure),
|
88
|
+
shared_info_(Handle<SharedFunctionInfo>(closure->shared())),
|
89
|
+
script_(Handle<Script>(Script::cast(shared_info_->script()))),
|
90
|
+
extension_(NULL),
|
91
|
+
pre_parse_data_(NULL),
|
92
|
+
supports_deoptimization_(false),
|
93
|
+
osr_ast_id_(AstNode::kNoNumber) {
|
94
|
+
Initialize(BASE);
|
95
|
+
}
|
96
|
+
|
97
|
+
|
98
|
+
void CompilationInfo::DisableOptimization() {
|
99
|
+
if (FLAG_optimize_closures) {
|
100
|
+
// If we allow closures optimizations and it's an optimizable closure
|
101
|
+
// mark it correspondingly.
|
102
|
+
bool is_closure = closure_.is_null() && !scope_->HasTrivialOuterContext();
|
103
|
+
if (is_closure) {
|
104
|
+
bool is_optimizable_closure =
|
105
|
+
!scope_->outer_scope_calls_eval() && !scope_->inside_with();
|
106
|
+
if (is_optimizable_closure) {
|
107
|
+
SetMode(BASE);
|
108
|
+
return;
|
109
|
+
}
|
110
|
+
}
|
111
|
+
}
|
112
|
+
|
113
|
+
SetMode(NONOPT);
|
114
|
+
}
|
115
|
+
|
116
|
+
|
117
|
+
// Determine whether to use the full compiler for all code. If the flag
|
118
|
+
// --always-full-compiler is specified this is the case. For the virtual frame
|
119
|
+
// based compiler the full compiler is also used if a debugger is connected, as
|
120
|
+
// the code from the full compiler supports mode precise break points. For the
|
121
|
+
// crankshaft adaptive compiler debugging the optimized code is not possible at
|
122
|
+
// all. However crankshaft support recompilation of functions, so in this case
|
123
|
+
// the full compiler need not be be used if a debugger is attached, but only if
|
124
|
+
// break points has actually been set.
|
125
|
+
static bool AlwaysFullCompiler() {
|
126
|
+
#ifdef ENABLE_DEBUGGER_SUPPORT
|
127
|
+
Isolate* isolate = Isolate::Current();
|
128
|
+
if (V8::UseCrankshaft()) {
|
129
|
+
return FLAG_always_full_compiler || isolate->debug()->has_break_points();
|
130
|
+
} else {
|
131
|
+
return FLAG_always_full_compiler || isolate->debugger()->IsDebuggerActive();
|
132
|
+
}
|
133
|
+
#else
|
134
|
+
return FLAG_always_full_compiler;
|
135
|
+
#endif
|
136
|
+
}
|
137
|
+
|
138
|
+
|
139
|
+
static void FinishOptimization(Handle<JSFunction> function, int64_t start) {
|
140
|
+
int opt_count = function->shared()->opt_count();
|
141
|
+
function->shared()->set_opt_count(opt_count + 1);
|
142
|
+
double ms = static_cast<double>(OS::Ticks() - start) / 1000;
|
143
|
+
if (FLAG_trace_opt) {
|
144
|
+
PrintF("[optimizing: ");
|
145
|
+
function->PrintName();
|
146
|
+
PrintF(" / %" V8PRIxPTR, reinterpret_cast<intptr_t>(*function));
|
147
|
+
PrintF(" - took %0.3f ms]\n", ms);
|
148
|
+
}
|
149
|
+
if (FLAG_trace_opt_stats) {
|
150
|
+
static double compilation_time = 0.0;
|
151
|
+
static int compiled_functions = 0;
|
152
|
+
static int code_size = 0;
|
153
|
+
|
154
|
+
compilation_time += ms;
|
155
|
+
compiled_functions++;
|
156
|
+
code_size += function->shared()->SourceSize();
|
157
|
+
PrintF("Compiled: %d functions with %d byte source size in %fms.\n",
|
158
|
+
compiled_functions,
|
159
|
+
code_size,
|
160
|
+
compilation_time);
|
161
|
+
}
|
162
|
+
}
|
163
|
+
|
164
|
+
|
165
|
+
static void AbortAndDisable(CompilationInfo* info) {
|
166
|
+
// Disable optimization for the shared function info and mark the
|
167
|
+
// code as non-optimizable. The marker on the shared function info
|
168
|
+
// is there because we flush non-optimized code thereby loosing the
|
169
|
+
// non-optimizable information for the code. When the code is
|
170
|
+
// regenerated and set on the shared function info it is marked as
|
171
|
+
// non-optimizable if optimization is disabled for the shared
|
172
|
+
// function info.
|
173
|
+
Handle<SharedFunctionInfo> shared = info->shared_info();
|
174
|
+
shared->set_optimization_disabled(true);
|
175
|
+
Handle<Code> code = Handle<Code>(shared->code());
|
176
|
+
ASSERT(code->kind() == Code::FUNCTION);
|
177
|
+
code->set_optimizable(false);
|
178
|
+
info->SetCode(code);
|
179
|
+
Isolate* isolate = code->GetIsolate();
|
180
|
+
isolate->compilation_cache()->MarkForLazyOptimizing(info->closure());
|
181
|
+
if (FLAG_trace_opt) {
|
182
|
+
PrintF("[disabled optimization for: ");
|
183
|
+
info->closure()->PrintName();
|
184
|
+
PrintF(" / %" V8PRIxPTR "]\n",
|
185
|
+
reinterpret_cast<intptr_t>(*info->closure()));
|
186
|
+
}
|
187
|
+
}
|
188
|
+
|
189
|
+
|
190
|
+
static bool MakeCrankshaftCode(CompilationInfo* info) {
|
191
|
+
// Test if we can optimize this function when asked to. We can only
|
192
|
+
// do this after the scopes are computed.
|
193
|
+
if (!info->AllowOptimize()) info->DisableOptimization();
|
194
|
+
|
195
|
+
// In case we are not optimizing simply return the code from
|
196
|
+
// the full code generator.
|
197
|
+
if (!info->IsOptimizing()) {
|
198
|
+
return FullCodeGenerator::MakeCode(info);
|
199
|
+
}
|
200
|
+
|
201
|
+
// We should never arrive here if there is not code object on the
|
202
|
+
// shared function object.
|
203
|
+
Handle<Code> code(info->shared_info()->code());
|
204
|
+
ASSERT(code->kind() == Code::FUNCTION);
|
205
|
+
|
206
|
+
// We should never arrive here if optimization has been disabled on the
|
207
|
+
// shared function info.
|
208
|
+
ASSERT(!info->shared_info()->optimization_disabled());
|
209
|
+
|
210
|
+
// Fall back to using the full code generator if it's not possible
|
211
|
+
// to use the Hydrogen-based optimizing compiler. We already have
|
212
|
+
// generated code for this from the shared function object.
|
213
|
+
if (AlwaysFullCompiler() || !FLAG_use_hydrogen) {
|
214
|
+
info->SetCode(code);
|
215
|
+
return true;
|
216
|
+
}
|
217
|
+
|
218
|
+
// Limit the number of times we re-compile a functions with
|
219
|
+
// the optimizing compiler.
|
220
|
+
const int kMaxOptCount =
|
221
|
+
FLAG_deopt_every_n_times == 0 ? Compiler::kDefaultMaxOptCount : 1000;
|
222
|
+
if (info->shared_info()->opt_count() > kMaxOptCount) {
|
223
|
+
AbortAndDisable(info);
|
224
|
+
// True indicates the compilation pipeline is still going, not
|
225
|
+
// necessarily that we optimized the code.
|
226
|
+
return true;
|
227
|
+
}
|
228
|
+
|
229
|
+
// Due to an encoding limit on LUnallocated operands in the Lithium
|
230
|
+
// language, we cannot optimize functions with too many formal parameters
|
231
|
+
// or perform on-stack replacement for function with too many
|
232
|
+
// stack-allocated local variables.
|
233
|
+
//
|
234
|
+
// The encoding is as a signed value, with parameters and receiver using
|
235
|
+
// the negative indices and locals the non-negative ones.
|
236
|
+
const int limit = LUnallocated::kMaxFixedIndices / 2;
|
237
|
+
Scope* scope = info->scope();
|
238
|
+
if ((scope->num_parameters() + 1) > limit ||
|
239
|
+
scope->num_stack_slots() > limit) {
|
240
|
+
AbortAndDisable(info);
|
241
|
+
// True indicates the compilation pipeline is still going, not
|
242
|
+
// necessarily that we optimized the code.
|
243
|
+
return true;
|
244
|
+
}
|
245
|
+
|
246
|
+
// Take --hydrogen-filter into account.
|
247
|
+
Vector<const char> filter = CStrVector(FLAG_hydrogen_filter);
|
248
|
+
Handle<String> name = info->function()->debug_name();
|
249
|
+
bool match = filter.is_empty() || name->IsEqualTo(filter);
|
250
|
+
if (!match) {
|
251
|
+
info->SetCode(code);
|
252
|
+
return true;
|
253
|
+
}
|
254
|
+
|
255
|
+
// Recompile the unoptimized version of the code if the current version
|
256
|
+
// doesn't have deoptimization support. Alternatively, we may decide to
|
257
|
+
// run the full code generator to get a baseline for the compile-time
|
258
|
+
// performance of the hydrogen-based compiler.
|
259
|
+
int64_t start = OS::Ticks();
|
260
|
+
bool should_recompile = !info->shared_info()->has_deoptimization_support();
|
261
|
+
if (should_recompile || FLAG_hydrogen_stats) {
|
262
|
+
HPhase phase(HPhase::kFullCodeGen);
|
263
|
+
CompilationInfo unoptimized(info->shared_info());
|
264
|
+
// Note that we use the same AST that we will use for generating the
|
265
|
+
// optimized code.
|
266
|
+
unoptimized.SetFunction(info->function());
|
267
|
+
unoptimized.SetScope(info->scope());
|
268
|
+
if (should_recompile) unoptimized.EnableDeoptimizationSupport();
|
269
|
+
bool succeeded = FullCodeGenerator::MakeCode(&unoptimized);
|
270
|
+
if (should_recompile) {
|
271
|
+
if (!succeeded) return false;
|
272
|
+
Handle<SharedFunctionInfo> shared = info->shared_info();
|
273
|
+
shared->EnableDeoptimizationSupport(*unoptimized.code());
|
274
|
+
// The existing unoptimized code was replaced with the new one.
|
275
|
+
Compiler::RecordFunctionCompilation(
|
276
|
+
Logger::LAZY_COMPILE_TAG, &unoptimized, shared);
|
277
|
+
}
|
278
|
+
}
|
279
|
+
|
280
|
+
// Check that the unoptimized, shared code is ready for
|
281
|
+
// optimizations. When using the always_opt flag we disregard the
|
282
|
+
// optimizable marker in the code object and optimize anyway. This
|
283
|
+
// is safe as long as the unoptimized code has deoptimization
|
284
|
+
// support.
|
285
|
+
ASSERT(FLAG_always_opt || code->optimizable());
|
286
|
+
ASSERT(info->shared_info()->has_deoptimization_support());
|
287
|
+
|
288
|
+
if (FLAG_trace_hydrogen) {
|
289
|
+
PrintF("-----------------------------------------------------------\n");
|
290
|
+
PrintF("Compiling method %s using hydrogen\n", *name->ToCString());
|
291
|
+
HTracer::Instance()->TraceCompilation(info->function());
|
292
|
+
}
|
293
|
+
|
294
|
+
Handle<Context> global_context(info->closure()->context()->global_context());
|
295
|
+
TypeFeedbackOracle oracle(code, global_context);
|
296
|
+
HGraphBuilder builder(info, &oracle);
|
297
|
+
HPhase phase(HPhase::kTotal);
|
298
|
+
HGraph* graph = builder.CreateGraph();
|
299
|
+
if (info->isolate()->has_pending_exception()) {
|
300
|
+
info->SetCode(Handle<Code>::null());
|
301
|
+
return false;
|
302
|
+
}
|
303
|
+
|
304
|
+
if (graph != NULL && FLAG_build_lithium) {
|
305
|
+
Handle<Code> optimized_code = graph->Compile(info);
|
306
|
+
if (!optimized_code.is_null()) {
|
307
|
+
info->SetCode(optimized_code);
|
308
|
+
FinishOptimization(info->closure(), start);
|
309
|
+
return true;
|
310
|
+
}
|
311
|
+
}
|
312
|
+
|
313
|
+
// Compilation with the Hydrogen compiler failed. Keep using the
|
314
|
+
// shared code but mark it as unoptimizable.
|
315
|
+
AbortAndDisable(info);
|
316
|
+
// True indicates the compilation pipeline is still going, not necessarily
|
317
|
+
// that we optimized the code.
|
318
|
+
return true;
|
319
|
+
}
|
320
|
+
|
321
|
+
|
322
|
+
static bool MakeCode(CompilationInfo* info) {
|
323
|
+
// Precondition: code has been parsed. Postcondition: the code field in
|
324
|
+
// the compilation info is set if compilation succeeded.
|
325
|
+
ASSERT(info->function() != NULL);
|
326
|
+
|
327
|
+
if (Rewriter::Rewrite(info) && Scope::Analyze(info)) {
|
328
|
+
if (V8::UseCrankshaft()) return MakeCrankshaftCode(info);
|
329
|
+
// If crankshaft is not supported fall back to full code generator
|
330
|
+
// for all compilation.
|
331
|
+
return FullCodeGenerator::MakeCode(info);
|
332
|
+
}
|
333
|
+
|
334
|
+
return false;
|
335
|
+
}
|
336
|
+
|
337
|
+
|
338
|
+
#ifdef ENABLE_DEBUGGER_SUPPORT
|
339
|
+
bool Compiler::MakeCodeForLiveEdit(CompilationInfo* info) {
|
340
|
+
// Precondition: code has been parsed. Postcondition: the code field in
|
341
|
+
// the compilation info is set if compilation succeeded.
|
342
|
+
bool succeeded = MakeCode(info);
|
343
|
+
if (!info->shared_info().is_null()) {
|
344
|
+
Handle<SerializedScopeInfo> scope_info =
|
345
|
+
SerializedScopeInfo::Create(info->scope());
|
346
|
+
info->shared_info()->set_scope_info(*scope_info);
|
347
|
+
}
|
348
|
+
return succeeded;
|
349
|
+
}
|
350
|
+
#endif
|
351
|
+
|
352
|
+
|
353
|
+
static Handle<SharedFunctionInfo> MakeFunctionInfo(CompilationInfo* info) {
|
354
|
+
CompilationZoneScope zone_scope(DELETE_ON_EXIT);
|
355
|
+
|
356
|
+
Isolate* isolate = info->isolate();
|
357
|
+
PostponeInterruptsScope postpone(isolate);
|
358
|
+
|
359
|
+
ASSERT(!isolate->global_context().is_null());
|
360
|
+
Handle<Script> script = info->script();
|
361
|
+
script->set_context_data((*isolate->global_context())->data());
|
362
|
+
|
363
|
+
#ifdef ENABLE_DEBUGGER_SUPPORT
|
364
|
+
if (info->is_eval()) {
|
365
|
+
Script::CompilationType compilation_type = Script::COMPILATION_TYPE_EVAL;
|
366
|
+
script->set_compilation_type(Smi::FromInt(compilation_type));
|
367
|
+
// For eval scripts add information on the function from which eval was
|
368
|
+
// called.
|
369
|
+
if (info->is_eval()) {
|
370
|
+
StackTraceFrameIterator it(isolate);
|
371
|
+
if (!it.done()) {
|
372
|
+
script->set_eval_from_shared(
|
373
|
+
JSFunction::cast(it.frame()->function())->shared());
|
374
|
+
Code* code = it.frame()->LookupCode();
|
375
|
+
int offset = static_cast<int>(
|
376
|
+
it.frame()->pc() - code->instruction_start());
|
377
|
+
script->set_eval_from_instructions_offset(Smi::FromInt(offset));
|
378
|
+
}
|
379
|
+
}
|
380
|
+
}
|
381
|
+
|
382
|
+
// Notify debugger
|
383
|
+
isolate->debugger()->OnBeforeCompile(script);
|
384
|
+
#endif
|
385
|
+
|
386
|
+
// Only allow non-global compiles for eval.
|
387
|
+
ASSERT(info->is_eval() || info->is_global());
|
388
|
+
|
389
|
+
if (!ParserApi::Parse(info)) return Handle<SharedFunctionInfo>::null();
|
390
|
+
|
391
|
+
// Measure how long it takes to do the compilation; only take the
|
392
|
+
// rest of the function into account to avoid overlap with the
|
393
|
+
// parsing statistics.
|
394
|
+
HistogramTimer* rate = info->is_eval()
|
395
|
+
? info->isolate()->counters()->compile_eval()
|
396
|
+
: info->isolate()->counters()->compile();
|
397
|
+
HistogramTimerScope timer(rate);
|
398
|
+
|
399
|
+
// Compile the code.
|
400
|
+
FunctionLiteral* lit = info->function();
|
401
|
+
LiveEditFunctionTracker live_edit_tracker(isolate, lit);
|
402
|
+
if (!MakeCode(info)) {
|
403
|
+
isolate->StackOverflow();
|
404
|
+
return Handle<SharedFunctionInfo>::null();
|
405
|
+
}
|
406
|
+
|
407
|
+
// Allocate function.
|
408
|
+
ASSERT(!info->code().is_null());
|
409
|
+
Handle<SharedFunctionInfo> result =
|
410
|
+
isolate->factory()->NewSharedFunctionInfo(
|
411
|
+
lit->name(),
|
412
|
+
lit->materialized_literal_count(),
|
413
|
+
info->code(),
|
414
|
+
SerializedScopeInfo::Create(info->scope()));
|
415
|
+
|
416
|
+
ASSERT_EQ(RelocInfo::kNoPosition, lit->function_token_position());
|
417
|
+
Compiler::SetFunctionInfo(result, lit, true, script);
|
418
|
+
|
419
|
+
if (script->name()->IsString()) {
|
420
|
+
PROFILE(isolate, CodeCreateEvent(
|
421
|
+
info->is_eval()
|
422
|
+
? Logger::EVAL_TAG
|
423
|
+
: Logger::ToNativeByScript(Logger::SCRIPT_TAG, *script),
|
424
|
+
*info->code(),
|
425
|
+
*result,
|
426
|
+
String::cast(script->name())));
|
427
|
+
GDBJIT(AddCode(Handle<String>(String::cast(script->name())),
|
428
|
+
script,
|
429
|
+
info->code()));
|
430
|
+
} else {
|
431
|
+
PROFILE(isolate, CodeCreateEvent(
|
432
|
+
info->is_eval()
|
433
|
+
? Logger::EVAL_TAG
|
434
|
+
: Logger::ToNativeByScript(Logger::SCRIPT_TAG, *script),
|
435
|
+
*info->code(),
|
436
|
+
*result,
|
437
|
+
isolate->heap()->empty_string()));
|
438
|
+
GDBJIT(AddCode(Handle<String>(), script, info->code()));
|
439
|
+
}
|
440
|
+
|
441
|
+
// Hint to the runtime system used when allocating space for initial
|
442
|
+
// property space by setting the expected number of properties for
|
443
|
+
// the instances of the function.
|
444
|
+
SetExpectedNofPropertiesFromEstimate(result, lit->expected_property_count());
|
445
|
+
|
446
|
+
#ifdef ENABLE_DEBUGGER_SUPPORT
|
447
|
+
// Notify debugger
|
448
|
+
isolate->debugger()->OnAfterCompile(
|
449
|
+
script, Debugger::NO_AFTER_COMPILE_FLAGS);
|
450
|
+
#endif
|
451
|
+
|
452
|
+
live_edit_tracker.RecordFunctionInfo(result, lit);
|
453
|
+
|
454
|
+
return result;
|
455
|
+
}
|
456
|
+
|
457
|
+
|
458
|
+
Handle<SharedFunctionInfo> Compiler::Compile(Handle<String> source,
|
459
|
+
Handle<Object> script_name,
|
460
|
+
int line_offset,
|
461
|
+
int column_offset,
|
462
|
+
v8::Extension* extension,
|
463
|
+
ScriptDataImpl* input_pre_data,
|
464
|
+
Handle<Object> script_data,
|
465
|
+
NativesFlag natives) {
|
466
|
+
Isolate* isolate = source->GetIsolate();
|
467
|
+
int source_length = source->length();
|
468
|
+
isolate->counters()->total_load_size()->Increment(source_length);
|
469
|
+
isolate->counters()->total_compile_size()->Increment(source_length);
|
470
|
+
|
471
|
+
// The VM is in the COMPILER state until exiting this function.
|
472
|
+
VMState state(isolate, COMPILER);
|
473
|
+
|
474
|
+
CompilationCache* compilation_cache = isolate->compilation_cache();
|
475
|
+
|
476
|
+
// Do a lookup in the compilation cache but not for extensions.
|
477
|
+
Handle<SharedFunctionInfo> result;
|
478
|
+
if (extension == NULL) {
|
479
|
+
result = compilation_cache->LookupScript(source,
|
480
|
+
script_name,
|
481
|
+
line_offset,
|
482
|
+
column_offset);
|
483
|
+
}
|
484
|
+
|
485
|
+
if (result.is_null()) {
|
486
|
+
// No cache entry found. Do pre-parsing, if it makes sense, and compile
|
487
|
+
// the script.
|
488
|
+
// Building preparse data that is only used immediately after is only a
|
489
|
+
// saving if we might skip building the AST for lazily compiled functions.
|
490
|
+
// I.e., preparse data isn't relevant when the lazy flag is off, and
|
491
|
+
// for small sources, odds are that there aren't many functions
|
492
|
+
// that would be compiled lazily anyway, so we skip the preparse step
|
493
|
+
// in that case too.
|
494
|
+
ScriptDataImpl* pre_data = input_pre_data;
|
495
|
+
if (pre_data == NULL
|
496
|
+
&& source_length >= FLAG_min_preparse_length) {
|
497
|
+
if (source->IsExternalTwoByteString()) {
|
498
|
+
ExternalTwoByteStringUC16CharacterStream stream(
|
499
|
+
Handle<ExternalTwoByteString>::cast(source), 0, source->length());
|
500
|
+
pre_data = ParserApi::PartialPreParse(&stream, extension);
|
501
|
+
} else {
|
502
|
+
GenericStringUC16CharacterStream stream(source, 0, source->length());
|
503
|
+
pre_data = ParserApi::PartialPreParse(&stream, extension);
|
504
|
+
}
|
505
|
+
}
|
506
|
+
|
507
|
+
// Create a script object describing the script to be compiled.
|
508
|
+
Handle<Script> script = FACTORY->NewScript(source);
|
509
|
+
if (natives == NATIVES_CODE) {
|
510
|
+
script->set_type(Smi::FromInt(Script::TYPE_NATIVE));
|
511
|
+
}
|
512
|
+
if (!script_name.is_null()) {
|
513
|
+
script->set_name(*script_name);
|
514
|
+
script->set_line_offset(Smi::FromInt(line_offset));
|
515
|
+
script->set_column_offset(Smi::FromInt(column_offset));
|
516
|
+
}
|
517
|
+
|
518
|
+
script->set_data(script_data.is_null() ? HEAP->undefined_value()
|
519
|
+
: *script_data);
|
520
|
+
|
521
|
+
// Compile the function and add it to the cache.
|
522
|
+
CompilationInfo info(script);
|
523
|
+
info.MarkAsGlobal();
|
524
|
+
info.SetExtension(extension);
|
525
|
+
info.SetPreParseData(pre_data);
|
526
|
+
if (natives == NATIVES_CODE) info.MarkAsAllowingNativesSyntax();
|
527
|
+
result = MakeFunctionInfo(&info);
|
528
|
+
if (extension == NULL && !result.is_null()) {
|
529
|
+
compilation_cache->PutScript(source, result);
|
530
|
+
}
|
531
|
+
|
532
|
+
// Get rid of the pre-parsing data (if necessary).
|
533
|
+
if (input_pre_data == NULL && pre_data != NULL) {
|
534
|
+
delete pre_data;
|
535
|
+
}
|
536
|
+
}
|
537
|
+
|
538
|
+
if (result.is_null()) isolate->ReportPendingMessages();
|
539
|
+
return result;
|
540
|
+
}
|
541
|
+
|
542
|
+
|
543
|
+
Handle<SharedFunctionInfo> Compiler::CompileEval(Handle<String> source,
|
544
|
+
Handle<Context> context,
|
545
|
+
bool is_global,
|
546
|
+
StrictModeFlag strict_mode) {
|
547
|
+
Isolate* isolate = source->GetIsolate();
|
548
|
+
int source_length = source->length();
|
549
|
+
isolate->counters()->total_eval_size()->Increment(source_length);
|
550
|
+
isolate->counters()->total_compile_size()->Increment(source_length);
|
551
|
+
|
552
|
+
// The VM is in the COMPILER state until exiting this function.
|
553
|
+
VMState state(isolate, COMPILER);
|
554
|
+
|
555
|
+
// Do a lookup in the compilation cache; if the entry is not there, invoke
|
556
|
+
// the compiler and add the result to the cache.
|
557
|
+
Handle<SharedFunctionInfo> result;
|
558
|
+
CompilationCache* compilation_cache = isolate->compilation_cache();
|
559
|
+
result = compilation_cache->LookupEval(source,
|
560
|
+
context,
|
561
|
+
is_global,
|
562
|
+
strict_mode);
|
563
|
+
|
564
|
+
if (result.is_null()) {
|
565
|
+
// Create a script object describing the script to be compiled.
|
566
|
+
Handle<Script> script = isolate->factory()->NewScript(source);
|
567
|
+
CompilationInfo info(script);
|
568
|
+
info.MarkAsEval();
|
569
|
+
if (is_global) info.MarkAsGlobal();
|
570
|
+
if (strict_mode == kStrictMode) info.MarkAsStrict();
|
571
|
+
info.SetCallingContext(context);
|
572
|
+
result = MakeFunctionInfo(&info);
|
573
|
+
if (!result.is_null()) {
|
574
|
+
CompilationCache* compilation_cache = isolate->compilation_cache();
|
575
|
+
// If caller is strict mode, the result must be strict as well,
|
576
|
+
// but not the other way around. Consider:
|
577
|
+
// eval("'use strict'; ...");
|
578
|
+
ASSERT(strict_mode == kNonStrictMode || result->strict_mode());
|
579
|
+
compilation_cache->PutEval(source, context, is_global, result);
|
580
|
+
}
|
581
|
+
}
|
582
|
+
|
583
|
+
return result;
|
584
|
+
}
|
585
|
+
|
586
|
+
|
587
|
+
bool Compiler::CompileLazy(CompilationInfo* info) {
|
588
|
+
CompilationZoneScope zone_scope(DELETE_ON_EXIT);
|
589
|
+
|
590
|
+
// The VM is in the COMPILER state until exiting this function.
|
591
|
+
VMState state(info->isolate(), COMPILER);
|
592
|
+
|
593
|
+
Isolate* isolate = info->isolate();
|
594
|
+
PostponeInterruptsScope postpone(isolate);
|
595
|
+
|
596
|
+
Handle<SharedFunctionInfo> shared = info->shared_info();
|
597
|
+
int compiled_size = shared->end_position() - shared->start_position();
|
598
|
+
isolate->counters()->total_compile_size()->Increment(compiled_size);
|
599
|
+
|
600
|
+
// Generate the AST for the lazily compiled function.
|
601
|
+
if (ParserApi::Parse(info)) {
|
602
|
+
// Measure how long it takes to do the lazy compilation; only take the
|
603
|
+
// rest of the function into account to avoid overlap with the lazy
|
604
|
+
// parsing statistics.
|
605
|
+
HistogramTimerScope timer(isolate->counters()->compile_lazy());
|
606
|
+
|
607
|
+
// Compile the code.
|
608
|
+
if (!MakeCode(info)) {
|
609
|
+
if (!isolate->has_pending_exception()) {
|
610
|
+
isolate->StackOverflow();
|
611
|
+
}
|
612
|
+
} else {
|
613
|
+
ASSERT(!info->code().is_null());
|
614
|
+
Handle<Code> code = info->code();
|
615
|
+
// Set optimizable to false if this is disallowed by the shared
|
616
|
+
// function info, e.g., we might have flushed the code and must
|
617
|
+
// reset this bit when lazy compiling the code again.
|
618
|
+
if (shared->optimization_disabled()) code->set_optimizable(false);
|
619
|
+
|
620
|
+
Handle<JSFunction> function = info->closure();
|
621
|
+
RecordFunctionCompilation(Logger::LAZY_COMPILE_TAG, info, shared);
|
622
|
+
|
623
|
+
if (info->IsOptimizing()) {
|
624
|
+
function->ReplaceCode(*code);
|
625
|
+
} else {
|
626
|
+
// Update the shared function info with the compiled code and the
|
627
|
+
// scope info. Please note, that the order of the shared function
|
628
|
+
// info initialization is important since set_scope_info might
|
629
|
+
// trigger a GC, causing the ASSERT below to be invalid if the code
|
630
|
+
// was flushed. By settting the code object last we avoid this.
|
631
|
+
Handle<SerializedScopeInfo> scope_info =
|
632
|
+
SerializedScopeInfo::Create(info->scope());
|
633
|
+
shared->set_scope_info(*scope_info);
|
634
|
+
shared->set_code(*code);
|
635
|
+
if (!function.is_null()) {
|
636
|
+
function->ReplaceCode(*code);
|
637
|
+
ASSERT(!function->IsOptimized());
|
638
|
+
}
|
639
|
+
|
640
|
+
// Set the expected number of properties for instances.
|
641
|
+
FunctionLiteral* lit = info->function();
|
642
|
+
int expected = lit->expected_property_count();
|
643
|
+
SetExpectedNofPropertiesFromEstimate(shared, expected);
|
644
|
+
|
645
|
+
// Set the optimization hints after performing lazy compilation, as
|
646
|
+
// these are not set when the function is set up as a lazily
|
647
|
+
// compiled function.
|
648
|
+
shared->SetThisPropertyAssignmentsInfo(
|
649
|
+
lit->has_only_simple_this_property_assignments(),
|
650
|
+
*lit->this_property_assignments());
|
651
|
+
|
652
|
+
// Check the function has compiled code.
|
653
|
+
ASSERT(shared->is_compiled());
|
654
|
+
shared->set_code_age(0);
|
655
|
+
|
656
|
+
if (info->AllowOptimize() && !shared->optimization_disabled()) {
|
657
|
+
// If we're asked to always optimize, we compile the optimized
|
658
|
+
// version of the function right away - unless the debugger is
|
659
|
+
// active as it makes no sense to compile optimized code then.
|
660
|
+
if (FLAG_always_opt &&
|
661
|
+
!Isolate::Current()->debug()->has_break_points()) {
|
662
|
+
CompilationInfo optimized(function);
|
663
|
+
optimized.SetOptimizing(AstNode::kNoNumber);
|
664
|
+
return CompileLazy(&optimized);
|
665
|
+
} else if (isolate->compilation_cache()->ShouldOptimizeEagerly(
|
666
|
+
function)) {
|
667
|
+
isolate->runtime_profiler()->OptimizeSoon(*function);
|
668
|
+
}
|
669
|
+
}
|
670
|
+
}
|
671
|
+
|
672
|
+
return true;
|
673
|
+
}
|
674
|
+
}
|
675
|
+
|
676
|
+
ASSERT(info->code().is_null());
|
677
|
+
return false;
|
678
|
+
}
|
679
|
+
|
680
|
+
|
681
|
+
Handle<SharedFunctionInfo> Compiler::BuildFunctionInfo(FunctionLiteral* literal,
|
682
|
+
Handle<Script> script) {
|
683
|
+
// Precondition: code has been parsed and scopes have been analyzed.
|
684
|
+
CompilationInfo info(script);
|
685
|
+
info.SetFunction(literal);
|
686
|
+
info.SetScope(literal->scope());
|
687
|
+
|
688
|
+
LiveEditFunctionTracker live_edit_tracker(info.isolate(), literal);
|
689
|
+
// Determine if the function can be lazily compiled. This is necessary to
|
690
|
+
// allow some of our builtin JS files to be lazily compiled. These
|
691
|
+
// builtins cannot be handled lazily by the parser, since we have to know
|
692
|
+
// if a function uses the special natives syntax, which is something the
|
693
|
+
// parser records.
|
694
|
+
bool allow_lazy = literal->AllowsLazyCompilation() &&
|
695
|
+
!LiveEditFunctionTracker::IsActive(info.isolate());
|
696
|
+
|
697
|
+
Handle<SerializedScopeInfo> scope_info(SerializedScopeInfo::Empty());
|
698
|
+
|
699
|
+
// Generate code
|
700
|
+
if (FLAG_lazy && allow_lazy) {
|
701
|
+
Handle<Code> code = info.isolate()->builtins()->LazyCompile();
|
702
|
+
info.SetCode(code);
|
703
|
+
} else if ((V8::UseCrankshaft() && MakeCrankshaftCode(&info)) ||
|
704
|
+
(!V8::UseCrankshaft() && FullCodeGenerator::MakeCode(&info))) {
|
705
|
+
ASSERT(!info.code().is_null());
|
706
|
+
scope_info = SerializedScopeInfo::Create(info.scope());
|
707
|
+
} else {
|
708
|
+
return Handle<SharedFunctionInfo>::null();
|
709
|
+
}
|
710
|
+
|
711
|
+
// Create a shared function info object.
|
712
|
+
Handle<SharedFunctionInfo> result =
|
713
|
+
FACTORY->NewSharedFunctionInfo(literal->name(),
|
714
|
+
literal->materialized_literal_count(),
|
715
|
+
info.code(),
|
716
|
+
scope_info);
|
717
|
+
SetFunctionInfo(result, literal, false, script);
|
718
|
+
RecordFunctionCompilation(Logger::FUNCTION_TAG, &info, result);
|
719
|
+
result->set_allows_lazy_compilation(allow_lazy);
|
720
|
+
|
721
|
+
// Set the expected number of properties for instances and return
|
722
|
+
// the resulting function.
|
723
|
+
SetExpectedNofPropertiesFromEstimate(result,
|
724
|
+
literal->expected_property_count());
|
725
|
+
live_edit_tracker.RecordFunctionInfo(result, literal);
|
726
|
+
return result;
|
727
|
+
}
|
728
|
+
|
729
|
+
|
730
|
+
// Sets the function info on a function.
|
731
|
+
// The start_position points to the first '(' character after the function name
|
732
|
+
// in the full script source. When counting characters in the script source the
|
733
|
+
// the first character is number 0 (not 1).
|
734
|
+
void Compiler::SetFunctionInfo(Handle<SharedFunctionInfo> function_info,
|
735
|
+
FunctionLiteral* lit,
|
736
|
+
bool is_toplevel,
|
737
|
+
Handle<Script> script) {
|
738
|
+
function_info->set_length(lit->num_parameters());
|
739
|
+
function_info->set_formal_parameter_count(lit->num_parameters());
|
740
|
+
function_info->set_script(*script);
|
741
|
+
function_info->set_function_token_position(lit->function_token_position());
|
742
|
+
function_info->set_start_position(lit->start_position());
|
743
|
+
function_info->set_end_position(lit->end_position());
|
744
|
+
function_info->set_is_expression(lit->is_expression());
|
745
|
+
function_info->set_is_toplevel(is_toplevel);
|
746
|
+
function_info->set_inferred_name(*lit->inferred_name());
|
747
|
+
function_info->SetThisPropertyAssignmentsInfo(
|
748
|
+
lit->has_only_simple_this_property_assignments(),
|
749
|
+
*lit->this_property_assignments());
|
750
|
+
function_info->set_allows_lazy_compilation(lit->AllowsLazyCompilation());
|
751
|
+
function_info->set_strict_mode(lit->strict_mode());
|
752
|
+
}
|
753
|
+
|
754
|
+
|
755
|
+
void Compiler::RecordFunctionCompilation(Logger::LogEventsAndTags tag,
|
756
|
+
CompilationInfo* info,
|
757
|
+
Handle<SharedFunctionInfo> shared) {
|
758
|
+
// SharedFunctionInfo is passed separately, because if CompilationInfo
|
759
|
+
// was created using Script object, it will not have it.
|
760
|
+
|
761
|
+
// Log the code generation. If source information is available include
|
762
|
+
// script name and line number. Check explicitly whether logging is
|
763
|
+
// enabled as finding the line number is not free.
|
764
|
+
if (info->isolate()->logger()->is_logging() || CpuProfiler::is_profiling()) {
|
765
|
+
Handle<Script> script = info->script();
|
766
|
+
Handle<Code> code = info->code();
|
767
|
+
if (*code == info->isolate()->builtins()->builtin(Builtins::kLazyCompile))
|
768
|
+
return;
|
769
|
+
if (script->name()->IsString()) {
|
770
|
+
int line_num = GetScriptLineNumber(script, shared->start_position()) + 1;
|
771
|
+
USE(line_num);
|
772
|
+
PROFILE(info->isolate(),
|
773
|
+
CodeCreateEvent(Logger::ToNativeByScript(tag, *script),
|
774
|
+
*code,
|
775
|
+
*shared,
|
776
|
+
String::cast(script->name()),
|
777
|
+
line_num));
|
778
|
+
} else {
|
779
|
+
PROFILE(info->isolate(),
|
780
|
+
CodeCreateEvent(Logger::ToNativeByScript(tag, *script),
|
781
|
+
*code,
|
782
|
+
*shared,
|
783
|
+
shared->DebugName()));
|
784
|
+
}
|
785
|
+
}
|
786
|
+
|
787
|
+
GDBJIT(AddCode(name,
|
788
|
+
Handle<Script>(info->script()),
|
789
|
+
Handle<Code>(info->code())));
|
790
|
+
}
|
791
|
+
|
792
|
+
} } // namespace v8::internal
|