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,177 @@
|
|
1
|
+
// Copyright 2006-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
|
+
|
29
|
+
#ifndef V8_HANDLES_INL_H_
|
30
|
+
#define V8_HANDLES_INL_H_
|
31
|
+
|
32
|
+
#include "api.h"
|
33
|
+
#include "apiutils.h"
|
34
|
+
#include "handles.h"
|
35
|
+
#include "isolate.h"
|
36
|
+
|
37
|
+
namespace v8 {
|
38
|
+
namespace internal {
|
39
|
+
|
40
|
+
inline Isolate* GetIsolateForHandle(Object* obj) {
|
41
|
+
return Isolate::Current();
|
42
|
+
}
|
43
|
+
|
44
|
+
inline Isolate* GetIsolateForHandle(HeapObject* obj) {
|
45
|
+
return obj->GetIsolate();
|
46
|
+
}
|
47
|
+
|
48
|
+
template<typename T>
|
49
|
+
Handle<T>::Handle(T* obj) {
|
50
|
+
ASSERT(!obj->IsFailure());
|
51
|
+
location_ = HandleScope::CreateHandle(obj, GetIsolateForHandle(obj));
|
52
|
+
}
|
53
|
+
|
54
|
+
|
55
|
+
template<typename T>
|
56
|
+
Handle<T>::Handle(T* obj, Isolate* isolate) {
|
57
|
+
ASSERT(!obj->IsFailure());
|
58
|
+
location_ = HandleScope::CreateHandle(obj, isolate);
|
59
|
+
}
|
60
|
+
|
61
|
+
|
62
|
+
template <typename T>
|
63
|
+
inline T* Handle<T>::operator*() const {
|
64
|
+
ASSERT(location_ != NULL);
|
65
|
+
ASSERT(reinterpret_cast<Address>(*location_) != kHandleZapValue);
|
66
|
+
return *BitCast<T**>(location_);
|
67
|
+
}
|
68
|
+
|
69
|
+
|
70
|
+
HandleScope::HandleScope() {
|
71
|
+
Isolate* isolate = Isolate::Current();
|
72
|
+
v8::ImplementationUtilities::HandleScopeData* current =
|
73
|
+
isolate->handle_scope_data();
|
74
|
+
isolate_ = isolate;
|
75
|
+
prev_next_ = current->next;
|
76
|
+
prev_limit_ = current->limit;
|
77
|
+
current->level++;
|
78
|
+
}
|
79
|
+
|
80
|
+
|
81
|
+
HandleScope::HandleScope(Isolate* isolate) {
|
82
|
+
ASSERT(isolate == Isolate::Current());
|
83
|
+
v8::ImplementationUtilities::HandleScopeData* current =
|
84
|
+
isolate->handle_scope_data();
|
85
|
+
isolate_ = isolate;
|
86
|
+
prev_next_ = current->next;
|
87
|
+
prev_limit_ = current->limit;
|
88
|
+
current->level++;
|
89
|
+
}
|
90
|
+
|
91
|
+
|
92
|
+
HandleScope::~HandleScope() {
|
93
|
+
CloseScope();
|
94
|
+
}
|
95
|
+
|
96
|
+
void HandleScope::CloseScope() {
|
97
|
+
ASSERT(isolate_ == Isolate::Current());
|
98
|
+
v8::ImplementationUtilities::HandleScopeData* current =
|
99
|
+
isolate_->handle_scope_data();
|
100
|
+
current->next = prev_next_;
|
101
|
+
current->level--;
|
102
|
+
if (current->limit != prev_limit_) {
|
103
|
+
current->limit = prev_limit_;
|
104
|
+
DeleteExtensions(isolate_);
|
105
|
+
}
|
106
|
+
#ifdef DEBUG
|
107
|
+
ZapRange(prev_next_, prev_limit_);
|
108
|
+
#endif
|
109
|
+
}
|
110
|
+
|
111
|
+
|
112
|
+
template <typename T>
|
113
|
+
Handle<T> HandleScope::CloseAndEscape(Handle<T> handle_value) {
|
114
|
+
T* value = *handle_value;
|
115
|
+
// Throw away all handles in the current scope.
|
116
|
+
CloseScope();
|
117
|
+
v8::ImplementationUtilities::HandleScopeData* current =
|
118
|
+
isolate_->handle_scope_data();
|
119
|
+
// Allocate one handle in the parent scope.
|
120
|
+
ASSERT(current->level > 0);
|
121
|
+
Handle<T> result(CreateHandle<T>(value, isolate_));
|
122
|
+
// Reinitialize the current scope (so that it's ready
|
123
|
+
// to be used or closed again).
|
124
|
+
prev_next_ = current->next;
|
125
|
+
prev_limit_ = current->limit;
|
126
|
+
current->level++;
|
127
|
+
return result;
|
128
|
+
}
|
129
|
+
|
130
|
+
|
131
|
+
template <typename T>
|
132
|
+
T** HandleScope::CreateHandle(T* value, Isolate* isolate) {
|
133
|
+
ASSERT(isolate == Isolate::Current());
|
134
|
+
v8::ImplementationUtilities::HandleScopeData* current =
|
135
|
+
isolate->handle_scope_data();
|
136
|
+
|
137
|
+
internal::Object** cur = current->next;
|
138
|
+
if (cur == current->limit) cur = Extend();
|
139
|
+
// Update the current next field, set the value in the created
|
140
|
+
// handle, and return the result.
|
141
|
+
ASSERT(cur < current->limit);
|
142
|
+
current->next = cur + 1;
|
143
|
+
|
144
|
+
T** result = reinterpret_cast<T**>(cur);
|
145
|
+
*result = value;
|
146
|
+
return result;
|
147
|
+
}
|
148
|
+
|
149
|
+
|
150
|
+
#ifdef DEBUG
|
151
|
+
inline NoHandleAllocation::NoHandleAllocation() {
|
152
|
+
v8::ImplementationUtilities::HandleScopeData* current =
|
153
|
+
Isolate::Current()->handle_scope_data();
|
154
|
+
|
155
|
+
// Shrink the current handle scope to make it impossible to do
|
156
|
+
// handle allocations without an explicit handle scope.
|
157
|
+
current->limit = current->next;
|
158
|
+
|
159
|
+
level_ = current->level;
|
160
|
+
current->level = 0;
|
161
|
+
}
|
162
|
+
|
163
|
+
|
164
|
+
inline NoHandleAllocation::~NoHandleAllocation() {
|
165
|
+
// Restore state in current handle scope to re-enable handle
|
166
|
+
// allocations.
|
167
|
+
v8::ImplementationUtilities::HandleScopeData* data =
|
168
|
+
Isolate::Current()->handle_scope_data();
|
169
|
+
ASSERT_EQ(0, data->level);
|
170
|
+
data->level = level_;
|
171
|
+
}
|
172
|
+
#endif
|
173
|
+
|
174
|
+
|
175
|
+
} } // namespace v8::internal
|
176
|
+
|
177
|
+
#endif // V8_HANDLES_INL_H_
|
@@ -0,0 +1,965 @@
|
|
1
|
+
// Copyright 2009 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 "accessors.h"
|
31
|
+
#include "api.h"
|
32
|
+
#include "arguments.h"
|
33
|
+
#include "bootstrapper.h"
|
34
|
+
#include "compiler.h"
|
35
|
+
#include "debug.h"
|
36
|
+
#include "execution.h"
|
37
|
+
#include "global-handles.h"
|
38
|
+
#include "natives.h"
|
39
|
+
#include "runtime.h"
|
40
|
+
#include "string-search.h"
|
41
|
+
#include "stub-cache.h"
|
42
|
+
#include "vm-state-inl.h"
|
43
|
+
|
44
|
+
namespace v8 {
|
45
|
+
namespace internal {
|
46
|
+
|
47
|
+
|
48
|
+
int HandleScope::NumberOfHandles() {
|
49
|
+
Isolate* isolate = Isolate::Current();
|
50
|
+
HandleScopeImplementer* impl = isolate->handle_scope_implementer();
|
51
|
+
int n = impl->blocks()->length();
|
52
|
+
if (n == 0) return 0;
|
53
|
+
return ((n - 1) * kHandleBlockSize) + static_cast<int>(
|
54
|
+
(isolate->handle_scope_data()->next - impl->blocks()->last()));
|
55
|
+
}
|
56
|
+
|
57
|
+
|
58
|
+
Object** HandleScope::Extend() {
|
59
|
+
Isolate* isolate = Isolate::Current();
|
60
|
+
v8::ImplementationUtilities::HandleScopeData* current =
|
61
|
+
isolate->handle_scope_data();
|
62
|
+
|
63
|
+
Object** result = current->next;
|
64
|
+
|
65
|
+
ASSERT(result == current->limit);
|
66
|
+
// Make sure there's at least one scope on the stack and that the
|
67
|
+
// top of the scope stack isn't a barrier.
|
68
|
+
if (current->level == 0) {
|
69
|
+
Utils::ReportApiFailure("v8::HandleScope::CreateHandle()",
|
70
|
+
"Cannot create a handle without a HandleScope");
|
71
|
+
return NULL;
|
72
|
+
}
|
73
|
+
HandleScopeImplementer* impl = isolate->handle_scope_implementer();
|
74
|
+
// If there's more room in the last block, we use that. This is used
|
75
|
+
// for fast creation of scopes after scope barriers.
|
76
|
+
if (!impl->blocks()->is_empty()) {
|
77
|
+
Object** limit = &impl->blocks()->last()[kHandleBlockSize];
|
78
|
+
if (current->limit != limit) {
|
79
|
+
current->limit = limit;
|
80
|
+
ASSERT(limit - current->next < kHandleBlockSize);
|
81
|
+
}
|
82
|
+
}
|
83
|
+
|
84
|
+
// If we still haven't found a slot for the handle, we extend the
|
85
|
+
// current handle scope by allocating a new handle block.
|
86
|
+
if (result == current->limit) {
|
87
|
+
// If there's a spare block, use it for growing the current scope.
|
88
|
+
result = impl->GetSpareOrNewBlock();
|
89
|
+
// Add the extension to the global list of blocks, but count the
|
90
|
+
// extension as part of the current scope.
|
91
|
+
impl->blocks()->Add(result);
|
92
|
+
current->limit = &result[kHandleBlockSize];
|
93
|
+
}
|
94
|
+
|
95
|
+
return result;
|
96
|
+
}
|
97
|
+
|
98
|
+
|
99
|
+
void HandleScope::DeleteExtensions(Isolate* isolate) {
|
100
|
+
ASSERT(isolate == Isolate::Current());
|
101
|
+
v8::ImplementationUtilities::HandleScopeData* current =
|
102
|
+
isolate->handle_scope_data();
|
103
|
+
isolate->handle_scope_implementer()->DeleteExtensions(current->limit);
|
104
|
+
}
|
105
|
+
|
106
|
+
|
107
|
+
void HandleScope::ZapRange(Object** start, Object** end) {
|
108
|
+
ASSERT(end - start <= kHandleBlockSize);
|
109
|
+
for (Object** p = start; p != end; p++) {
|
110
|
+
*reinterpret_cast<Address*>(p) = v8::internal::kHandleZapValue;
|
111
|
+
}
|
112
|
+
}
|
113
|
+
|
114
|
+
|
115
|
+
Address HandleScope::current_level_address() {
|
116
|
+
return reinterpret_cast<Address>(
|
117
|
+
&Isolate::Current()->handle_scope_data()->level);
|
118
|
+
}
|
119
|
+
|
120
|
+
|
121
|
+
Address HandleScope::current_next_address() {
|
122
|
+
return reinterpret_cast<Address>(
|
123
|
+
&Isolate::Current()->handle_scope_data()->next);
|
124
|
+
}
|
125
|
+
|
126
|
+
|
127
|
+
Address HandleScope::current_limit_address() {
|
128
|
+
return reinterpret_cast<Address>(
|
129
|
+
&Isolate::Current()->handle_scope_data()->limit);
|
130
|
+
}
|
131
|
+
|
132
|
+
|
133
|
+
Handle<FixedArray> AddKeysFromJSArray(Handle<FixedArray> content,
|
134
|
+
Handle<JSArray> array) {
|
135
|
+
CALL_HEAP_FUNCTION(content->GetIsolate(),
|
136
|
+
content->AddKeysFromJSArray(*array), FixedArray);
|
137
|
+
}
|
138
|
+
|
139
|
+
|
140
|
+
Handle<FixedArray> UnionOfKeys(Handle<FixedArray> first,
|
141
|
+
Handle<FixedArray> second) {
|
142
|
+
CALL_HEAP_FUNCTION(first->GetIsolate(),
|
143
|
+
first->UnionOfKeys(*second), FixedArray);
|
144
|
+
}
|
145
|
+
|
146
|
+
|
147
|
+
Handle<JSGlobalProxy> ReinitializeJSGlobalProxy(
|
148
|
+
Handle<JSFunction> constructor,
|
149
|
+
Handle<JSGlobalProxy> global) {
|
150
|
+
CALL_HEAP_FUNCTION(
|
151
|
+
constructor->GetIsolate(),
|
152
|
+
constructor->GetHeap()->ReinitializeJSGlobalProxy(*constructor, *global),
|
153
|
+
JSGlobalProxy);
|
154
|
+
}
|
155
|
+
|
156
|
+
|
157
|
+
void SetExpectedNofProperties(Handle<JSFunction> func, int nof) {
|
158
|
+
// If objects constructed from this function exist then changing
|
159
|
+
// 'estimated_nof_properties' is dangerous since the previous value might
|
160
|
+
// have been compiled into the fast construct stub. More over, the inobject
|
161
|
+
// slack tracking logic might have adjusted the previous value, so even
|
162
|
+
// passing the same value is risky.
|
163
|
+
if (func->shared()->live_objects_may_exist()) return;
|
164
|
+
|
165
|
+
func->shared()->set_expected_nof_properties(nof);
|
166
|
+
if (func->has_initial_map()) {
|
167
|
+
Handle<Map> new_initial_map =
|
168
|
+
func->GetIsolate()->factory()->CopyMapDropTransitions(
|
169
|
+
Handle<Map>(func->initial_map()));
|
170
|
+
new_initial_map->set_unused_property_fields(nof);
|
171
|
+
func->set_initial_map(*new_initial_map);
|
172
|
+
}
|
173
|
+
}
|
174
|
+
|
175
|
+
|
176
|
+
void SetPrototypeProperty(Handle<JSFunction> func, Handle<JSObject> value) {
|
177
|
+
CALL_HEAP_FUNCTION_VOID(func->GetIsolate(),
|
178
|
+
func->SetPrototype(*value));
|
179
|
+
}
|
180
|
+
|
181
|
+
|
182
|
+
static int ExpectedNofPropertiesFromEstimate(int estimate) {
|
183
|
+
// If no properties are added in the constructor, they are more likely
|
184
|
+
// to be added later.
|
185
|
+
if (estimate == 0) estimate = 2;
|
186
|
+
|
187
|
+
// We do not shrink objects that go into a snapshot (yet), so we adjust
|
188
|
+
// the estimate conservatively.
|
189
|
+
if (Serializer::enabled()) return estimate + 2;
|
190
|
+
|
191
|
+
// Inobject slack tracking will reclaim redundant inobject space later,
|
192
|
+
// so we can afford to adjust the estimate generously.
|
193
|
+
return estimate + 8;
|
194
|
+
}
|
195
|
+
|
196
|
+
|
197
|
+
void SetExpectedNofPropertiesFromEstimate(Handle<SharedFunctionInfo> shared,
|
198
|
+
int estimate) {
|
199
|
+
// See the comment in SetExpectedNofProperties.
|
200
|
+
if (shared->live_objects_may_exist()) return;
|
201
|
+
|
202
|
+
shared->set_expected_nof_properties(
|
203
|
+
ExpectedNofPropertiesFromEstimate(estimate));
|
204
|
+
}
|
205
|
+
|
206
|
+
|
207
|
+
void NormalizeProperties(Handle<JSObject> object,
|
208
|
+
PropertyNormalizationMode mode,
|
209
|
+
int expected_additional_properties) {
|
210
|
+
CALL_HEAP_FUNCTION_VOID(object->GetIsolate(),
|
211
|
+
object->NormalizeProperties(
|
212
|
+
mode,
|
213
|
+
expected_additional_properties));
|
214
|
+
}
|
215
|
+
|
216
|
+
|
217
|
+
void NormalizeElements(Handle<JSObject> object) {
|
218
|
+
CALL_HEAP_FUNCTION_VOID(object->GetIsolate(),
|
219
|
+
object->NormalizeElements());
|
220
|
+
}
|
221
|
+
|
222
|
+
|
223
|
+
void TransformToFastProperties(Handle<JSObject> object,
|
224
|
+
int unused_property_fields) {
|
225
|
+
CALL_HEAP_FUNCTION_VOID(
|
226
|
+
object->GetIsolate(),
|
227
|
+
object->TransformToFastProperties(unused_property_fields));
|
228
|
+
}
|
229
|
+
|
230
|
+
|
231
|
+
void NumberDictionarySet(Handle<NumberDictionary> dictionary,
|
232
|
+
uint32_t index,
|
233
|
+
Handle<Object> value,
|
234
|
+
PropertyDetails details) {
|
235
|
+
CALL_HEAP_FUNCTION_VOID(dictionary->GetIsolate(),
|
236
|
+
dictionary->Set(index, *value, details));
|
237
|
+
}
|
238
|
+
|
239
|
+
|
240
|
+
void FlattenString(Handle<String> string) {
|
241
|
+
CALL_HEAP_FUNCTION_VOID(string->GetIsolate(), string->TryFlatten());
|
242
|
+
}
|
243
|
+
|
244
|
+
|
245
|
+
Handle<String> FlattenGetString(Handle<String> string) {
|
246
|
+
CALL_HEAP_FUNCTION(string->GetIsolate(), string->TryFlatten(), String);
|
247
|
+
}
|
248
|
+
|
249
|
+
|
250
|
+
Handle<Object> SetPrototype(Handle<JSFunction> function,
|
251
|
+
Handle<Object> prototype) {
|
252
|
+
ASSERT(function->should_have_prototype());
|
253
|
+
CALL_HEAP_FUNCTION(function->GetIsolate(),
|
254
|
+
Accessors::FunctionSetPrototype(*function,
|
255
|
+
*prototype,
|
256
|
+
NULL),
|
257
|
+
Object);
|
258
|
+
}
|
259
|
+
|
260
|
+
|
261
|
+
Handle<Object> SetProperty(Handle<JSObject> object,
|
262
|
+
Handle<String> key,
|
263
|
+
Handle<Object> value,
|
264
|
+
PropertyAttributes attributes,
|
265
|
+
StrictModeFlag strict_mode) {
|
266
|
+
CALL_HEAP_FUNCTION(object->GetIsolate(),
|
267
|
+
object->SetProperty(*key, *value, attributes, strict_mode),
|
268
|
+
Object);
|
269
|
+
}
|
270
|
+
|
271
|
+
|
272
|
+
Handle<Object> SetProperty(Handle<Object> object,
|
273
|
+
Handle<Object> key,
|
274
|
+
Handle<Object> value,
|
275
|
+
PropertyAttributes attributes,
|
276
|
+
StrictModeFlag strict_mode) {
|
277
|
+
Isolate* isolate = Isolate::Current();
|
278
|
+
CALL_HEAP_FUNCTION(
|
279
|
+
isolate,
|
280
|
+
Runtime::SetObjectProperty(
|
281
|
+
isolate, object, key, value, attributes, strict_mode),
|
282
|
+
Object);
|
283
|
+
}
|
284
|
+
|
285
|
+
|
286
|
+
Handle<Object> ForceSetProperty(Handle<JSObject> object,
|
287
|
+
Handle<Object> key,
|
288
|
+
Handle<Object> value,
|
289
|
+
PropertyAttributes attributes) {
|
290
|
+
Isolate* isolate = object->GetIsolate();
|
291
|
+
CALL_HEAP_FUNCTION(
|
292
|
+
isolate,
|
293
|
+
Runtime::ForceSetObjectProperty(
|
294
|
+
isolate, object, key, value, attributes),
|
295
|
+
Object);
|
296
|
+
}
|
297
|
+
|
298
|
+
|
299
|
+
Handle<Object> SetNormalizedProperty(Handle<JSObject> object,
|
300
|
+
Handle<String> key,
|
301
|
+
Handle<Object> value,
|
302
|
+
PropertyDetails details) {
|
303
|
+
CALL_HEAP_FUNCTION(object->GetIsolate(),
|
304
|
+
object->SetNormalizedProperty(*key, *value, details),
|
305
|
+
Object);
|
306
|
+
}
|
307
|
+
|
308
|
+
|
309
|
+
Handle<Object> ForceDeleteProperty(Handle<JSObject> object,
|
310
|
+
Handle<Object> key) {
|
311
|
+
Isolate* isolate = object->GetIsolate();
|
312
|
+
CALL_HEAP_FUNCTION(isolate,
|
313
|
+
Runtime::ForceDeleteObjectProperty(isolate, object, key),
|
314
|
+
Object);
|
315
|
+
}
|
316
|
+
|
317
|
+
|
318
|
+
Handle<Object> SetLocalPropertyIgnoreAttributes(
|
319
|
+
Handle<JSObject> object,
|
320
|
+
Handle<String> key,
|
321
|
+
Handle<Object> value,
|
322
|
+
PropertyAttributes attributes) {
|
323
|
+
CALL_HEAP_FUNCTION(
|
324
|
+
object->GetIsolate(),
|
325
|
+
object->SetLocalPropertyIgnoreAttributes(*key, *value, attributes),
|
326
|
+
Object);
|
327
|
+
}
|
328
|
+
|
329
|
+
|
330
|
+
void SetLocalPropertyNoThrow(Handle<JSObject> object,
|
331
|
+
Handle<String> key,
|
332
|
+
Handle<Object> value,
|
333
|
+
PropertyAttributes attributes) {
|
334
|
+
Isolate* isolate = object->GetIsolate();
|
335
|
+
ASSERT(!isolate->has_pending_exception());
|
336
|
+
CHECK(!SetLocalPropertyIgnoreAttributes(
|
337
|
+
object, key, value, attributes).is_null());
|
338
|
+
CHECK(!isolate->has_pending_exception());
|
339
|
+
}
|
340
|
+
|
341
|
+
|
342
|
+
Handle<Object> SetPropertyWithInterceptor(Handle<JSObject> object,
|
343
|
+
Handle<String> key,
|
344
|
+
Handle<Object> value,
|
345
|
+
PropertyAttributes attributes,
|
346
|
+
StrictModeFlag strict_mode) {
|
347
|
+
CALL_HEAP_FUNCTION(object->GetIsolate(),
|
348
|
+
object->SetPropertyWithInterceptor(*key,
|
349
|
+
*value,
|
350
|
+
attributes,
|
351
|
+
strict_mode),
|
352
|
+
Object);
|
353
|
+
}
|
354
|
+
|
355
|
+
|
356
|
+
Handle<Object> GetProperty(Handle<JSObject> obj,
|
357
|
+
const char* name) {
|
358
|
+
Isolate* isolate = obj->GetIsolate();
|
359
|
+
Handle<String> str = isolate->factory()->LookupAsciiSymbol(name);
|
360
|
+
CALL_HEAP_FUNCTION(isolate, obj->GetProperty(*str), Object);
|
361
|
+
}
|
362
|
+
|
363
|
+
|
364
|
+
Handle<Object> GetProperty(Handle<Object> obj,
|
365
|
+
Handle<Object> key) {
|
366
|
+
Isolate* isolate = Isolate::Current();
|
367
|
+
CALL_HEAP_FUNCTION(isolate,
|
368
|
+
Runtime::GetObjectProperty(isolate, obj, key), Object);
|
369
|
+
}
|
370
|
+
|
371
|
+
|
372
|
+
Handle<Object> GetElement(Handle<Object> obj,
|
373
|
+
uint32_t index) {
|
374
|
+
Isolate* isolate = Isolate::Current();
|
375
|
+
CALL_HEAP_FUNCTION(isolate, Runtime::GetElement(obj, index), Object);
|
376
|
+
}
|
377
|
+
|
378
|
+
|
379
|
+
Handle<Object> GetPropertyWithInterceptor(Handle<JSObject> receiver,
|
380
|
+
Handle<JSObject> holder,
|
381
|
+
Handle<String> name,
|
382
|
+
PropertyAttributes* attributes) {
|
383
|
+
Isolate* isolate = receiver->GetIsolate();
|
384
|
+
CALL_HEAP_FUNCTION(isolate,
|
385
|
+
holder->GetPropertyWithInterceptor(*receiver,
|
386
|
+
*name,
|
387
|
+
attributes),
|
388
|
+
Object);
|
389
|
+
}
|
390
|
+
|
391
|
+
|
392
|
+
Handle<Object> GetPrototype(Handle<Object> obj) {
|
393
|
+
Handle<Object> result(obj->GetPrototype());
|
394
|
+
return result;
|
395
|
+
}
|
396
|
+
|
397
|
+
|
398
|
+
Handle<Object> SetPrototype(Handle<JSObject> obj, Handle<Object> value) {
|
399
|
+
const bool skip_hidden_prototypes = false;
|
400
|
+
CALL_HEAP_FUNCTION(obj->GetIsolate(),
|
401
|
+
obj->SetPrototype(*value, skip_hidden_prototypes), Object);
|
402
|
+
}
|
403
|
+
|
404
|
+
|
405
|
+
Handle<Object> PreventExtensions(Handle<JSObject> object) {
|
406
|
+
CALL_HEAP_FUNCTION(object->GetIsolate(), object->PreventExtensions(), Object);
|
407
|
+
}
|
408
|
+
|
409
|
+
|
410
|
+
Handle<Object> GetHiddenProperties(Handle<JSObject> obj,
|
411
|
+
bool create_if_needed) {
|
412
|
+
Isolate* isolate = obj->GetIsolate();
|
413
|
+
Object* holder = obj->BypassGlobalProxy();
|
414
|
+
if (holder->IsUndefined()) return isolate->factory()->undefined_value();
|
415
|
+
obj = Handle<JSObject>(JSObject::cast(holder), isolate);
|
416
|
+
|
417
|
+
if (obj->HasFastProperties()) {
|
418
|
+
// If the object has fast properties, check whether the first slot
|
419
|
+
// in the descriptor array matches the hidden symbol. Since the
|
420
|
+
// hidden symbols hash code is zero (and no other string has hash
|
421
|
+
// code zero) it will always occupy the first entry if present.
|
422
|
+
DescriptorArray* descriptors = obj->map()->instance_descriptors();
|
423
|
+
if ((descriptors->number_of_descriptors() > 0) &&
|
424
|
+
(descriptors->GetKey(0) == isolate->heap()->hidden_symbol()) &&
|
425
|
+
descriptors->IsProperty(0)) {
|
426
|
+
ASSERT(descriptors->GetType(0) == FIELD);
|
427
|
+
return Handle<Object>(obj->FastPropertyAt(descriptors->GetFieldIndex(0)),
|
428
|
+
isolate);
|
429
|
+
}
|
430
|
+
}
|
431
|
+
|
432
|
+
// Only attempt to find the hidden properties in the local object and not
|
433
|
+
// in the prototype chain. Note that HasLocalProperty() can cause a GC in
|
434
|
+
// the general case in the presence of interceptors.
|
435
|
+
if (!obj->HasHiddenPropertiesObject()) {
|
436
|
+
// Hidden properties object not found. Allocate a new hidden properties
|
437
|
+
// object if requested. Otherwise return the undefined value.
|
438
|
+
if (create_if_needed) {
|
439
|
+
Handle<Object> hidden_obj =
|
440
|
+
isolate->factory()->NewJSObject(isolate->object_function());
|
441
|
+
CALL_HEAP_FUNCTION(isolate,
|
442
|
+
obj->SetHiddenPropertiesObject(*hidden_obj), Object);
|
443
|
+
} else {
|
444
|
+
return isolate->factory()->undefined_value();
|
445
|
+
}
|
446
|
+
}
|
447
|
+
return Handle<Object>(obj->GetHiddenPropertiesObject(), isolate);
|
448
|
+
}
|
449
|
+
|
450
|
+
|
451
|
+
Handle<Object> DeleteElement(Handle<JSObject> obj,
|
452
|
+
uint32_t index) {
|
453
|
+
CALL_HEAP_FUNCTION(obj->GetIsolate(),
|
454
|
+
obj->DeleteElement(index, JSObject::NORMAL_DELETION),
|
455
|
+
Object);
|
456
|
+
}
|
457
|
+
|
458
|
+
|
459
|
+
Handle<Object> DeleteProperty(Handle<JSObject> obj,
|
460
|
+
Handle<String> prop) {
|
461
|
+
CALL_HEAP_FUNCTION(obj->GetIsolate(),
|
462
|
+
obj->DeleteProperty(*prop, JSObject::NORMAL_DELETION),
|
463
|
+
Object);
|
464
|
+
}
|
465
|
+
|
466
|
+
|
467
|
+
Handle<Object> LookupSingleCharacterStringFromCode(uint32_t index) {
|
468
|
+
Isolate* isolate = Isolate::Current();
|
469
|
+
CALL_HEAP_FUNCTION(
|
470
|
+
isolate,
|
471
|
+
isolate->heap()->LookupSingleCharacterStringFromCode(index), Object);
|
472
|
+
}
|
473
|
+
|
474
|
+
|
475
|
+
Handle<String> SubString(Handle<String> str,
|
476
|
+
int start,
|
477
|
+
int end,
|
478
|
+
PretenureFlag pretenure) {
|
479
|
+
CALL_HEAP_FUNCTION(str->GetIsolate(),
|
480
|
+
str->SubString(start, end, pretenure), String);
|
481
|
+
}
|
482
|
+
|
483
|
+
|
484
|
+
Handle<Object> SetElement(Handle<JSObject> object,
|
485
|
+
uint32_t index,
|
486
|
+
Handle<Object> value,
|
487
|
+
StrictModeFlag strict_mode) {
|
488
|
+
if (object->HasExternalArrayElements()) {
|
489
|
+
if (!value->IsSmi() && !value->IsHeapNumber() && !value->IsUndefined()) {
|
490
|
+
bool has_exception;
|
491
|
+
Handle<Object> number = Execution::ToNumber(value, &has_exception);
|
492
|
+
if (has_exception) return Handle<Object>();
|
493
|
+
value = number;
|
494
|
+
}
|
495
|
+
}
|
496
|
+
CALL_HEAP_FUNCTION(object->GetIsolate(),
|
497
|
+
object->SetElement(index, *value, strict_mode), Object);
|
498
|
+
}
|
499
|
+
|
500
|
+
|
501
|
+
Handle<Object> SetOwnElement(Handle<JSObject> object,
|
502
|
+
uint32_t index,
|
503
|
+
Handle<Object> value,
|
504
|
+
StrictModeFlag strict_mode) {
|
505
|
+
ASSERT(!object->HasExternalArrayElements());
|
506
|
+
CALL_HEAP_FUNCTION(object->GetIsolate(),
|
507
|
+
object->SetElement(index, *value, strict_mode, false),
|
508
|
+
Object);
|
509
|
+
}
|
510
|
+
|
511
|
+
|
512
|
+
Handle<JSObject> Copy(Handle<JSObject> obj) {
|
513
|
+
Isolate* isolate = obj->GetIsolate();
|
514
|
+
CALL_HEAP_FUNCTION(isolate,
|
515
|
+
isolate->heap()->CopyJSObject(*obj), JSObject);
|
516
|
+
}
|
517
|
+
|
518
|
+
|
519
|
+
Handle<Object> SetAccessor(Handle<JSObject> obj, Handle<AccessorInfo> info) {
|
520
|
+
CALL_HEAP_FUNCTION(obj->GetIsolate(), obj->DefineAccessor(*info), Object);
|
521
|
+
}
|
522
|
+
|
523
|
+
|
524
|
+
// Wrappers for scripts are kept alive and cached in weak global
|
525
|
+
// handles referred from proxy objects held by the scripts as long as
|
526
|
+
// they are used. When they are not used anymore, the garbage
|
527
|
+
// collector will call the weak callback on the global handle
|
528
|
+
// associated with the wrapper and get rid of both the wrapper and the
|
529
|
+
// handle.
|
530
|
+
static void ClearWrapperCache(Persistent<v8::Value> handle, void*) {
|
531
|
+
#ifdef ENABLE_HEAP_PROTECTION
|
532
|
+
// Weak reference callbacks are called as if from outside V8. We
|
533
|
+
// need to reeenter to unprotect the heap.
|
534
|
+
VMState state(OTHER);
|
535
|
+
#endif
|
536
|
+
Handle<Object> cache = Utils::OpenHandle(*handle);
|
537
|
+
JSValue* wrapper = JSValue::cast(*cache);
|
538
|
+
Proxy* proxy = Script::cast(wrapper->value())->wrapper();
|
539
|
+
ASSERT(proxy->proxy() == reinterpret_cast<Address>(cache.location()));
|
540
|
+
proxy->set_proxy(0);
|
541
|
+
Isolate* isolate = Isolate::Current();
|
542
|
+
isolate->global_handles()->Destroy(cache.location());
|
543
|
+
isolate->counters()->script_wrappers()->Decrement();
|
544
|
+
}
|
545
|
+
|
546
|
+
|
547
|
+
Handle<JSValue> GetScriptWrapper(Handle<Script> script) {
|
548
|
+
if (script->wrapper()->proxy() != NULL) {
|
549
|
+
// Return the script wrapper directly from the cache.
|
550
|
+
return Handle<JSValue>(
|
551
|
+
reinterpret_cast<JSValue**>(script->wrapper()->proxy()));
|
552
|
+
}
|
553
|
+
Isolate* isolate = Isolate::Current();
|
554
|
+
// Construct a new script wrapper.
|
555
|
+
isolate->counters()->script_wrappers()->Increment();
|
556
|
+
Handle<JSFunction> constructor = isolate->script_function();
|
557
|
+
Handle<JSValue> result =
|
558
|
+
Handle<JSValue>::cast(isolate->factory()->NewJSObject(constructor));
|
559
|
+
result->set_value(*script);
|
560
|
+
|
561
|
+
// Create a new weak global handle and use it to cache the wrapper
|
562
|
+
// for future use. The cache will automatically be cleared by the
|
563
|
+
// garbage collector when it is not used anymore.
|
564
|
+
Handle<Object> handle = isolate->global_handles()->Create(*result);
|
565
|
+
isolate->global_handles()->MakeWeak(handle.location(), NULL,
|
566
|
+
&ClearWrapperCache);
|
567
|
+
script->wrapper()->set_proxy(reinterpret_cast<Address>(handle.location()));
|
568
|
+
return result;
|
569
|
+
}
|
570
|
+
|
571
|
+
|
572
|
+
// Init line_ends array with code positions of line ends inside script
|
573
|
+
// source.
|
574
|
+
void InitScriptLineEnds(Handle<Script> script) {
|
575
|
+
if (!script->line_ends()->IsUndefined()) return;
|
576
|
+
|
577
|
+
Isolate* isolate = script->GetIsolate();
|
578
|
+
|
579
|
+
if (!script->source()->IsString()) {
|
580
|
+
ASSERT(script->source()->IsUndefined());
|
581
|
+
Handle<FixedArray> empty = isolate->factory()->NewFixedArray(0);
|
582
|
+
script->set_line_ends(*empty);
|
583
|
+
ASSERT(script->line_ends()->IsFixedArray());
|
584
|
+
return;
|
585
|
+
}
|
586
|
+
|
587
|
+
Handle<String> src(String::cast(script->source()), isolate);
|
588
|
+
|
589
|
+
Handle<FixedArray> array = CalculateLineEnds(src, true);
|
590
|
+
|
591
|
+
if (*array != isolate->heap()->empty_fixed_array()) {
|
592
|
+
array->set_map(isolate->heap()->fixed_cow_array_map());
|
593
|
+
}
|
594
|
+
|
595
|
+
script->set_line_ends(*array);
|
596
|
+
ASSERT(script->line_ends()->IsFixedArray());
|
597
|
+
}
|
598
|
+
|
599
|
+
|
600
|
+
template <typename SourceChar>
|
601
|
+
static void CalculateLineEnds(Isolate* isolate,
|
602
|
+
List<int>* line_ends,
|
603
|
+
Vector<const SourceChar> src,
|
604
|
+
bool with_last_line) {
|
605
|
+
const int src_len = src.length();
|
606
|
+
StringSearch<char, SourceChar> search(isolate, CStrVector("\n"));
|
607
|
+
|
608
|
+
// Find and record line ends.
|
609
|
+
int position = 0;
|
610
|
+
while (position != -1 && position < src_len) {
|
611
|
+
position = search.Search(src, position);
|
612
|
+
if (position != -1) {
|
613
|
+
line_ends->Add(position);
|
614
|
+
position++;
|
615
|
+
} else if (with_last_line) {
|
616
|
+
// Even if the last line misses a line end, it is counted.
|
617
|
+
line_ends->Add(src_len);
|
618
|
+
return;
|
619
|
+
}
|
620
|
+
}
|
621
|
+
}
|
622
|
+
|
623
|
+
|
624
|
+
Handle<FixedArray> CalculateLineEnds(Handle<String> src,
|
625
|
+
bool with_last_line) {
|
626
|
+
src = FlattenGetString(src);
|
627
|
+
// Rough estimate of line count based on a roughly estimated average
|
628
|
+
// length of (unpacked) code.
|
629
|
+
int line_count_estimate = src->length() >> 4;
|
630
|
+
List<int> line_ends(line_count_estimate);
|
631
|
+
Isolate* isolate = src->GetIsolate();
|
632
|
+
{
|
633
|
+
AssertNoAllocation no_heap_allocation; // ensure vectors stay valid.
|
634
|
+
// Dispatch on type of strings.
|
635
|
+
if (src->IsAsciiRepresentation()) {
|
636
|
+
CalculateLineEnds(isolate,
|
637
|
+
&line_ends,
|
638
|
+
src->ToAsciiVector(),
|
639
|
+
with_last_line);
|
640
|
+
} else {
|
641
|
+
CalculateLineEnds(isolate,
|
642
|
+
&line_ends,
|
643
|
+
src->ToUC16Vector(),
|
644
|
+
with_last_line);
|
645
|
+
}
|
646
|
+
}
|
647
|
+
int line_count = line_ends.length();
|
648
|
+
Handle<FixedArray> array = isolate->factory()->NewFixedArray(line_count);
|
649
|
+
for (int i = 0; i < line_count; i++) {
|
650
|
+
array->set(i, Smi::FromInt(line_ends[i]));
|
651
|
+
}
|
652
|
+
return array;
|
653
|
+
}
|
654
|
+
|
655
|
+
|
656
|
+
// Convert code position into line number.
|
657
|
+
int GetScriptLineNumber(Handle<Script> script, int code_pos) {
|
658
|
+
InitScriptLineEnds(script);
|
659
|
+
AssertNoAllocation no_allocation;
|
660
|
+
FixedArray* line_ends_array = FixedArray::cast(script->line_ends());
|
661
|
+
const int line_ends_len = line_ends_array->length();
|
662
|
+
|
663
|
+
if (!line_ends_len) return -1;
|
664
|
+
|
665
|
+
if ((Smi::cast(line_ends_array->get(0)))->value() >= code_pos) {
|
666
|
+
return script->line_offset()->value();
|
667
|
+
}
|
668
|
+
|
669
|
+
int left = 0;
|
670
|
+
int right = line_ends_len;
|
671
|
+
while (int half = (right - left) / 2) {
|
672
|
+
if ((Smi::cast(line_ends_array->get(left + half)))->value() > code_pos) {
|
673
|
+
right -= half;
|
674
|
+
} else {
|
675
|
+
left += half;
|
676
|
+
}
|
677
|
+
}
|
678
|
+
return right + script->line_offset()->value();
|
679
|
+
}
|
680
|
+
|
681
|
+
|
682
|
+
int GetScriptLineNumberSafe(Handle<Script> script, int code_pos) {
|
683
|
+
AssertNoAllocation no_allocation;
|
684
|
+
if (!script->line_ends()->IsUndefined()) {
|
685
|
+
return GetScriptLineNumber(script, code_pos);
|
686
|
+
}
|
687
|
+
// Slow mode: we do not have line_ends. We have to iterate through source.
|
688
|
+
if (!script->source()->IsString()) {
|
689
|
+
return -1;
|
690
|
+
}
|
691
|
+
String* source = String::cast(script->source());
|
692
|
+
int line = 0;
|
693
|
+
int len = source->length();
|
694
|
+
for (int pos = 0; pos < len; pos++) {
|
695
|
+
if (pos == code_pos) {
|
696
|
+
break;
|
697
|
+
}
|
698
|
+
if (source->Get(pos) == '\n') {
|
699
|
+
line++;
|
700
|
+
}
|
701
|
+
}
|
702
|
+
return line;
|
703
|
+
}
|
704
|
+
|
705
|
+
|
706
|
+
void CustomArguments::IterateInstance(ObjectVisitor* v) {
|
707
|
+
v->VisitPointers(values_, values_ + ARRAY_SIZE(values_));
|
708
|
+
}
|
709
|
+
|
710
|
+
|
711
|
+
// Compute the property keys from the interceptor.
|
712
|
+
v8::Handle<v8::Array> GetKeysForNamedInterceptor(Handle<JSObject> receiver,
|
713
|
+
Handle<JSObject> object) {
|
714
|
+
Isolate* isolate = receiver->GetIsolate();
|
715
|
+
Handle<InterceptorInfo> interceptor(object->GetNamedInterceptor());
|
716
|
+
CustomArguments args(isolate, interceptor->data(), *receiver, *object);
|
717
|
+
v8::AccessorInfo info(args.end());
|
718
|
+
v8::Handle<v8::Array> result;
|
719
|
+
if (!interceptor->enumerator()->IsUndefined()) {
|
720
|
+
v8::NamedPropertyEnumerator enum_fun =
|
721
|
+
v8::ToCData<v8::NamedPropertyEnumerator>(interceptor->enumerator());
|
722
|
+
LOG(isolate, ApiObjectAccess("interceptor-named-enum", *object));
|
723
|
+
{
|
724
|
+
// Leaving JavaScript.
|
725
|
+
VMState state(isolate, EXTERNAL);
|
726
|
+
result = enum_fun(info);
|
727
|
+
}
|
728
|
+
}
|
729
|
+
return result;
|
730
|
+
}
|
731
|
+
|
732
|
+
|
733
|
+
// Compute the element keys from the interceptor.
|
734
|
+
v8::Handle<v8::Array> GetKeysForIndexedInterceptor(Handle<JSObject> receiver,
|
735
|
+
Handle<JSObject> object) {
|
736
|
+
Isolate* isolate = receiver->GetIsolate();
|
737
|
+
Handle<InterceptorInfo> interceptor(object->GetIndexedInterceptor());
|
738
|
+
CustomArguments args(isolate, interceptor->data(), *receiver, *object);
|
739
|
+
v8::AccessorInfo info(args.end());
|
740
|
+
v8::Handle<v8::Array> result;
|
741
|
+
if (!interceptor->enumerator()->IsUndefined()) {
|
742
|
+
v8::IndexedPropertyEnumerator enum_fun =
|
743
|
+
v8::ToCData<v8::IndexedPropertyEnumerator>(interceptor->enumerator());
|
744
|
+
LOG(isolate, ApiObjectAccess("interceptor-indexed-enum", *object));
|
745
|
+
{
|
746
|
+
// Leaving JavaScript.
|
747
|
+
VMState state(isolate, EXTERNAL);
|
748
|
+
result = enum_fun(info);
|
749
|
+
}
|
750
|
+
}
|
751
|
+
return result;
|
752
|
+
}
|
753
|
+
|
754
|
+
|
755
|
+
static bool ContainsOnlyValidKeys(Handle<FixedArray> array) {
|
756
|
+
int len = array->length();
|
757
|
+
for (int i = 0; i < len; i++) {
|
758
|
+
Object* e = array->get(i);
|
759
|
+
if (!(e->IsString() || e->IsNumber())) return false;
|
760
|
+
}
|
761
|
+
return true;
|
762
|
+
}
|
763
|
+
|
764
|
+
|
765
|
+
Handle<FixedArray> GetKeysInFixedArrayFor(Handle<JSObject> object,
|
766
|
+
KeyCollectionType type) {
|
767
|
+
USE(ContainsOnlyValidKeys);
|
768
|
+
Isolate* isolate = object->GetIsolate();
|
769
|
+
Handle<FixedArray> content = isolate->factory()->empty_fixed_array();
|
770
|
+
Handle<JSObject> arguments_boilerplate = Handle<JSObject>(
|
771
|
+
isolate->context()->global_context()->arguments_boilerplate(),
|
772
|
+
isolate);
|
773
|
+
Handle<JSFunction> arguments_function = Handle<JSFunction>(
|
774
|
+
JSFunction::cast(arguments_boilerplate->map()->constructor()),
|
775
|
+
isolate);
|
776
|
+
|
777
|
+
// Only collect keys if access is permitted.
|
778
|
+
for (Handle<Object> p = object;
|
779
|
+
*p != isolate->heap()->null_value();
|
780
|
+
p = Handle<Object>(p->GetPrototype(), isolate)) {
|
781
|
+
Handle<JSObject> current(JSObject::cast(*p), isolate);
|
782
|
+
|
783
|
+
// Check access rights if required.
|
784
|
+
if (current->IsAccessCheckNeeded() &&
|
785
|
+
!isolate->MayNamedAccess(*current,
|
786
|
+
isolate->heap()->undefined_value(),
|
787
|
+
v8::ACCESS_KEYS)) {
|
788
|
+
isolate->ReportFailedAccessCheck(*current, v8::ACCESS_KEYS);
|
789
|
+
break;
|
790
|
+
}
|
791
|
+
|
792
|
+
// Compute the element keys.
|
793
|
+
Handle<FixedArray> element_keys =
|
794
|
+
isolate->factory()->NewFixedArray(current->NumberOfEnumElements());
|
795
|
+
current->GetEnumElementKeys(*element_keys);
|
796
|
+
content = UnionOfKeys(content, element_keys);
|
797
|
+
ASSERT(ContainsOnlyValidKeys(content));
|
798
|
+
|
799
|
+
// Add the element keys from the interceptor.
|
800
|
+
if (current->HasIndexedInterceptor()) {
|
801
|
+
v8::Handle<v8::Array> result =
|
802
|
+
GetKeysForIndexedInterceptor(object, current);
|
803
|
+
if (!result.IsEmpty())
|
804
|
+
content = AddKeysFromJSArray(content, v8::Utils::OpenHandle(*result));
|
805
|
+
ASSERT(ContainsOnlyValidKeys(content));
|
806
|
+
}
|
807
|
+
|
808
|
+
// We can cache the computed property keys if access checks are
|
809
|
+
// not needed and no interceptors are involved.
|
810
|
+
//
|
811
|
+
// We do not use the cache if the object has elements and
|
812
|
+
// therefore it does not make sense to cache the property names
|
813
|
+
// for arguments objects. Arguments objects will always have
|
814
|
+
// elements.
|
815
|
+
// Wrapped strings have elements, but don't have an elements
|
816
|
+
// array or dictionary. So the fast inline test for whether to
|
817
|
+
// use the cache says yes, so we should not create a cache.
|
818
|
+
bool cache_enum_keys =
|
819
|
+
((current->map()->constructor() != *arguments_function) &&
|
820
|
+
!current->IsJSValue() &&
|
821
|
+
!current->IsAccessCheckNeeded() &&
|
822
|
+
!current->HasNamedInterceptor() &&
|
823
|
+
!current->HasIndexedInterceptor());
|
824
|
+
// Compute the property keys and cache them if possible.
|
825
|
+
content =
|
826
|
+
UnionOfKeys(content, GetEnumPropertyKeys(current, cache_enum_keys));
|
827
|
+
ASSERT(ContainsOnlyValidKeys(content));
|
828
|
+
|
829
|
+
// Add the property keys from the interceptor.
|
830
|
+
if (current->HasNamedInterceptor()) {
|
831
|
+
v8::Handle<v8::Array> result =
|
832
|
+
GetKeysForNamedInterceptor(object, current);
|
833
|
+
if (!result.IsEmpty())
|
834
|
+
content = AddKeysFromJSArray(content, v8::Utils::OpenHandle(*result));
|
835
|
+
ASSERT(ContainsOnlyValidKeys(content));
|
836
|
+
}
|
837
|
+
|
838
|
+
// If we only want local properties we bail out after the first
|
839
|
+
// iteration.
|
840
|
+
if (type == LOCAL_ONLY)
|
841
|
+
break;
|
842
|
+
}
|
843
|
+
return content;
|
844
|
+
}
|
845
|
+
|
846
|
+
|
847
|
+
Handle<JSArray> GetKeysFor(Handle<JSObject> object) {
|
848
|
+
Isolate* isolate = object->GetIsolate();
|
849
|
+
isolate->counters()->for_in()->Increment();
|
850
|
+
Handle<FixedArray> elements = GetKeysInFixedArrayFor(object,
|
851
|
+
INCLUDE_PROTOS);
|
852
|
+
return isolate->factory()->NewJSArrayWithElements(elements);
|
853
|
+
}
|
854
|
+
|
855
|
+
|
856
|
+
Handle<FixedArray> GetEnumPropertyKeys(Handle<JSObject> object,
|
857
|
+
bool cache_result) {
|
858
|
+
int index = 0;
|
859
|
+
Isolate* isolate = object->GetIsolate();
|
860
|
+
if (object->HasFastProperties()) {
|
861
|
+
if (object->map()->instance_descriptors()->HasEnumCache()) {
|
862
|
+
isolate->counters()->enum_cache_hits()->Increment();
|
863
|
+
DescriptorArray* desc = object->map()->instance_descriptors();
|
864
|
+
return Handle<FixedArray>(FixedArray::cast(desc->GetEnumCache()),
|
865
|
+
isolate);
|
866
|
+
}
|
867
|
+
isolate->counters()->enum_cache_misses()->Increment();
|
868
|
+
int num_enum = object->NumberOfEnumProperties();
|
869
|
+
Handle<FixedArray> storage = isolate->factory()->NewFixedArray(num_enum);
|
870
|
+
Handle<FixedArray> sort_array = isolate->factory()->NewFixedArray(num_enum);
|
871
|
+
Handle<DescriptorArray> descs =
|
872
|
+
Handle<DescriptorArray>(object->map()->instance_descriptors(), isolate);
|
873
|
+
for (int i = 0; i < descs->number_of_descriptors(); i++) {
|
874
|
+
if (descs->IsProperty(i) && !descs->IsDontEnum(i)) {
|
875
|
+
(*storage)->set(index, descs->GetKey(i));
|
876
|
+
PropertyDetails details(descs->GetDetails(i));
|
877
|
+
(*sort_array)->set(index, Smi::FromInt(details.index()));
|
878
|
+
index++;
|
879
|
+
}
|
880
|
+
}
|
881
|
+
(*storage)->SortPairs(*sort_array, sort_array->length());
|
882
|
+
if (cache_result) {
|
883
|
+
Handle<FixedArray> bridge_storage =
|
884
|
+
isolate->factory()->NewFixedArray(
|
885
|
+
DescriptorArray::kEnumCacheBridgeLength);
|
886
|
+
DescriptorArray* desc = object->map()->instance_descriptors();
|
887
|
+
desc->SetEnumCache(*bridge_storage, *storage);
|
888
|
+
}
|
889
|
+
ASSERT(storage->length() == index);
|
890
|
+
return storage;
|
891
|
+
} else {
|
892
|
+
int num_enum = object->NumberOfEnumProperties();
|
893
|
+
Handle<FixedArray> storage = isolate->factory()->NewFixedArray(num_enum);
|
894
|
+
Handle<FixedArray> sort_array = isolate->factory()->NewFixedArray(num_enum);
|
895
|
+
object->property_dictionary()->CopyEnumKeysTo(*storage, *sort_array);
|
896
|
+
return storage;
|
897
|
+
}
|
898
|
+
}
|
899
|
+
|
900
|
+
|
901
|
+
bool EnsureCompiled(Handle<SharedFunctionInfo> shared,
|
902
|
+
ClearExceptionFlag flag) {
|
903
|
+
return shared->is_compiled() || CompileLazyShared(shared, flag);
|
904
|
+
}
|
905
|
+
|
906
|
+
|
907
|
+
static bool CompileLazyHelper(CompilationInfo* info,
|
908
|
+
ClearExceptionFlag flag) {
|
909
|
+
// Compile the source information to a code object.
|
910
|
+
ASSERT(info->IsOptimizing() || !info->shared_info()->is_compiled());
|
911
|
+
ASSERT(!info->isolate()->has_pending_exception());
|
912
|
+
bool result = Compiler::CompileLazy(info);
|
913
|
+
ASSERT(result != Isolate::Current()->has_pending_exception());
|
914
|
+
if (!result && flag == CLEAR_EXCEPTION) {
|
915
|
+
info->isolate()->clear_pending_exception();
|
916
|
+
}
|
917
|
+
return result;
|
918
|
+
}
|
919
|
+
|
920
|
+
|
921
|
+
bool CompileLazyShared(Handle<SharedFunctionInfo> shared,
|
922
|
+
ClearExceptionFlag flag) {
|
923
|
+
CompilationInfo info(shared);
|
924
|
+
return CompileLazyHelper(&info, flag);
|
925
|
+
}
|
926
|
+
|
927
|
+
|
928
|
+
static bool CompileLazyFunction(Handle<JSFunction> function,
|
929
|
+
ClearExceptionFlag flag,
|
930
|
+
InLoopFlag in_loop_flag) {
|
931
|
+
bool result = true;
|
932
|
+
if (function->shared()->is_compiled()) {
|
933
|
+
function->ReplaceCode(function->shared()->code());
|
934
|
+
function->shared()->set_code_age(0);
|
935
|
+
} else {
|
936
|
+
CompilationInfo info(function);
|
937
|
+
if (in_loop_flag == IN_LOOP) info.MarkAsInLoop();
|
938
|
+
result = CompileLazyHelper(&info, flag);
|
939
|
+
ASSERT(!result || function->is_compiled());
|
940
|
+
}
|
941
|
+
return result;
|
942
|
+
}
|
943
|
+
|
944
|
+
|
945
|
+
bool CompileLazy(Handle<JSFunction> function,
|
946
|
+
ClearExceptionFlag flag) {
|
947
|
+
return CompileLazyFunction(function, flag, NOT_IN_LOOP);
|
948
|
+
}
|
949
|
+
|
950
|
+
|
951
|
+
bool CompileLazyInLoop(Handle<JSFunction> function,
|
952
|
+
ClearExceptionFlag flag) {
|
953
|
+
return CompileLazyFunction(function, flag, IN_LOOP);
|
954
|
+
}
|
955
|
+
|
956
|
+
|
957
|
+
bool CompileOptimized(Handle<JSFunction> function,
|
958
|
+
int osr_ast_id,
|
959
|
+
ClearExceptionFlag flag) {
|
960
|
+
CompilationInfo info(function);
|
961
|
+
info.SetOptimizing(osr_ast_id);
|
962
|
+
return CompileLazyHelper(&info, flag);
|
963
|
+
}
|
964
|
+
|
965
|
+
} } // namespace v8::internal
|