therubyracer 0.8.1.pre2 → 0.8.1
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/Changelog.md +2 -1
- data/README.md +6 -3
- data/ext/v8/upstream/3.1.8/.gitignore +31 -0
- data/ext/v8/upstream/3.1.8/AUTHORS +40 -0
- data/ext/v8/upstream/3.1.8/ChangeLog +2566 -0
- data/ext/v8/upstream/3.1.8/LICENSE +52 -0
- data/ext/v8/upstream/3.1.8/LICENSE.strongtalk +29 -0
- data/ext/v8/upstream/3.1.8/LICENSE.v8 +26 -0
- data/ext/v8/upstream/3.1.8/LICENSE.valgrind +45 -0
- data/ext/v8/upstream/3.1.8/SConstruct +1192 -0
- data/ext/v8/upstream/3.1.8/build/README.txt +25 -0
- data/ext/v8/upstream/3.1.8/build/all.gyp +18 -0
- data/ext/v8/upstream/3.1.8/build/armu.gypi +32 -0
- data/ext/v8/upstream/3.1.8/build/common.gypi +82 -0
- data/ext/v8/upstream/3.1.8/build/gyp_v8 +145 -0
- data/ext/v8/upstream/3.1.8/include/v8-debug.h +384 -0
- data/ext/v8/upstream/3.1.8/include/v8-preparser.h +116 -0
- data/ext/v8/upstream/3.1.8/include/v8-profiler.h +426 -0
- data/ext/v8/upstream/3.1.8/include/v8-testing.h +99 -0
- data/ext/v8/upstream/3.1.8/include/v8.h +3846 -0
- data/ext/v8/upstream/3.1.8/include/v8stdint.h +53 -0
- data/ext/v8/upstream/3.1.8/preparser/preparser-process.cc +206 -0
- data/ext/v8/upstream/3.1.8/src/SConscript +356 -0
- data/ext/v8/upstream/3.1.8/src/accessors.cc +907 -0
- data/ext/v8/upstream/3.1.8/src/accessors.h +121 -0
- data/ext/v8/upstream/3.1.8/src/allocation.cc +204 -0
- data/ext/v8/upstream/3.1.8/src/allocation.h +176 -0
- data/ext/v8/upstream/3.1.8/src/api.cc +5191 -0
- data/ext/v8/upstream/3.1.8/src/api.h +508 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/apinatives.js +0 -0
- data/ext/v8/upstream/3.1.8/src/apiutils.h +80 -0
- data/ext/v8/upstream/3.1.8/src/arguments.h +105 -0
- data/ext/v8/upstream/3.1.8/src/arm/assembler-arm-inl.h +352 -0
- data/ext/v8/upstream/3.1.8/src/arm/assembler-arm.cc +2756 -0
- data/ext/v8/upstream/3.1.8/src/arm/assembler-arm.h +1294 -0
- data/ext/v8/upstream/3.1.8/src/arm/builtins-arm.cc +1628 -0
- data/ext/v8/upstream/3.1.8/src/arm/code-stubs-arm.cc +6783 -0
- data/ext/v8/upstream/3.1.8/src/arm/code-stubs-arm.h +657 -0
- data/ext/v8/upstream/3.1.8/src/arm/codegen-arm-inl.h +48 -0
- data/ext/v8/upstream/3.1.8/src/arm/codegen-arm.cc +7403 -0
- data/ext/v8/upstream/3.1.8/src/arm/codegen-arm.h +595 -0
- data/ext/v8/upstream/3.1.8/src/arm/constants-arm.cc +152 -0
- data/ext/v8/upstream/3.1.8/src/arm/constants-arm.h +769 -0
- data/ext/v8/upstream/3.1.8/src/arm/cpu-arm.cc +147 -0
- data/ext/v8/upstream/3.1.8/src/arm/debug-arm.cc +315 -0
- data/ext/v8/upstream/3.1.8/src/arm/deoptimizer-arm.cc +700 -0
- data/ext/v8/upstream/3.1.8/src/arm/disasm-arm.cc +1439 -0
- data/ext/v8/upstream/3.1.8/src/arm/frames-arm.cc +45 -0
- data/ext/v8/upstream/3.1.8/src/arm/frames-arm.h +168 -0
- data/ext/v8/upstream/3.1.8/src/arm/full-codegen-arm.cc +4230 -0
- data/ext/v8/upstream/3.1.8/src/arm/ic-arm.cc +1799 -0
- data/ext/v8/upstream/3.1.8/src/arm/jump-target-arm.cc +174 -0
- data/ext/v8/upstream/3.1.8/src/arm/lithium-arm.cc +2041 -0
- data/ext/v8/upstream/3.1.8/src/arm/lithium-arm.h +2046 -0
- data/ext/v8/upstream/3.1.8/src/arm/lithium-codegen-arm.cc +3822 -0
- data/ext/v8/upstream/3.1.8/src/arm/lithium-codegen-arm.h +312 -0
- data/ext/v8/upstream/3.1.8/src/arm/lithium-gap-resolver-arm.cc +303 -0
- data/ext/v8/upstream/3.1.8/src/arm/lithium-gap-resolver-arm.h +84 -0
- data/ext/v8/upstream/3.1.8/src/arm/macro-assembler-arm.cc +2701 -0
- data/ext/v8/upstream/3.1.8/src/arm/macro-assembler-arm.h +1015 -0
- data/ext/v8/upstream/3.1.8/src/arm/regexp-macro-assembler-arm.cc +1280 -0
- data/ext/v8/upstream/3.1.8/src/arm/regexp-macro-assembler-arm.h +252 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/arm/register-allocator-arm-inl.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/arm/register-allocator-arm.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/arm/register-allocator-arm.h +0 -0
- data/ext/v8/upstream/3.1.8/src/arm/simulator-arm.cc +3165 -0
- data/ext/v8/upstream/3.1.8/src/arm/simulator-arm.h +402 -0
- data/ext/v8/upstream/3.1.8/src/arm/stub-cache-arm.cc +4077 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/arm/virtual-frame-arm-inl.h +0 -0
- data/ext/v8/upstream/3.1.8/src/arm/virtual-frame-arm.cc +843 -0
- data/ext/v8/upstream/3.1.8/src/arm/virtual-frame-arm.h +520 -0
- data/ext/v8/upstream/3.1.8/src/array.js +1231 -0
- data/ext/v8/upstream/3.1.8/src/assembler.cc +973 -0
- data/ext/v8/upstream/3.1.8/src/assembler.h +787 -0
- data/ext/v8/upstream/3.1.8/src/ast-inl.h +107 -0
- data/ext/v8/upstream/3.1.8/src/ast.cc +1067 -0
- data/ext/v8/upstream/3.1.8/src/ast.h +2177 -0
- data/ext/v8/upstream/3.1.8/src/atomicops.h +165 -0
- data/ext/v8/upstream/3.1.8/src/atomicops_internals_arm_gcc.h +145 -0
- data/ext/v8/upstream/3.1.8/src/atomicops_internals_x86_gcc.cc +126 -0
- data/ext/v8/upstream/3.1.8/src/atomicops_internals_x86_gcc.h +287 -0
- data/ext/v8/upstream/3.1.8/src/atomicops_internals_x86_macosx.h +301 -0
- data/ext/v8/upstream/3.1.8/src/atomicops_internals_x86_msvc.h +203 -0
- data/ext/v8/upstream/3.1.8/src/bignum-dtoa.cc +655 -0
- data/ext/v8/upstream/3.1.8/src/bignum-dtoa.h +81 -0
- data/ext/v8/upstream/3.1.8/src/bignum.cc +768 -0
- data/ext/v8/upstream/3.1.8/src/bignum.h +140 -0
- data/ext/v8/upstream/3.1.8/src/bootstrapper.cc +1888 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/bootstrapper.h +0 -0
- data/ext/v8/upstream/3.1.8/src/builtins.cc +1586 -0
- data/ext/v8/upstream/3.1.8/src/builtins.h +339 -0
- data/ext/v8/upstream/3.1.8/src/bytecodes-irregexp.h +105 -0
- data/ext/v8/upstream/3.1.8/src/cached-powers.cc +177 -0
- data/ext/v8/upstream/3.1.8/src/cached-powers.h +65 -0
- data/ext/v8/upstream/3.1.8/src/char-predicates-inl.h +94 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/char-predicates.h +0 -0
- data/ext/v8/upstream/3.1.8/src/checks.cc +110 -0
- data/ext/v8/upstream/3.1.8/src/checks.h +292 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/circular-queue-inl.h +0 -0
- data/ext/v8/upstream/3.1.8/src/circular-queue.cc +122 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/circular-queue.h +0 -0
- data/ext/v8/upstream/3.1.8/src/code-stubs.cc +230 -0
- data/ext/v8/upstream/3.1.8/src/code-stubs.h +950 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/code.h +0 -0
- data/ext/v8/upstream/3.1.8/src/codegen-inl.h +64 -0
- data/ext/v8/upstream/3.1.8/src/codegen.cc +495 -0
- data/ext/v8/upstream/3.1.8/src/codegen.h +245 -0
- data/ext/v8/upstream/3.1.8/src/compilation-cache.cc +654 -0
- data/ext/v8/upstream/3.1.8/src/compilation-cache.h +112 -0
- data/ext/v8/upstream/3.1.8/src/compiler.cc +806 -0
- data/ext/v8/upstream/3.1.8/src/compiler.h +290 -0
- data/ext/v8/upstream/3.1.8/src/contexts.cc +320 -0
- data/ext/v8/upstream/3.1.8/src/contexts.h +376 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/conversions-inl.h +0 -0
- data/ext/v8/upstream/3.1.8/src/conversions.cc +1069 -0
- data/ext/v8/upstream/3.1.8/src/conversions.h +122 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/counters.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/counters.h +242 -0
- data/ext/v8/upstream/3.1.8/src/cpu-profiler-inl.h +100 -0
- data/ext/v8/upstream/3.1.8/src/cpu-profiler.cc +554 -0
- data/ext/v8/upstream/3.1.8/src/cpu-profiler.h +291 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/cpu.h +0 -0
- data/ext/v8/upstream/3.1.8/src/d8-debug.cc +367 -0
- data/ext/v8/upstream/3.1.8/src/d8-debug.h +157 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/d8-posix.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/d8-readline.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/d8-windows.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/d8.cc +792 -0
- data/ext/v8/upstream/3.1.8/src/d8.gyp +85 -0
- data/ext/v8/upstream/3.1.8/src/d8.h +231 -0
- data/ext/v8/upstream/3.1.8/src/d8.js +2798 -0
- data/ext/v8/upstream/3.1.8/src/data-flow.cc +545 -0
- data/ext/v8/upstream/3.1.8/src/data-flow.h +379 -0
- data/ext/v8/upstream/3.1.8/src/date.js +1103 -0
- data/ext/v8/upstream/3.1.8/src/dateparser-inl.h +125 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/dateparser.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/dateparser.h +263 -0
- data/ext/v8/upstream/3.1.8/src/debug-agent.cc +446 -0
- data/ext/v8/upstream/3.1.8/src/debug-agent.h +131 -0
- data/ext/v8/upstream/3.1.8/src/debug-debugger.js +2569 -0
- data/ext/v8/upstream/3.1.8/src/debug.cc +3085 -0
- data/ext/v8/upstream/3.1.8/src/debug.h +1025 -0
- data/ext/v8/upstream/3.1.8/src/deoptimizer.cc +1185 -0
- data/ext/v8/upstream/3.1.8/src/deoptimizer.h +529 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/disasm.h +0 -0
- data/ext/v8/upstream/3.1.8/src/disassembler.cc +338 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/disassembler.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/diy-fp.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/diy-fp.h +0 -0
- data/ext/v8/upstream/3.1.8/src/double.h +238 -0
- data/ext/v8/upstream/3.1.8/src/dtoa.cc +103 -0
- data/ext/v8/upstream/3.1.8/src/dtoa.h +85 -0
- data/ext/v8/upstream/3.1.8/src/execution.cc +735 -0
- data/ext/v8/upstream/3.1.8/src/execution.h +322 -0
- data/ext/v8/upstream/3.1.8/src/extensions/experimental/experimental.gyp +53 -0
- data/ext/v8/upstream/3.1.8/src/extensions/experimental/i18n-extension.cc +264 -0
- data/ext/v8/upstream/3.1.8/src/extensions/experimental/i18n-extension.h +64 -0
- data/ext/v8/upstream/3.1.8/src/extensions/externalize-string-extension.cc +141 -0
- data/ext/v8/upstream/3.1.8/src/extensions/externalize-string-extension.h +50 -0
- data/ext/v8/upstream/3.1.8/src/extensions/gc-extension.cc +58 -0
- data/ext/v8/upstream/3.1.8/src/extensions/gc-extension.h +49 -0
- data/ext/v8/upstream/3.1.8/src/factory.cc +1087 -0
- data/ext/v8/upstream/3.1.8/src/factory.h +432 -0
- data/ext/v8/upstream/3.1.8/src/fast-dtoa.cc +736 -0
- data/ext/v8/upstream/3.1.8/src/fast-dtoa.h +83 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/fixed-dtoa.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/fixed-dtoa.h +0 -0
- data/ext/v8/upstream/3.1.8/src/flag-definitions.h +552 -0
- data/ext/v8/upstream/3.1.8/src/flags.cc +551 -0
- data/ext/v8/upstream/3.1.8/src/flags.h +79 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/frame-element.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/frame-element.h +277 -0
- data/ext/v8/upstream/3.1.8/src/frames-inl.h +210 -0
- data/ext/v8/upstream/3.1.8/src/frames.cc +1232 -0
- data/ext/v8/upstream/3.1.8/src/frames.h +826 -0
- data/ext/v8/upstream/3.1.8/src/full-codegen.cc +1382 -0
- data/ext/v8/upstream/3.1.8/src/full-codegen.h +751 -0
- data/ext/v8/upstream/3.1.8/src/func-name-inferrer.cc +90 -0
- data/ext/v8/upstream/3.1.8/src/func-name-inferrer.h +111 -0
- data/ext/v8/upstream/3.1.8/src/gdb-jit.cc +1547 -0
- data/ext/v8/upstream/3.1.8/src/gdb-jit.h +138 -0
- data/ext/v8/upstream/3.1.8/src/global-handles.cc +534 -0
- data/ext/v8/upstream/3.1.8/src/global-handles.h +181 -0
- data/ext/v8/upstream/3.1.8/src/globals.h +325 -0
- data/ext/v8/upstream/3.1.8/src/handles-inl.h +80 -0
- data/ext/v8/upstream/3.1.8/src/handles.cc +910 -0
- data/ext/v8/upstream/3.1.8/src/handles.h +424 -0
- data/ext/v8/upstream/3.1.8/src/hashmap.cc +230 -0
- data/ext/v8/upstream/3.1.8/src/hashmap.h +121 -0
- data/ext/v8/upstream/3.1.8/src/heap-inl.h +587 -0
- data/ext/v8/upstream/3.1.8/src/heap-profiler.cc +1128 -0
- data/ext/v8/upstream/3.1.8/src/heap-profiler.h +381 -0
- data/ext/v8/upstream/3.1.8/src/heap.cc +5610 -0
- data/ext/v8/upstream/3.1.8/src/heap.h +2218 -0
- data/ext/v8/upstream/3.1.8/src/hydrogen-instructions.cc +1490 -0
- data/ext/v8/upstream/3.1.8/src/hydrogen-instructions.h +3493 -0
- data/ext/v8/upstream/3.1.8/src/hydrogen.cc +6056 -0
- data/ext/v8/upstream/3.1.8/src/hydrogen.h +1091 -0
- data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32-inl.h +429 -0
- data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32.cc +2800 -0
- data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32.h +1093 -0
- data/ext/v8/upstream/3.1.8/src/ia32/builtins-ia32.cc +1590 -0
- data/ext/v8/upstream/3.1.8/src/ia32/code-stubs-ia32.cc +6624 -0
- data/ext/v8/upstream/3.1.8/src/ia32/code-stubs-ia32.h +536 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/codegen-ia32-inl.h +0 -0
- data/ext/v8/upstream/3.1.8/src/ia32/codegen-ia32.cc +10354 -0
- data/ext/v8/upstream/3.1.8/src/ia32/codegen-ia32.h +798 -0
- data/ext/v8/upstream/3.1.8/src/ia32/cpu-ia32.cc +87 -0
- data/ext/v8/upstream/3.1.8/src/ia32/debug-ia32.cc +309 -0
- data/ext/v8/upstream/3.1.8/src/ia32/deoptimizer-ia32.cc +664 -0
- data/ext/v8/upstream/3.1.8/src/ia32/disasm-ia32.cc +1597 -0
- data/ext/v8/upstream/3.1.8/src/ia32/frames-ia32.cc +45 -0
- data/ext/v8/upstream/3.1.8/src/ia32/frames-ia32.h +140 -0
- data/ext/v8/upstream/3.1.8/src/ia32/full-codegen-ia32.cc +4278 -0
- data/ext/v8/upstream/3.1.8/src/ia32/ic-ia32.cc +1786 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/jump-target-ia32.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-codegen-ia32.cc +3880 -0
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-codegen-ia32.h +309 -0
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-gap-resolver-ia32.cc +460 -0
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-gap-resolver-ia32.h +110 -0
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-ia32.cc +2095 -0
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-ia32.h +2127 -0
- data/ext/v8/upstream/3.1.8/src/ia32/macro-assembler-ia32.cc +2031 -0
- data/ext/v8/upstream/3.1.8/src/ia32/macro-assembler-ia32.h +798 -0
- data/ext/v8/upstream/3.1.8/src/ia32/regexp-macro-assembler-ia32.cc +1253 -0
- data/ext/v8/upstream/3.1.8/src/ia32/regexp-macro-assembler-ia32.h +215 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/register-allocator-ia32-inl.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/register-allocator-ia32.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/register-allocator-ia32.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/simulator-ia32.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/ia32/simulator-ia32.h +72 -0
- data/ext/v8/upstream/3.1.8/src/ia32/stub-cache-ia32.cc +3732 -0
- data/ext/v8/upstream/3.1.8/src/ia32/virtual-frame-ia32.cc +1360 -0
- data/ext/v8/upstream/3.1.8/src/ia32/virtual-frame-ia32.h +646 -0
- data/ext/v8/upstream/3.1.8/src/ic-inl.h +129 -0
- data/ext/v8/upstream/3.1.8/src/ic.cc +2333 -0
- data/ext/v8/upstream/3.1.8/src/ic.h +639 -0
- data/ext/v8/upstream/3.1.8/src/inspector.cc +63 -0
- data/ext/v8/upstream/3.1.8/src/inspector.h +62 -0
- data/ext/v8/upstream/3.1.8/src/interpreter-irregexp.cc +655 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/interpreter-irregexp.h +0 -0
- data/ext/v8/upstream/3.1.8/src/json.js +342 -0
- data/ext/v8/upstream/3.1.8/src/jsregexp.cc +5340 -0
- data/ext/v8/upstream/3.1.8/src/jsregexp.h +1484 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target-heavy-inl.h +0 -0
- data/ext/v8/upstream/3.1.8/src/jump-target-heavy.cc +430 -0
- data/ext/v8/upstream/3.1.8/src/jump-target-heavy.h +244 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target-inl.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target-light-inl.h +0 -0
- data/ext/v8/upstream/3.1.8/src/jump-target-light.cc +111 -0
- data/ext/v8/upstream/3.1.8/src/jump-target-light.h +193 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target.h +0 -0
- data/ext/v8/upstream/3.1.8/src/list-inl.h +206 -0
- data/ext/v8/upstream/3.1.8/src/list.h +164 -0
- data/ext/v8/upstream/3.1.8/src/lithium-allocator-inl.h +140 -0
- data/ext/v8/upstream/3.1.8/src/lithium-allocator.cc +2093 -0
- data/ext/v8/upstream/3.1.8/src/lithium-allocator.h +644 -0
- data/ext/v8/upstream/3.1.8/src/lithium.cc +168 -0
- data/ext/v8/upstream/3.1.8/src/lithium.h +592 -0
- data/ext/v8/upstream/3.1.8/src/liveedit-debugger.js +1082 -0
- data/ext/v8/upstream/3.1.8/src/liveedit.cc +1650 -0
- data/ext/v8/upstream/3.1.8/src/liveedit.h +174 -0
- data/ext/v8/upstream/3.1.8/src/liveobjectlist-inl.h +126 -0
- data/ext/v8/upstream/3.1.8/src/liveobjectlist.cc +2527 -0
- data/ext/v8/upstream/3.1.8/src/liveobjectlist.h +322 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/log-inl.h +0 -0
- data/ext/v8/upstream/3.1.8/src/log-utils.cc +336 -0
- data/ext/v8/upstream/3.1.8/src/log-utils.h +232 -0
- data/ext/v8/upstream/3.1.8/src/log.cc +1608 -0
- data/ext/v8/upstream/3.1.8/src/log.h +379 -0
- data/ext/v8/upstream/3.1.8/src/macro-assembler.h +120 -0
- data/ext/v8/upstream/3.1.8/src/macros.py +178 -0
- data/ext/v8/upstream/3.1.8/src/mark-compact.cc +2957 -0
- data/ext/v8/upstream/3.1.8/src/mark-compact.h +433 -0
- data/ext/v8/upstream/3.1.8/src/math.js +264 -0
- data/ext/v8/upstream/3.1.8/src/memory.h +82 -0
- data/ext/v8/upstream/3.1.8/src/messages.cc +164 -0
- data/ext/v8/upstream/3.1.8/src/messages.h +114 -0
- data/ext/v8/upstream/3.1.8/src/messages.js +1071 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/assembler-mips-inl.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/assembler-mips.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/mips/assembler-mips.h +667 -0
- data/ext/v8/upstream/3.1.8/src/mips/builtins-mips.cc +205 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/codegen-mips-inl.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/codegen-mips.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/mips/codegen-mips.h +431 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/constants-mips.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/constants-mips.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/cpu-mips.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/mips/debug-mips.cc +127 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/disasm-mips.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/fast-codegen-mips.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/mips/frames-mips.cc +96 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/frames-mips.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/full-codegen-mips.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/mips/ic-mips.cc +208 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/jump-target-mips.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/macro-assembler-mips.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/macro-assembler-mips.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/register-allocator-mips-inl.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/register-allocator-mips.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/register-allocator-mips.h +0 -0
- data/ext/v8/upstream/3.1.8/src/mips/simulator-mips.cc +1650 -0
- data/ext/v8/upstream/3.1.8/src/mips/simulator-mips.h +311 -0
- data/ext/v8/upstream/3.1.8/src/mips/stub-cache-mips.cc +418 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/virtual-frame-mips.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/virtual-frame-mips.h +0 -0
- data/ext/v8/upstream/3.1.8/src/mirror-debugger.js +2380 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mksnapshot.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/natives.h +0 -0
- data/ext/v8/upstream/3.1.8/src/objects-debug.cc +722 -0
- data/ext/v8/upstream/3.1.8/src/objects-inl.h +3946 -0
- data/ext/v8/upstream/3.1.8/src/objects-printer.cc +801 -0
- data/ext/v8/upstream/3.1.8/src/objects-visiting.cc +142 -0
- data/ext/v8/upstream/3.1.8/src/objects-visiting.h +401 -0
- data/ext/v8/upstream/3.1.8/src/objects.cc +10044 -0
- data/ext/v8/upstream/3.1.8/src/objects.h +6571 -0
- data/ext/v8/upstream/3.1.8/src/parser.cc +5165 -0
- data/ext/v8/upstream/3.1.8/src/parser.h +802 -0
- data/ext/v8/upstream/3.1.8/src/platform-cygwin.cc +745 -0
- data/ext/v8/upstream/3.1.8/src/platform-freebsd.cc +702 -0
- data/ext/v8/upstream/3.1.8/src/platform-linux.cc +981 -0
- data/ext/v8/upstream/3.1.8/src/platform-macos.cc +732 -0
- data/ext/v8/upstream/3.1.8/src/platform-nullos.cc +498 -0
- data/ext/v8/upstream/3.1.8/src/platform-openbsd.cc +657 -0
- data/ext/v8/upstream/3.1.8/src/platform-posix.cc +399 -0
- data/ext/v8/upstream/3.1.8/src/platform-solaris.cc +714 -0
- data/ext/v8/upstream/3.1.8/src/platform-win32.cc +1974 -0
- data/ext/v8/upstream/3.1.8/src/platform.h +636 -0
- data/ext/v8/upstream/3.1.8/src/preparse-data.cc +183 -0
- data/ext/v8/upstream/3.1.8/src/preparse-data.h +249 -0
- data/ext/v8/upstream/3.1.8/src/preparser-api.cc +213 -0
- data/ext/v8/upstream/3.1.8/src/preparser.cc +1205 -0
- data/ext/v8/upstream/3.1.8/src/preparser.h +278 -0
- data/ext/v8/upstream/3.1.8/src/prettyprinter.cc +1539 -0
- data/ext/v8/upstream/3.1.8/src/prettyprinter.h +223 -0
- data/ext/v8/upstream/3.1.8/src/profile-generator-inl.h +128 -0
- data/ext/v8/upstream/3.1.8/src/profile-generator.cc +2899 -0
- data/ext/v8/upstream/3.1.8/src/profile-generator.h +1151 -0
- data/ext/v8/upstream/3.1.8/src/property.cc +96 -0
- data/ext/v8/upstream/3.1.8/src/property.h +337 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/regexp-macro-assembler-irregexp-inl.h +0 -0
- data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler-irregexp.cc +470 -0
- data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler-irregexp.h +142 -0
- data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler-tracer.cc +373 -0
- data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler-tracer.h +104 -0
- data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler.cc +257 -0
- data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler.h +231 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/regexp-stack.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/regexp-stack.h +0 -0
- data/ext/v8/upstream/3.1.8/src/regexp.js +483 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/register-allocator-inl.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/register-allocator.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/register-allocator.h +0 -0
- data/ext/v8/upstream/3.1.8/src/rewriter.cc +1023 -0
- data/ext/v8/upstream/3.1.8/src/rewriter.h +59 -0
- data/ext/v8/upstream/3.1.8/src/runtime-profiler.cc +443 -0
- data/ext/v8/upstream/3.1.8/src/runtime-profiler.h +77 -0
- data/ext/v8/upstream/3.1.8/src/runtime.cc +11592 -0
- data/ext/v8/upstream/3.1.8/src/runtime.h +582 -0
- data/ext/v8/upstream/3.1.8/src/runtime.js +643 -0
- data/ext/v8/upstream/3.1.8/src/safepoint-table.cc +253 -0
- data/ext/v8/upstream/3.1.8/src/safepoint-table.h +263 -0
- data/ext/v8/upstream/3.1.8/src/scanner-base.cc +971 -0
- data/ext/v8/upstream/3.1.8/src/scanner-base.h +653 -0
- data/ext/v8/upstream/3.1.8/src/scanner.cc +586 -0
- data/ext/v8/upstream/3.1.8/src/scanner.h +194 -0
- data/ext/v8/upstream/3.1.8/src/scopeinfo.cc +636 -0
- data/ext/v8/upstream/3.1.8/src/scopeinfo.h +238 -0
- data/ext/v8/upstream/3.1.8/src/scopes.cc +1063 -0
- data/ext/v8/upstream/3.1.8/src/scopes.h +494 -0
- data/ext/v8/upstream/3.1.8/src/serialize.cc +1535 -0
- data/ext/v8/upstream/3.1.8/src/serialize.h +584 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/shell.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/simulator.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/smart-pointer.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/snapshot-common.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/snapshot-empty.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/snapshot.h +0 -0
- data/ext/v8/upstream/3.1.8/src/spaces-inl.h +524 -0
- data/ext/v8/upstream/3.1.8/src/spaces.cc +3254 -0
- data/ext/v8/upstream/3.1.8/src/spaces.h +2362 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/splay-tree-inl.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/splay-tree.h +0 -0
- data/ext/v8/upstream/3.1.8/src/string-search.cc +40 -0
- data/ext/v8/upstream/3.1.8/src/string-search.h +567 -0
- data/ext/v8/upstream/3.1.8/src/string-stream.cc +584 -0
- data/ext/v8/upstream/3.1.8/src/string-stream.h +191 -0
- data/ext/v8/upstream/3.1.8/src/string.js +915 -0
- data/ext/v8/upstream/3.1.8/src/strtod.cc +440 -0
- data/ext/v8/upstream/3.1.8/src/strtod.h +40 -0
- data/ext/v8/upstream/3.1.8/src/stub-cache.cc +1878 -0
- data/ext/v8/upstream/3.1.8/src/stub-cache.h +849 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/third_party/valgrind/valgrind.h +0 -0
- data/ext/v8/upstream/3.1.8/src/token.cc +63 -0
- data/ext/v8/upstream/3.1.8/src/token.h +288 -0
- data/ext/v8/upstream/3.1.8/src/top.cc +1152 -0
- data/ext/v8/upstream/3.1.8/src/top.h +608 -0
- data/ext/v8/upstream/3.1.8/src/type-info.cc +406 -0
- data/ext/v8/upstream/3.1.8/src/type-info.h +283 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/unbound-queue-inl.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/unbound-queue.h +0 -0
- data/ext/v8/upstream/3.1.8/src/unicode-inl.h +238 -0
- data/ext/v8/upstream/3.1.8/src/unicode.cc +1624 -0
- data/ext/v8/upstream/3.1.8/src/unicode.h +280 -0
- data/ext/v8/upstream/3.1.8/src/uri.js +402 -0
- data/ext/v8/upstream/3.1.8/src/utils.cc +371 -0
- data/ext/v8/upstream/3.1.8/src/utils.h +793 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/v8-counters.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/v8-counters.h +290 -0
- data/ext/v8/upstream/3.1.8/src/v8.cc +270 -0
- data/ext/v8/upstream/3.1.8/src/v8.h +127 -0
- data/ext/v8/upstream/3.1.8/src/v8checks.h +64 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/v8dll-main.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/v8globals.h +480 -0
- data/ext/v8/upstream/3.1.8/src/v8natives.js +1252 -0
- data/ext/v8/upstream/3.1.8/src/v8preparserdll-main.cc +39 -0
- data/ext/v8/upstream/3.1.8/src/v8threads.cc +440 -0
- data/ext/v8/upstream/3.1.8/src/v8threads.h +157 -0
- data/ext/v8/upstream/3.1.8/src/v8utils.h +354 -0
- data/ext/v8/upstream/3.1.8/src/variables.cc +132 -0
- data/ext/v8/upstream/3.1.8/src/variables.h +212 -0
- data/ext/v8/upstream/3.1.8/src/version.cc +95 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/version.h +0 -0
- data/ext/v8/upstream/3.1.8/src/virtual-frame-heavy-inl.h +190 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame-heavy.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame-inl.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame-light-inl.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame-light.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/virtual-frame.h +59 -0
- data/ext/v8/upstream/3.1.8/src/vm-state-inl.h +134 -0
- data/ext/v8/upstream/3.1.8/src/vm-state.h +68 -0
- data/ext/v8/upstream/3.1.8/src/win32-headers.h +95 -0
- data/ext/v8/upstream/3.1.8/src/x64/assembler-x64-inl.h +455 -0
- data/ext/v8/upstream/3.1.8/src/x64/assembler-x64.cc +3162 -0
- data/ext/v8/upstream/3.1.8/src/x64/assembler-x64.h +1584 -0
- data/ext/v8/upstream/3.1.8/src/x64/builtins-x64.cc +1492 -0
- data/ext/v8/upstream/3.1.8/src/x64/code-stubs-x64.cc +5150 -0
- data/ext/v8/upstream/3.1.8/src/x64/code-stubs-x64.h +519 -0
- data/ext/v8/upstream/3.1.8/src/x64/codegen-x64-inl.h +46 -0
- data/ext/v8/upstream/3.1.8/src/x64/codegen-x64.cc +8835 -0
- data/ext/v8/upstream/3.1.8/src/x64/codegen-x64.h +750 -0
- data/ext/v8/upstream/3.1.8/src/x64/cpu-x64.cc +86 -0
- data/ext/v8/upstream/3.1.8/src/x64/debug-x64.cc +316 -0
- data/ext/v8/upstream/3.1.8/src/x64/deoptimizer-x64.cc +781 -0
- data/ext/v8/upstream/3.1.8/src/x64/disasm-x64.cc +1737 -0
- data/ext/v8/upstream/3.1.8/src/x64/frames-x64.cc +45 -0
- data/ext/v8/upstream/3.1.8/src/x64/frames-x64.h +130 -0
- data/ext/v8/upstream/3.1.8/src/x64/full-codegen-x64.cc +3984 -0
- data/ext/v8/upstream/3.1.8/src/x64/ic-x64.cc +1761 -0
- data/ext/v8/upstream/3.1.8/src/x64/jump-target-x64.cc +437 -0
- data/ext/v8/upstream/3.1.8/src/x64/lithium-codegen-x64.cc +3639 -0
- data/ext/v8/upstream/3.1.8/src/x64/lithium-codegen-x64.h +305 -0
- data/ext/v8/upstream/3.1.8/src/x64/lithium-gap-resolver-x64.cc +320 -0
- data/ext/v8/upstream/3.1.8/src/x64/lithium-gap-resolver-x64.h +74 -0
- data/ext/v8/upstream/3.1.8/src/x64/lithium-x64.cc +2044 -0
- data/ext/v8/upstream/3.1.8/src/x64/lithium-x64.h +2052 -0
- data/ext/v8/upstream/3.1.8/src/x64/macro-assembler-x64.cc +2660 -0
- data/ext/v8/upstream/3.1.8/src/x64/macro-assembler-x64.h +1852 -0
- data/ext/v8/upstream/3.1.8/src/x64/regexp-macro-assembler-x64.cc +1382 -0
- data/ext/v8/upstream/3.1.8/src/x64/regexp-macro-assembler-x64.h +278 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/x64/register-allocator-x64-inl.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/x64/register-allocator-x64.cc +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/x64/register-allocator-x64.h +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/x64/simulator-x64.cc +0 -0
- data/ext/v8/upstream/3.1.8/src/x64/simulator-x64.h +71 -0
- data/ext/v8/upstream/3.1.8/src/x64/stub-cache-x64.cc +3509 -0
- data/ext/v8/upstream/3.1.8/src/x64/virtual-frame-x64.cc +1292 -0
- data/ext/v8/upstream/3.1.8/src/x64/virtual-frame-x64.h +593 -0
- data/ext/v8/upstream/3.1.8/src/zone-inl.h +83 -0
- data/ext/v8/upstream/3.1.8/src/zone.cc +195 -0
- data/ext/v8/upstream/3.1.8/src/zone.h +233 -0
- data/ext/v8/upstream/3.1.8/tools/codemap.js +265 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/consarray.js +0 -0
- data/ext/v8/upstream/3.1.8/tools/csvparser.js +78 -0
- data/ext/v8/upstream/3.1.8/tools/disasm.py +92 -0
- data/ext/v8/upstream/3.1.8/tools/gc-nvp-trace-processor.py +328 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/generate-ten-powers.scm +0 -0
- data/ext/v8/upstream/3.1.8/tools/grokdump.py +840 -0
- data/ext/v8/upstream/3.1.8/tools/gyp/v8.gyp +869 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/js2c.py +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/jsmin.py +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/linux-tick-processor +0 -0
- data/ext/v8/upstream/3.1.8/tools/ll_prof.py +919 -0
- data/ext/v8/upstream/3.1.8/tools/logreader.js +185 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/mac-nm +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/mac-tick-processor +0 -0
- data/ext/v8/upstream/3.1.8/tools/oom_dump/README +31 -0
- data/ext/v8/upstream/3.1.8/tools/oom_dump/SConstruct +42 -0
- data/ext/v8/upstream/3.1.8/tools/oom_dump/oom_dump.cc +288 -0
- data/ext/v8/upstream/3.1.8/tools/presubmit.py +305 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/process-heap-prof.py +0 -0
- data/ext/v8/upstream/3.1.8/tools/profile.js +751 -0
- data/ext/v8/upstream/3.1.8/tools/profile_view.js +219 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/run-valgrind.py +0 -0
- data/ext/v8/upstream/3.1.8/tools/splaytree.js +316 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/stats-viewer.py +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/tickprocessor-driver.js +0 -0
- data/ext/v8/upstream/3.1.8/tools/tickprocessor.js +863 -0
- data/ext/v8/upstream/3.1.8/tools/utils.py +96 -0
- data/ext/v8/upstream/3.1.8/tools/visual_studio/README.txt +70 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/arm.vsprops +0 -0
- data/ext/v8/upstream/3.1.8/tools/visual_studio/common.vsprops +34 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/d8.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/d8_arm.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/d8_x64.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/d8js2c.cmd +0 -0
- data/ext/v8/upstream/3.1.8/tools/visual_studio/debug.vsprops +17 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/ia32.vsprops +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/js2c.cmd +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/release.vsprops +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8.sln +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_arm.sln +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_arm.vcproj +0 -0
- data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base.vcproj +1296 -0
- data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base_arm.vcproj +1234 -0
- data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base_x64.vcproj +1296 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_cctest.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_cctest_arm.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_cctest_x64.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_mksnapshot.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_mksnapshot_x64.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_process_sample.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_process_sample_arm.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_process_sample_x64.vcproj +0 -0
- data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_shell_sample.vcproj +147 -0
- data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_shell_sample_arm.vcproj +147 -0
- data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_shell_sample_x64.vcproj +163 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_snapshot.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_snapshot_cc.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_snapshot_cc_x64.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_snapshot_x64.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_x64.sln +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_x64.vcproj +0 -0
- data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/x64.vsprops +0 -0
- data/ext/v8/upstream/3.1.8/tools/windows-tick-processor.bat +30 -0
- data/ext/v8/upstream/Makefile +2 -1
- data/ext/v8/v8_template.cpp +2 -2
- data/lib/v8/version.rb +1 -1
- data/spec/redjs/jsapi_spec.rb +2 -2
- metadata +552 -490
- data/ext/v8/upstream/2.3.3/.gitignore +0 -26
- data/ext/v8/upstream/2.3.3/AUTHORS +0 -31
- data/ext/v8/upstream/2.3.3/ChangeLog +0 -1916
- data/ext/v8/upstream/2.3.3/LICENSE +0 -55
- data/ext/v8/upstream/2.3.3/SConstruct +0 -1154
- data/ext/v8/upstream/2.3.3/include/v8-debug.h +0 -381
- data/ext/v8/upstream/2.3.3/include/v8-profiler.h +0 -353
- data/ext/v8/upstream/2.3.3/include/v8.h +0 -3616
- data/ext/v8/upstream/2.3.3/src/SConscript +0 -330
- data/ext/v8/upstream/2.3.3/src/accessors.cc +0 -661
- data/ext/v8/upstream/2.3.3/src/accessors.h +0 -114
- data/ext/v8/upstream/2.3.3/src/allocation.cc +0 -198
- data/ext/v8/upstream/2.3.3/src/allocation.h +0 -169
- data/ext/v8/upstream/2.3.3/src/api.cc +0 -4795
- data/ext/v8/upstream/2.3.3/src/api.h +0 -485
- data/ext/v8/upstream/2.3.3/src/apiutils.h +0 -69
- data/ext/v8/upstream/2.3.3/src/arguments.h +0 -96
- data/ext/v8/upstream/2.3.3/src/arm/assembler-arm-inl.h +0 -305
- data/ext/v8/upstream/2.3.3/src/arm/assembler-arm.cc +0 -2580
- data/ext/v8/upstream/2.3.3/src/arm/assembler-arm.h +0 -1275
- data/ext/v8/upstream/2.3.3/src/arm/builtins-arm.cc +0 -1320
- data/ext/v8/upstream/2.3.3/src/arm/codegen-arm-inl.h +0 -48
- data/ext/v8/upstream/2.3.3/src/arm/codegen-arm.cc +0 -11398
- data/ext/v8/upstream/2.3.3/src/arm/codegen-arm.h +0 -1102
- data/ext/v8/upstream/2.3.3/src/arm/constants-arm.cc +0 -154
- data/ext/v8/upstream/2.3.3/src/arm/constants-arm.h +0 -388
- data/ext/v8/upstream/2.3.3/src/arm/cpu-arm.cc +0 -142
- data/ext/v8/upstream/2.3.3/src/arm/debug-arm.cc +0 -309
- data/ext/v8/upstream/2.3.3/src/arm/disasm-arm.cc +0 -1459
- data/ext/v8/upstream/2.3.3/src/arm/fast-codegen-arm.cc +0 -241
- data/ext/v8/upstream/2.3.3/src/arm/frames-arm.cc +0 -123
- data/ext/v8/upstream/2.3.3/src/arm/frames-arm.h +0 -162
- data/ext/v8/upstream/2.3.3/src/arm/full-codegen-arm.cc +0 -3178
- data/ext/v8/upstream/2.3.3/src/arm/ic-arm.cc +0 -2258
- data/ext/v8/upstream/2.3.3/src/arm/jump-target-arm.cc +0 -164
- data/ext/v8/upstream/2.3.3/src/arm/macro-assembler-arm.cc +0 -1892
- data/ext/v8/upstream/2.3.3/src/arm/macro-assembler-arm.h +0 -727
- data/ext/v8/upstream/2.3.3/src/arm/regexp-macro-assembler-arm.cc +0 -1261
- data/ext/v8/upstream/2.3.3/src/arm/regexp-macro-assembler-arm.h +0 -266
- data/ext/v8/upstream/2.3.3/src/arm/simulator-arm.cc +0 -2822
- data/ext/v8/upstream/2.3.3/src/arm/simulator-arm.h +0 -361
- data/ext/v8/upstream/2.3.3/src/arm/stub-cache-arm.cc +0 -2387
- data/ext/v8/upstream/2.3.3/src/arm/virtual-frame-arm.cc +0 -834
- data/ext/v8/upstream/2.3.3/src/arm/virtual-frame-arm.h +0 -519
- data/ext/v8/upstream/2.3.3/src/array.js +0 -1127
- data/ext/v8/upstream/2.3.3/src/assembler.cc +0 -801
- data/ext/v8/upstream/2.3.3/src/assembler.h +0 -573
- data/ext/v8/upstream/2.3.3/src/ast-inl.h +0 -81
- data/ext/v8/upstream/2.3.3/src/ast.cc +0 -1152
- data/ext/v8/upstream/2.3.3/src/ast.h +0 -2106
- data/ext/v8/upstream/2.3.3/src/bootstrapper.cc +0 -1819
- data/ext/v8/upstream/2.3.3/src/builtins.cc +0 -1529
- data/ext/v8/upstream/2.3.3/src/builtins.h +0 -263
- data/ext/v8/upstream/2.3.3/src/bytecodes-irregexp.h +0 -104
- data/ext/v8/upstream/2.3.3/src/cached-powers.h +0 -119
- data/ext/v8/upstream/2.3.3/src/char-predicates-inl.h +0 -86
- data/ext/v8/upstream/2.3.3/src/checks.cc +0 -100
- data/ext/v8/upstream/2.3.3/src/checks.h +0 -310
- data/ext/v8/upstream/2.3.3/src/circular-queue.cc +0 -121
- data/ext/v8/upstream/2.3.3/src/code-stubs.cc +0 -177
- data/ext/v8/upstream/2.3.3/src/code-stubs.h +0 -177
- data/ext/v8/upstream/2.3.3/src/codegen-inl.h +0 -60
- data/ext/v8/upstream/2.3.3/src/codegen.cc +0 -516
- data/ext/v8/upstream/2.3.3/src/codegen.h +0 -897
- data/ext/v8/upstream/2.3.3/src/compilation-cache.cc +0 -562
- data/ext/v8/upstream/2.3.3/src/compilation-cache.h +0 -102
- data/ext/v8/upstream/2.3.3/src/compiler.cc +0 -654
- data/ext/v8/upstream/2.3.3/src/compiler.h +0 -299
- data/ext/v8/upstream/2.3.3/src/contexts.cc +0 -256
- data/ext/v8/upstream/2.3.3/src/contexts.h +0 -342
- data/ext/v8/upstream/2.3.3/src/conversions.cc +0 -1119
- data/ext/v8/upstream/2.3.3/src/conversions.h +0 -123
- data/ext/v8/upstream/2.3.3/src/counters.h +0 -239
- data/ext/v8/upstream/2.3.3/src/cpu-profiler-inl.h +0 -100
- data/ext/v8/upstream/2.3.3/src/cpu-profiler.cc +0 -538
- data/ext/v8/upstream/2.3.3/src/cpu-profiler.h +0 -285
- data/ext/v8/upstream/2.3.3/src/d8-debug.cc +0 -356
- data/ext/v8/upstream/2.3.3/src/d8-debug.h +0 -155
- data/ext/v8/upstream/2.3.3/src/d8.cc +0 -783
- data/ext/v8/upstream/2.3.3/src/d8.h +0 -227
- data/ext/v8/upstream/2.3.3/src/d8.js +0 -1683
- data/ext/v8/upstream/2.3.3/src/data-flow.cc +0 -758
- data/ext/v8/upstream/2.3.3/src/data-flow.h +0 -278
- data/ext/v8/upstream/2.3.3/src/date.js +0 -1059
- data/ext/v8/upstream/2.3.3/src/dateparser-inl.h +0 -123
- data/ext/v8/upstream/2.3.3/src/dateparser.h +0 -244
- data/ext/v8/upstream/2.3.3/src/debug-agent.cc +0 -427
- data/ext/v8/upstream/2.3.3/src/debug-agent.h +0 -129
- data/ext/v8/upstream/2.3.3/src/debug-debugger.js +0 -2227
- data/ext/v8/upstream/2.3.3/src/debug.cc +0 -3005
- data/ext/v8/upstream/2.3.3/src/debug.h +0 -993
- data/ext/v8/upstream/2.3.3/src/disassembler.cc +0 -312
- data/ext/v8/upstream/2.3.3/src/double.h +0 -169
- data/ext/v8/upstream/2.3.3/src/dtoa-config.c +0 -92
- data/ext/v8/upstream/2.3.3/src/dtoa.cc +0 -77
- data/ext/v8/upstream/2.3.3/src/dtoa.h +0 -81
- data/ext/v8/upstream/2.3.3/src/execution.cc +0 -809
- data/ext/v8/upstream/2.3.3/src/execution.h +0 -336
- data/ext/v8/upstream/2.3.3/src/factory.cc +0 -1003
- data/ext/v8/upstream/2.3.3/src/factory.h +0 -410
- data/ext/v8/upstream/2.3.3/src/fast-codegen.cc +0 -746
- data/ext/v8/upstream/2.3.3/src/fast-codegen.h +0 -161
- data/ext/v8/upstream/2.3.3/src/fast-dtoa.cc +0 -505
- data/ext/v8/upstream/2.3.3/src/fast-dtoa.h +0 -58
- data/ext/v8/upstream/2.3.3/src/flag-definitions.h +0 -455
- data/ext/v8/upstream/2.3.3/src/flags.cc +0 -551
- data/ext/v8/upstream/2.3.3/src/flags.h +0 -81
- data/ext/v8/upstream/2.3.3/src/flow-graph.cc +0 -763
- data/ext/v8/upstream/2.3.3/src/flow-graph.h +0 -180
- data/ext/v8/upstream/2.3.3/src/frame-element.h +0 -273
- data/ext/v8/upstream/2.3.3/src/frames-inl.h +0 -217
- data/ext/v8/upstream/2.3.3/src/frames.cc +0 -826
- data/ext/v8/upstream/2.3.3/src/frames.h +0 -682
- data/ext/v8/upstream/2.3.3/src/full-codegen.cc +0 -1443
- data/ext/v8/upstream/2.3.3/src/full-codegen.h +0 -548
- data/ext/v8/upstream/2.3.3/src/func-name-inferrer.cc +0 -76
- data/ext/v8/upstream/2.3.3/src/func-name-inferrer.h +0 -135
- data/ext/v8/upstream/2.3.3/src/global-handles.cc +0 -520
- data/ext/v8/upstream/2.3.3/src/global-handles.h +0 -180
- data/ext/v8/upstream/2.3.3/src/globals.h +0 -669
- data/ext/v8/upstream/2.3.3/src/handles-inl.h +0 -76
- data/ext/v8/upstream/2.3.3/src/handles.cc +0 -825
- data/ext/v8/upstream/2.3.3/src/handles.h +0 -393
- data/ext/v8/upstream/2.3.3/src/hashmap.cc +0 -226
- data/ext/v8/upstream/2.3.3/src/hashmap.h +0 -120
- data/ext/v8/upstream/2.3.3/src/heap-inl.h +0 -493
- data/ext/v8/upstream/2.3.3/src/heap-profiler.cc +0 -779
- data/ext/v8/upstream/2.3.3/src/heap-profiler.h +0 -323
- data/ext/v8/upstream/2.3.3/src/heap.cc +0 -4994
- data/ext/v8/upstream/2.3.3/src/heap.h +0 -1984
- data/ext/v8/upstream/2.3.3/src/ia32/assembler-ia32-inl.h +0 -360
- data/ext/v8/upstream/2.3.3/src/ia32/assembler-ia32.cc +0 -2600
- data/ext/v8/upstream/2.3.3/src/ia32/assembler-ia32.h +0 -969
- data/ext/v8/upstream/2.3.3/src/ia32/builtins-ia32.cc +0 -1261
- data/ext/v8/upstream/2.3.3/src/ia32/codegen-ia32.cc +0 -13968
- data/ext/v8/upstream/2.3.3/src/ia32/codegen-ia32.h +0 -1097
- data/ext/v8/upstream/2.3.3/src/ia32/cpu-ia32.cc +0 -83
- data/ext/v8/upstream/2.3.3/src/ia32/debug-ia32.cc +0 -309
- data/ext/v8/upstream/2.3.3/src/ia32/disasm-ia32.cc +0 -1471
- data/ext/v8/upstream/2.3.3/src/ia32/fast-codegen-ia32.cc +0 -954
- data/ext/v8/upstream/2.3.3/src/ia32/fast-codegen-ia32.h +0 -155
- data/ext/v8/upstream/2.3.3/src/ia32/frames-ia32.cc +0 -115
- data/ext/v8/upstream/2.3.3/src/ia32/frames-ia32.h +0 -135
- data/ext/v8/upstream/2.3.3/src/ia32/full-codegen-ia32.cc +0 -3281
- data/ext/v8/upstream/2.3.3/src/ia32/ic-ia32.cc +0 -1966
- data/ext/v8/upstream/2.3.3/src/ia32/macro-assembler-ia32.cc +0 -1610
- data/ext/v8/upstream/2.3.3/src/ia32/macro-assembler-ia32.h +0 -610
- data/ext/v8/upstream/2.3.3/src/ia32/regexp-macro-assembler-ia32.cc +0 -1247
- data/ext/v8/upstream/2.3.3/src/ia32/regexp-macro-assembler-ia32.h +0 -214
- data/ext/v8/upstream/2.3.3/src/ia32/simulator-ia32.h +0 -62
- data/ext/v8/upstream/2.3.3/src/ia32/stub-cache-ia32.cc +0 -2750
- data/ext/v8/upstream/2.3.3/src/ia32/virtual-frame-ia32.cc +0 -1334
- data/ext/v8/upstream/2.3.3/src/ia32/virtual-frame-ia32.h +0 -627
- data/ext/v8/upstream/2.3.3/src/ic-inl.h +0 -120
- data/ext/v8/upstream/2.3.3/src/ic.cc +0 -1827
- data/ext/v8/upstream/2.3.3/src/ic.h +0 -515
- data/ext/v8/upstream/2.3.3/src/interpreter-irregexp.cc +0 -646
- data/ext/v8/upstream/2.3.3/src/json.js +0 -268
- data/ext/v8/upstream/2.3.3/src/jsregexp.cc +0 -5283
- data/ext/v8/upstream/2.3.3/src/jsregexp.h +0 -1463
- data/ext/v8/upstream/2.3.3/src/jump-target-heavy.cc +0 -429
- data/ext/v8/upstream/2.3.3/src/jump-target-heavy.h +0 -244
- data/ext/v8/upstream/2.3.3/src/jump-target-light.cc +0 -110
- data/ext/v8/upstream/2.3.3/src/jump-target-light.h +0 -192
- data/ext/v8/upstream/2.3.3/src/list-inl.h +0 -166
- data/ext/v8/upstream/2.3.3/src/list.h +0 -159
- data/ext/v8/upstream/2.3.3/src/liveedit-debugger.js +0 -1057
- data/ext/v8/upstream/2.3.3/src/liveedit.cc +0 -1480
- data/ext/v8/upstream/2.3.3/src/liveedit.h +0 -170
- data/ext/v8/upstream/2.3.3/src/log-utils.cc +0 -497
- data/ext/v8/upstream/2.3.3/src/log-utils.h +0 -289
- data/ext/v8/upstream/2.3.3/src/log.cc +0 -1561
- data/ext/v8/upstream/2.3.3/src/log.h +0 -384
- data/ext/v8/upstream/2.3.3/src/macro-assembler.h +0 -86
- data/ext/v8/upstream/2.3.3/src/macros.py +0 -177
- data/ext/v8/upstream/2.3.3/src/mark-compact.cc +0 -2330
- data/ext/v8/upstream/2.3.3/src/mark-compact.h +0 -451
- data/ext/v8/upstream/2.3.3/src/math.js +0 -264
- data/ext/v8/upstream/2.3.3/src/memory.h +0 -74
- data/ext/v8/upstream/2.3.3/src/messages.cc +0 -183
- data/ext/v8/upstream/2.3.3/src/messages.h +0 -113
- data/ext/v8/upstream/2.3.3/src/messages.js +0 -982
- data/ext/v8/upstream/2.3.3/src/mips/assembler-mips.h +0 -668
- data/ext/v8/upstream/2.3.3/src/mips/builtins-mips.cc +0 -205
- data/ext/v8/upstream/2.3.3/src/mips/codegen-mips.h +0 -434
- data/ext/v8/upstream/2.3.3/src/mips/debug-mips.cc +0 -131
- data/ext/v8/upstream/2.3.3/src/mips/frames-mips.cc +0 -102
- data/ext/v8/upstream/2.3.3/src/mips/ic-mips.cc +0 -220
- data/ext/v8/upstream/2.3.3/src/mips/simulator-mips.cc +0 -1651
- data/ext/v8/upstream/2.3.3/src/mips/simulator-mips.h +0 -311
- data/ext/v8/upstream/2.3.3/src/mips/stub-cache-mips.cc +0 -403
- data/ext/v8/upstream/2.3.3/src/mirror-debugger.js +0 -2380
- data/ext/v8/upstream/2.3.3/src/objects-debug.cc +0 -1366
- data/ext/v8/upstream/2.3.3/src/objects-inl.h +0 -3333
- data/ext/v8/upstream/2.3.3/src/objects.cc +0 -8820
- data/ext/v8/upstream/2.3.3/src/objects.h +0 -5373
- data/ext/v8/upstream/2.3.3/src/oprofile-agent.cc +0 -108
- data/ext/v8/upstream/2.3.3/src/oprofile-agent.h +0 -77
- data/ext/v8/upstream/2.3.3/src/parser.cc +0 -5207
- data/ext/v8/upstream/2.3.3/src/parser.h +0 -197
- data/ext/v8/upstream/2.3.3/src/platform-freebsd.cc +0 -667
- data/ext/v8/upstream/2.3.3/src/platform-linux.cc +0 -862
- data/ext/v8/upstream/2.3.3/src/platform-macos.cc +0 -665
- data/ext/v8/upstream/2.3.3/src/platform-nullos.cc +0 -454
- data/ext/v8/upstream/2.3.3/src/platform-openbsd.cc +0 -622
- data/ext/v8/upstream/2.3.3/src/platform-posix.cc +0 -362
- data/ext/v8/upstream/2.3.3/src/platform-solaris.cc +0 -653
- data/ext/v8/upstream/2.3.3/src/platform-win32.cc +0 -1911
- data/ext/v8/upstream/2.3.3/src/platform.h +0 -577
- data/ext/v8/upstream/2.3.3/src/powers-ten.h +0 -2461
- data/ext/v8/upstream/2.3.3/src/prettyprinter.cc +0 -1531
- data/ext/v8/upstream/2.3.3/src/prettyprinter.h +0 -221
- data/ext/v8/upstream/2.3.3/src/profile-generator-inl.h +0 -148
- data/ext/v8/upstream/2.3.3/src/profile-generator.cc +0 -1830
- data/ext/v8/upstream/2.3.3/src/profile-generator.h +0 -853
- data/ext/v8/upstream/2.3.3/src/property.cc +0 -96
- data/ext/v8/upstream/2.3.3/src/property.h +0 -315
- data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler-irregexp.cc +0 -464
- data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler-irregexp.h +0 -141
- data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler-tracer.cc +0 -356
- data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler-tracer.h +0 -103
- data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler.cc +0 -261
- data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler.h +0 -228
- data/ext/v8/upstream/2.3.3/src/regexp.js +0 -549
- data/ext/v8/upstream/2.3.3/src/rewriter.cc +0 -1038
- data/ext/v8/upstream/2.3.3/src/rewriter.h +0 -54
- data/ext/v8/upstream/2.3.3/src/runtime.cc +0 -10599
- data/ext/v8/upstream/2.3.3/src/runtime.h +0 -459
- data/ext/v8/upstream/2.3.3/src/runtime.js +0 -629
- data/ext/v8/upstream/2.3.3/src/scanner.cc +0 -1346
- data/ext/v8/upstream/2.3.3/src/scanner.h +0 -503
- data/ext/v8/upstream/2.3.3/src/scopeinfo.cc +0 -637
- data/ext/v8/upstream/2.3.3/src/scopeinfo.h +0 -233
- data/ext/v8/upstream/2.3.3/src/scopes.cc +0 -962
- data/ext/v8/upstream/2.3.3/src/scopes.h +0 -400
- data/ext/v8/upstream/2.3.3/src/serialize.cc +0 -1461
- data/ext/v8/upstream/2.3.3/src/serialize.h +0 -581
- data/ext/v8/upstream/2.3.3/src/spaces-inl.h +0 -483
- data/ext/v8/upstream/2.3.3/src/spaces.cc +0 -2901
- data/ext/v8/upstream/2.3.3/src/spaces.h +0 -2197
- data/ext/v8/upstream/2.3.3/src/string-stream.cc +0 -584
- data/ext/v8/upstream/2.3.3/src/string-stream.h +0 -189
- data/ext/v8/upstream/2.3.3/src/string.js +0 -1006
- data/ext/v8/upstream/2.3.3/src/stub-cache.cc +0 -1379
- data/ext/v8/upstream/2.3.3/src/stub-cache.h +0 -756
- data/ext/v8/upstream/2.3.3/src/third_party/dtoa/COPYING +0 -15
- data/ext/v8/upstream/2.3.3/src/third_party/dtoa/dtoa.c +0 -3334
- data/ext/v8/upstream/2.3.3/src/token.cc +0 -56
- data/ext/v8/upstream/2.3.3/src/token.h +0 -270
- data/ext/v8/upstream/2.3.3/src/top.cc +0 -1067
- data/ext/v8/upstream/2.3.3/src/top.h +0 -463
- data/ext/v8/upstream/2.3.3/src/type-info.cc +0 -53
- data/ext/v8/upstream/2.3.3/src/type-info.h +0 -244
- data/ext/v8/upstream/2.3.3/src/unicode-inl.h +0 -238
- data/ext/v8/upstream/2.3.3/src/unicode.cc +0 -749
- data/ext/v8/upstream/2.3.3/src/unicode.h +0 -279
- data/ext/v8/upstream/2.3.3/src/uri.js +0 -415
- data/ext/v8/upstream/2.3.3/src/utils.cc +0 -285
- data/ext/v8/upstream/2.3.3/src/utils.h +0 -745
- data/ext/v8/upstream/2.3.3/src/v8-counters.h +0 -250
- data/ext/v8/upstream/2.3.3/src/v8.cc +0 -228
- data/ext/v8/upstream/2.3.3/src/v8.h +0 -121
- data/ext/v8/upstream/2.3.3/src/v8natives.js +0 -1188
- data/ext/v8/upstream/2.3.3/src/v8threads.cc +0 -461
- data/ext/v8/upstream/2.3.3/src/v8threads.h +0 -159
- data/ext/v8/upstream/2.3.3/src/variables.cc +0 -119
- data/ext/v8/upstream/2.3.3/src/variables.h +0 -205
- data/ext/v8/upstream/2.3.3/src/version.cc +0 -88
- data/ext/v8/upstream/2.3.3/src/virtual-frame-heavy-inl.h +0 -192
- data/ext/v8/upstream/2.3.3/src/virtual-frame.h +0 -46
- data/ext/v8/upstream/2.3.3/src/vm-state-inl.h +0 -137
- data/ext/v8/upstream/2.3.3/src/vm-state.cc +0 -39
- data/ext/v8/upstream/2.3.3/src/vm-state.h +0 -77
- data/ext/v8/upstream/2.3.3/src/x64/assembler-x64-inl.h +0 -400
- data/ext/v8/upstream/2.3.3/src/x64/assembler-x64.cc +0 -2963
- data/ext/v8/upstream/2.3.3/src/x64/assembler-x64.h +0 -1438
- data/ext/v8/upstream/2.3.3/src/x64/builtins-x64.cc +0 -1296
- data/ext/v8/upstream/2.3.3/src/x64/codegen-x64-inl.h +0 -46
- data/ext/v8/upstream/2.3.3/src/x64/codegen-x64.cc +0 -12491
- data/ext/v8/upstream/2.3.3/src/x64/codegen-x64.h +0 -1090
- data/ext/v8/upstream/2.3.3/src/x64/cpu-x64.cc +0 -83
- data/ext/v8/upstream/2.3.3/src/x64/debug-x64.cc +0 -267
- data/ext/v8/upstream/2.3.3/src/x64/disasm-x64.cc +0 -1696
- data/ext/v8/upstream/2.3.3/src/x64/fast-codegen-x64.cc +0 -250
- data/ext/v8/upstream/2.3.3/src/x64/frames-x64.cc +0 -113
- data/ext/v8/upstream/2.3.3/src/x64/frames-x64.h +0 -125
- data/ext/v8/upstream/2.3.3/src/x64/full-codegen-x64.cc +0 -3270
- data/ext/v8/upstream/2.3.3/src/x64/ic-x64.cc +0 -1907
- data/ext/v8/upstream/2.3.3/src/x64/jump-target-x64.cc +0 -437
- data/ext/v8/upstream/2.3.3/src/x64/macro-assembler-x64.cc +0 -2793
- data/ext/v8/upstream/2.3.3/src/x64/macro-assembler-x64.h +0 -916
- data/ext/v8/upstream/2.3.3/src/x64/regexp-macro-assembler-x64.cc +0 -1374
- data/ext/v8/upstream/2.3.3/src/x64/regexp-macro-assembler-x64.h +0 -277
- data/ext/v8/upstream/2.3.3/src/x64/simulator-x64.h +0 -63
- data/ext/v8/upstream/2.3.3/src/x64/stub-cache-x64.cc +0 -2560
- data/ext/v8/upstream/2.3.3/src/x64/virtual-frame-x64.cc +0 -1264
- data/ext/v8/upstream/2.3.3/src/x64/virtual-frame-x64.h +0 -590
- data/ext/v8/upstream/2.3.3/src/zone-inl.h +0 -82
- data/ext/v8/upstream/2.3.3/src/zone.cc +0 -194
- data/ext/v8/upstream/2.3.3/src/zone.h +0 -221
- data/ext/v8/upstream/2.3.3/tools/codemap.js +0 -270
- data/ext/v8/upstream/2.3.3/tools/csvparser.js +0 -83
- data/ext/v8/upstream/2.3.3/tools/gc-nvp-trace-processor.py +0 -317
- data/ext/v8/upstream/2.3.3/tools/gyp/v8.gyp +0 -749
- data/ext/v8/upstream/2.3.3/tools/linux-tick-processor.py +0 -78
- data/ext/v8/upstream/2.3.3/tools/logreader.js +0 -338
- data/ext/v8/upstream/2.3.3/tools/oprofile/annotate +0 -7
- data/ext/v8/upstream/2.3.3/tools/oprofile/common +0 -19
- data/ext/v8/upstream/2.3.3/tools/oprofile/dump +0 -7
- data/ext/v8/upstream/2.3.3/tools/oprofile/report +0 -7
- data/ext/v8/upstream/2.3.3/tools/oprofile/reset +0 -7
- data/ext/v8/upstream/2.3.3/tools/oprofile/run +0 -14
- data/ext/v8/upstream/2.3.3/tools/oprofile/shutdown +0 -7
- data/ext/v8/upstream/2.3.3/tools/oprofile/start +0 -7
- data/ext/v8/upstream/2.3.3/tools/presubmit.py +0 -299
- data/ext/v8/upstream/2.3.3/tools/profile.js +0 -691
- data/ext/v8/upstream/2.3.3/tools/profile_view.js +0 -224
- data/ext/v8/upstream/2.3.3/tools/splaytree.js +0 -322
- data/ext/v8/upstream/2.3.3/tools/splaytree.py +0 -226
- data/ext/v8/upstream/2.3.3/tools/tickprocessor.js +0 -862
- data/ext/v8/upstream/2.3.3/tools/tickprocessor.py +0 -571
- data/ext/v8/upstream/2.3.3/tools/utils.py +0 -88
- data/ext/v8/upstream/2.3.3/tools/visual_studio/README.txt +0 -71
- data/ext/v8/upstream/2.3.3/tools/visual_studio/common.vsprops +0 -34
- data/ext/v8/upstream/2.3.3/tools/visual_studio/debug.vsprops +0 -17
- data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_base.vcproj +0 -1143
- data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_base_arm.vcproj +0 -1115
- data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_base_x64.vcproj +0 -1096
- data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_shell_sample.vcproj +0 -145
- data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_shell_sample_arm.vcproj +0 -145
- data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_shell_sample_x64.vcproj +0 -161
- data/ext/v8/upstream/2.3.3/tools/windows-tick-processor.bat +0 -29
- data/ext/v8/upstream/2.3.3/tools/windows-tick-processor.py +0 -137
@@ -1,954 +0,0 @@
|
|
1
|
-
// Copyright 2010 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
|
-
#if defined(V8_TARGET_ARCH_IA32)
|
31
|
-
|
32
|
-
#include "codegen-inl.h"
|
33
|
-
#include "fast-codegen.h"
|
34
|
-
#include "data-flow.h"
|
35
|
-
#include "scopes.h"
|
36
|
-
|
37
|
-
namespace v8 {
|
38
|
-
namespace internal {
|
39
|
-
|
40
|
-
#define BAILOUT(reason) \
|
41
|
-
do { \
|
42
|
-
if (FLAG_trace_bailout) { \
|
43
|
-
PrintF("%s\n", reason); \
|
44
|
-
} \
|
45
|
-
has_supported_syntax_ = false; \
|
46
|
-
return; \
|
47
|
-
} while (false)
|
48
|
-
|
49
|
-
|
50
|
-
#define CHECK_BAILOUT \
|
51
|
-
do { \
|
52
|
-
if (!has_supported_syntax_) return; \
|
53
|
-
} while (false)
|
54
|
-
|
55
|
-
|
56
|
-
void FastCodeGenSyntaxChecker::Check(CompilationInfo* info) {
|
57
|
-
info_ = info;
|
58
|
-
|
59
|
-
// We do not specialize if we do not have a receiver or if it is not a
|
60
|
-
// JS object with fast mode properties.
|
61
|
-
if (!info->has_receiver()) BAILOUT("No receiver");
|
62
|
-
if (!info->receiver()->IsJSObject()) BAILOUT("Receiver is not an object");
|
63
|
-
Handle<JSObject> object = Handle<JSObject>::cast(info->receiver());
|
64
|
-
if (!object->HasFastProperties()) BAILOUT("Receiver is in dictionary mode");
|
65
|
-
|
66
|
-
// We do not support stack or heap slots (both of which require
|
67
|
-
// allocation).
|
68
|
-
Scope* scope = info->scope();
|
69
|
-
if (scope->num_stack_slots() > 0) {
|
70
|
-
BAILOUT("Function has stack-allocated locals");
|
71
|
-
}
|
72
|
-
if (scope->num_heap_slots() > 0) {
|
73
|
-
BAILOUT("Function has context-allocated locals");
|
74
|
-
}
|
75
|
-
|
76
|
-
VisitDeclarations(scope->declarations());
|
77
|
-
CHECK_BAILOUT;
|
78
|
-
|
79
|
-
// We do not support empty function bodies.
|
80
|
-
if (info->function()->body()->is_empty()) {
|
81
|
-
BAILOUT("Function has an empty body");
|
82
|
-
}
|
83
|
-
VisitStatements(info->function()->body());
|
84
|
-
}
|
85
|
-
|
86
|
-
|
87
|
-
void FastCodeGenSyntaxChecker::VisitDeclarations(
|
88
|
-
ZoneList<Declaration*>* decls) {
|
89
|
-
if (!decls->is_empty()) BAILOUT("Function has declarations");
|
90
|
-
}
|
91
|
-
|
92
|
-
|
93
|
-
void FastCodeGenSyntaxChecker::VisitStatements(ZoneList<Statement*>* stmts) {
|
94
|
-
if (stmts->length() != 1) {
|
95
|
-
BAILOUT("Function body is not a singleton statement.");
|
96
|
-
}
|
97
|
-
Visit(stmts->at(0));
|
98
|
-
}
|
99
|
-
|
100
|
-
|
101
|
-
void FastCodeGenSyntaxChecker::VisitDeclaration(Declaration* decl) {
|
102
|
-
UNREACHABLE();
|
103
|
-
}
|
104
|
-
|
105
|
-
|
106
|
-
void FastCodeGenSyntaxChecker::VisitBlock(Block* stmt) {
|
107
|
-
VisitStatements(stmt->statements());
|
108
|
-
}
|
109
|
-
|
110
|
-
|
111
|
-
void FastCodeGenSyntaxChecker::VisitExpressionStatement(
|
112
|
-
ExpressionStatement* stmt) {
|
113
|
-
Visit(stmt->expression());
|
114
|
-
}
|
115
|
-
|
116
|
-
|
117
|
-
void FastCodeGenSyntaxChecker::VisitEmptyStatement(EmptyStatement* stmt) {
|
118
|
-
// Supported.
|
119
|
-
}
|
120
|
-
|
121
|
-
|
122
|
-
void FastCodeGenSyntaxChecker::VisitIfStatement(IfStatement* stmt) {
|
123
|
-
BAILOUT("IfStatement");
|
124
|
-
}
|
125
|
-
|
126
|
-
|
127
|
-
void FastCodeGenSyntaxChecker::VisitContinueStatement(ContinueStatement* stmt) {
|
128
|
-
BAILOUT("Continuestatement");
|
129
|
-
}
|
130
|
-
|
131
|
-
|
132
|
-
void FastCodeGenSyntaxChecker::VisitBreakStatement(BreakStatement* stmt) {
|
133
|
-
BAILOUT("BreakStatement");
|
134
|
-
}
|
135
|
-
|
136
|
-
|
137
|
-
void FastCodeGenSyntaxChecker::VisitReturnStatement(ReturnStatement* stmt) {
|
138
|
-
BAILOUT("ReturnStatement");
|
139
|
-
}
|
140
|
-
|
141
|
-
|
142
|
-
void FastCodeGenSyntaxChecker::VisitWithEnterStatement(
|
143
|
-
WithEnterStatement* stmt) {
|
144
|
-
BAILOUT("WithEnterStatement");
|
145
|
-
}
|
146
|
-
|
147
|
-
|
148
|
-
void FastCodeGenSyntaxChecker::VisitWithExitStatement(WithExitStatement* stmt) {
|
149
|
-
BAILOUT("WithExitStatement");
|
150
|
-
}
|
151
|
-
|
152
|
-
|
153
|
-
void FastCodeGenSyntaxChecker::VisitSwitchStatement(SwitchStatement* stmt) {
|
154
|
-
BAILOUT("SwitchStatement");
|
155
|
-
}
|
156
|
-
|
157
|
-
|
158
|
-
void FastCodeGenSyntaxChecker::VisitDoWhileStatement(DoWhileStatement* stmt) {
|
159
|
-
BAILOUT("DoWhileStatement");
|
160
|
-
}
|
161
|
-
|
162
|
-
|
163
|
-
void FastCodeGenSyntaxChecker::VisitWhileStatement(WhileStatement* stmt) {
|
164
|
-
BAILOUT("WhileStatement");
|
165
|
-
}
|
166
|
-
|
167
|
-
|
168
|
-
void FastCodeGenSyntaxChecker::VisitForStatement(ForStatement* stmt) {
|
169
|
-
BAILOUT("ForStatement");
|
170
|
-
}
|
171
|
-
|
172
|
-
|
173
|
-
void FastCodeGenSyntaxChecker::VisitForInStatement(ForInStatement* stmt) {
|
174
|
-
BAILOUT("ForInStatement");
|
175
|
-
}
|
176
|
-
|
177
|
-
|
178
|
-
void FastCodeGenSyntaxChecker::VisitTryCatchStatement(TryCatchStatement* stmt) {
|
179
|
-
BAILOUT("TryCatchStatement");
|
180
|
-
}
|
181
|
-
|
182
|
-
|
183
|
-
void FastCodeGenSyntaxChecker::VisitTryFinallyStatement(
|
184
|
-
TryFinallyStatement* stmt) {
|
185
|
-
BAILOUT("TryFinallyStatement");
|
186
|
-
}
|
187
|
-
|
188
|
-
|
189
|
-
void FastCodeGenSyntaxChecker::VisitDebuggerStatement(
|
190
|
-
DebuggerStatement* stmt) {
|
191
|
-
BAILOUT("DebuggerStatement");
|
192
|
-
}
|
193
|
-
|
194
|
-
|
195
|
-
void FastCodeGenSyntaxChecker::VisitFunctionLiteral(FunctionLiteral* expr) {
|
196
|
-
BAILOUT("FunctionLiteral");
|
197
|
-
}
|
198
|
-
|
199
|
-
|
200
|
-
void FastCodeGenSyntaxChecker::VisitSharedFunctionInfoLiteral(
|
201
|
-
SharedFunctionInfoLiteral* expr) {
|
202
|
-
BAILOUT("SharedFunctionInfoLiteral");
|
203
|
-
}
|
204
|
-
|
205
|
-
|
206
|
-
void FastCodeGenSyntaxChecker::VisitConditional(Conditional* expr) {
|
207
|
-
BAILOUT("Conditional");
|
208
|
-
}
|
209
|
-
|
210
|
-
|
211
|
-
void FastCodeGenSyntaxChecker::VisitSlot(Slot* expr) {
|
212
|
-
UNREACHABLE();
|
213
|
-
}
|
214
|
-
|
215
|
-
|
216
|
-
void FastCodeGenSyntaxChecker::VisitVariableProxy(VariableProxy* expr) {
|
217
|
-
// Only global variable references are supported.
|
218
|
-
Variable* var = expr->var();
|
219
|
-
if (!var->is_global() || var->is_this()) BAILOUT("Non-global variable");
|
220
|
-
|
221
|
-
// Check if the global variable is existing and non-deletable.
|
222
|
-
if (info()->has_global_object()) {
|
223
|
-
LookupResult lookup;
|
224
|
-
info()->global_object()->Lookup(*expr->name(), &lookup);
|
225
|
-
if (!lookup.IsProperty()) {
|
226
|
-
BAILOUT("Non-existing global variable");
|
227
|
-
}
|
228
|
-
// We do not handle global variables with accessors or interceptors.
|
229
|
-
if (lookup.type() != NORMAL) {
|
230
|
-
BAILOUT("Global variable with accessors or interceptors.");
|
231
|
-
}
|
232
|
-
// We do not handle deletable global variables.
|
233
|
-
if (!lookup.IsDontDelete()) {
|
234
|
-
BAILOUT("Deletable global variable");
|
235
|
-
}
|
236
|
-
}
|
237
|
-
}
|
238
|
-
|
239
|
-
|
240
|
-
void FastCodeGenSyntaxChecker::VisitLiteral(Literal* expr) {
|
241
|
-
BAILOUT("Literal");
|
242
|
-
}
|
243
|
-
|
244
|
-
|
245
|
-
void FastCodeGenSyntaxChecker::VisitRegExpLiteral(RegExpLiteral* expr) {
|
246
|
-
BAILOUT("RegExpLiteral");
|
247
|
-
}
|
248
|
-
|
249
|
-
|
250
|
-
void FastCodeGenSyntaxChecker::VisitObjectLiteral(ObjectLiteral* expr) {
|
251
|
-
BAILOUT("ObjectLiteral");
|
252
|
-
}
|
253
|
-
|
254
|
-
|
255
|
-
void FastCodeGenSyntaxChecker::VisitArrayLiteral(ArrayLiteral* expr) {
|
256
|
-
BAILOUT("ArrayLiteral");
|
257
|
-
}
|
258
|
-
|
259
|
-
|
260
|
-
void FastCodeGenSyntaxChecker::VisitCatchExtensionObject(
|
261
|
-
CatchExtensionObject* expr) {
|
262
|
-
BAILOUT("CatchExtensionObject");
|
263
|
-
}
|
264
|
-
|
265
|
-
|
266
|
-
void FastCodeGenSyntaxChecker::VisitAssignment(Assignment* expr) {
|
267
|
-
// Simple assignments to (named) this properties are supported.
|
268
|
-
if (expr->op() != Token::ASSIGN) BAILOUT("Non-simple assignment");
|
269
|
-
|
270
|
-
Property* prop = expr->target()->AsProperty();
|
271
|
-
if (prop == NULL) BAILOUT("Non-property assignment");
|
272
|
-
VariableProxy* proxy = prop->obj()->AsVariableProxy();
|
273
|
-
if (proxy == NULL || !proxy->var()->is_this()) {
|
274
|
-
BAILOUT("Non-this-property assignment");
|
275
|
-
}
|
276
|
-
if (!prop->key()->IsPropertyName()) {
|
277
|
-
BAILOUT("Non-named-property assignment");
|
278
|
-
}
|
279
|
-
|
280
|
-
// We will only specialize for fields on the object itself.
|
281
|
-
// Expression::IsPropertyName implies that the name is a literal
|
282
|
-
// symbol but we do not assume that.
|
283
|
-
Literal* key = prop->key()->AsLiteral();
|
284
|
-
if (key != NULL && key->handle()->IsString()) {
|
285
|
-
Handle<Object> receiver = info()->receiver();
|
286
|
-
Handle<String> name = Handle<String>::cast(key->handle());
|
287
|
-
LookupResult lookup;
|
288
|
-
receiver->Lookup(*name, &lookup);
|
289
|
-
if (!lookup.IsProperty()) {
|
290
|
-
BAILOUT("Assigned property not found at compile time");
|
291
|
-
}
|
292
|
-
if (lookup.holder() != *receiver) BAILOUT("Non-own property assignment");
|
293
|
-
if (!lookup.type() == FIELD) BAILOUT("Non-field property assignment");
|
294
|
-
} else {
|
295
|
-
UNREACHABLE();
|
296
|
-
BAILOUT("Unexpected non-string-literal property key");
|
297
|
-
}
|
298
|
-
|
299
|
-
Visit(expr->value());
|
300
|
-
}
|
301
|
-
|
302
|
-
|
303
|
-
void FastCodeGenSyntaxChecker::VisitThrow(Throw* expr) {
|
304
|
-
BAILOUT("Throw");
|
305
|
-
}
|
306
|
-
|
307
|
-
|
308
|
-
void FastCodeGenSyntaxChecker::VisitProperty(Property* expr) {
|
309
|
-
// We support named this property references.
|
310
|
-
VariableProxy* proxy = expr->obj()->AsVariableProxy();
|
311
|
-
if (proxy == NULL || !proxy->var()->is_this()) {
|
312
|
-
BAILOUT("Non-this-property reference");
|
313
|
-
}
|
314
|
-
if (!expr->key()->IsPropertyName()) {
|
315
|
-
BAILOUT("Non-named-property reference");
|
316
|
-
}
|
317
|
-
|
318
|
-
// We will only specialize for fields on the object itself.
|
319
|
-
// Expression::IsPropertyName implies that the name is a literal
|
320
|
-
// symbol but we do not assume that.
|
321
|
-
Literal* key = expr->key()->AsLiteral();
|
322
|
-
if (key != NULL && key->handle()->IsString()) {
|
323
|
-
Handle<Object> receiver = info()->receiver();
|
324
|
-
Handle<String> name = Handle<String>::cast(key->handle());
|
325
|
-
LookupResult lookup;
|
326
|
-
receiver->Lookup(*name, &lookup);
|
327
|
-
if (!lookup.IsProperty()) {
|
328
|
-
BAILOUT("Referenced property not found at compile time");
|
329
|
-
}
|
330
|
-
if (lookup.holder() != *receiver) BAILOUT("Non-own property reference");
|
331
|
-
if (!lookup.type() == FIELD) BAILOUT("Non-field property reference");
|
332
|
-
} else {
|
333
|
-
UNREACHABLE();
|
334
|
-
BAILOUT("Unexpected non-string-literal property key");
|
335
|
-
}
|
336
|
-
}
|
337
|
-
|
338
|
-
|
339
|
-
void FastCodeGenSyntaxChecker::VisitCall(Call* expr) {
|
340
|
-
BAILOUT("Call");
|
341
|
-
}
|
342
|
-
|
343
|
-
|
344
|
-
void FastCodeGenSyntaxChecker::VisitCallNew(CallNew* expr) {
|
345
|
-
BAILOUT("CallNew");
|
346
|
-
}
|
347
|
-
|
348
|
-
|
349
|
-
void FastCodeGenSyntaxChecker::VisitCallRuntime(CallRuntime* expr) {
|
350
|
-
BAILOUT("CallRuntime");
|
351
|
-
}
|
352
|
-
|
353
|
-
|
354
|
-
void FastCodeGenSyntaxChecker::VisitUnaryOperation(UnaryOperation* expr) {
|
355
|
-
BAILOUT("UnaryOperation");
|
356
|
-
}
|
357
|
-
|
358
|
-
|
359
|
-
void FastCodeGenSyntaxChecker::VisitCountOperation(CountOperation* expr) {
|
360
|
-
BAILOUT("CountOperation");
|
361
|
-
}
|
362
|
-
|
363
|
-
|
364
|
-
void FastCodeGenSyntaxChecker::VisitBinaryOperation(BinaryOperation* expr) {
|
365
|
-
// We support bitwise OR.
|
366
|
-
switch (expr->op()) {
|
367
|
-
case Token::COMMA:
|
368
|
-
BAILOUT("BinaryOperation COMMA");
|
369
|
-
case Token::OR:
|
370
|
-
BAILOUT("BinaryOperation OR");
|
371
|
-
case Token::AND:
|
372
|
-
BAILOUT("BinaryOperation AND");
|
373
|
-
|
374
|
-
case Token::BIT_OR:
|
375
|
-
// We support expressions nested on the left because they only require
|
376
|
-
// a pair of registers to keep all intermediate values in registers
|
377
|
-
// (i.e., the expression stack has height no more than two).
|
378
|
-
if (!expr->right()->IsLeaf()) BAILOUT("expression nested on right");
|
379
|
-
|
380
|
-
// We do not allow subexpressions with side effects because we
|
381
|
-
// (currently) bail out to the beginning of the full function. The
|
382
|
-
// only expressions with side effects that we would otherwise handle
|
383
|
-
// are assignments.
|
384
|
-
if (expr->left()->AsAssignment() != NULL ||
|
385
|
-
expr->right()->AsAssignment() != NULL) {
|
386
|
-
BAILOUT("subexpression of binary operation has side effects");
|
387
|
-
}
|
388
|
-
|
389
|
-
Visit(expr->left());
|
390
|
-
CHECK_BAILOUT;
|
391
|
-
Visit(expr->right());
|
392
|
-
break;
|
393
|
-
|
394
|
-
case Token::BIT_XOR:
|
395
|
-
BAILOUT("BinaryOperation BIT_XOR");
|
396
|
-
case Token::BIT_AND:
|
397
|
-
BAILOUT("BinaryOperation BIT_AND");
|
398
|
-
case Token::SHL:
|
399
|
-
BAILOUT("BinaryOperation SHL");
|
400
|
-
case Token::SAR:
|
401
|
-
BAILOUT("BinaryOperation SAR");
|
402
|
-
case Token::SHR:
|
403
|
-
BAILOUT("BinaryOperation SHR");
|
404
|
-
case Token::ADD:
|
405
|
-
BAILOUT("BinaryOperation ADD");
|
406
|
-
case Token::SUB:
|
407
|
-
BAILOUT("BinaryOperation SUB");
|
408
|
-
case Token::MUL:
|
409
|
-
BAILOUT("BinaryOperation MUL");
|
410
|
-
case Token::DIV:
|
411
|
-
BAILOUT("BinaryOperation DIV");
|
412
|
-
case Token::MOD:
|
413
|
-
BAILOUT("BinaryOperation MOD");
|
414
|
-
default:
|
415
|
-
UNREACHABLE();
|
416
|
-
}
|
417
|
-
}
|
418
|
-
|
419
|
-
|
420
|
-
void FastCodeGenSyntaxChecker::VisitCompareOperation(CompareOperation* expr) {
|
421
|
-
BAILOUT("CompareOperation");
|
422
|
-
}
|
423
|
-
|
424
|
-
|
425
|
-
void FastCodeGenSyntaxChecker::VisitThisFunction(ThisFunction* expr) {
|
426
|
-
BAILOUT("ThisFunction");
|
427
|
-
}
|
428
|
-
|
429
|
-
#undef BAILOUT
|
430
|
-
#undef CHECK_BAILOUT
|
431
|
-
|
432
|
-
|
433
|
-
#define __ ACCESS_MASM(masm())
|
434
|
-
|
435
|
-
Handle<Code> FastCodeGenerator::MakeCode(CompilationInfo* info) {
|
436
|
-
// Label the AST before calling MakeCodePrologue, so AST node numbers are
|
437
|
-
// printed with the AST.
|
438
|
-
AstLabeler labeler;
|
439
|
-
labeler.Label(info);
|
440
|
-
|
441
|
-
CodeGenerator::MakeCodePrologue(info);
|
442
|
-
|
443
|
-
const int kInitialBufferSize = 4 * KB;
|
444
|
-
MacroAssembler masm(NULL, kInitialBufferSize);
|
445
|
-
|
446
|
-
// Generate the fast-path code.
|
447
|
-
FastCodeGenerator fast_cgen(&masm);
|
448
|
-
fast_cgen.Generate(info);
|
449
|
-
if (fast_cgen.HasStackOverflow()) {
|
450
|
-
ASSERT(!Top::has_pending_exception());
|
451
|
-
return Handle<Code>::null();
|
452
|
-
}
|
453
|
-
|
454
|
-
// Generate the full code for the function in bailout mode, using the same
|
455
|
-
// macro assembler.
|
456
|
-
CodeGenerator cgen(&masm);
|
457
|
-
CodeGeneratorScope scope(&cgen);
|
458
|
-
info->set_mode(CompilationInfo::SECONDARY);
|
459
|
-
cgen.Generate(info);
|
460
|
-
if (cgen.HasStackOverflow()) {
|
461
|
-
ASSERT(!Top::has_pending_exception());
|
462
|
-
return Handle<Code>::null();
|
463
|
-
}
|
464
|
-
|
465
|
-
Code::Flags flags = Code::ComputeFlags(Code::FUNCTION, NOT_IN_LOOP);
|
466
|
-
return CodeGenerator::MakeCodeEpilogue(&masm, flags, info);
|
467
|
-
}
|
468
|
-
|
469
|
-
|
470
|
-
Register FastCodeGenerator::accumulator0() { return eax; }
|
471
|
-
Register FastCodeGenerator::accumulator1() { return edx; }
|
472
|
-
Register FastCodeGenerator::scratch0() { return ecx; }
|
473
|
-
Register FastCodeGenerator::scratch1() { return edi; }
|
474
|
-
Register FastCodeGenerator::receiver_reg() { return ebx; }
|
475
|
-
Register FastCodeGenerator::context_reg() { return esi; }
|
476
|
-
|
477
|
-
|
478
|
-
void FastCodeGenerator::EmitLoadReceiver() {
|
479
|
-
// Offset 2 is due to return address and saved frame pointer.
|
480
|
-
int index = 2 + function()->scope()->num_parameters();
|
481
|
-
__ mov(receiver_reg(), Operand(ebp, index * kPointerSize));
|
482
|
-
}
|
483
|
-
|
484
|
-
|
485
|
-
void FastCodeGenerator::EmitGlobalVariableLoad(Handle<Object> cell) {
|
486
|
-
ASSERT(!destination().is(no_reg));
|
487
|
-
ASSERT(cell->IsJSGlobalPropertyCell());
|
488
|
-
|
489
|
-
__ mov(destination(), Immediate(cell));
|
490
|
-
__ mov(destination(),
|
491
|
-
FieldOperand(destination(), JSGlobalPropertyCell::kValueOffset));
|
492
|
-
if (FLAG_debug_code) {
|
493
|
-
__ cmp(destination(), Factory::the_hole_value());
|
494
|
-
__ Check(not_equal, "DontDelete cells can't contain the hole");
|
495
|
-
}
|
496
|
-
|
497
|
-
// The loaded value is not known to be a smi.
|
498
|
-
clear_as_smi(destination());
|
499
|
-
}
|
500
|
-
|
501
|
-
|
502
|
-
void FastCodeGenerator::EmitThisPropertyStore(Handle<String> name) {
|
503
|
-
LookupResult lookup;
|
504
|
-
info()->receiver()->Lookup(*name, &lookup);
|
505
|
-
|
506
|
-
ASSERT(lookup.holder() == *info()->receiver());
|
507
|
-
ASSERT(lookup.type() == FIELD);
|
508
|
-
Handle<Map> map(Handle<HeapObject>::cast(info()->receiver())->map());
|
509
|
-
int index = lookup.GetFieldIndex() - map->inobject_properties();
|
510
|
-
int offset = index * kPointerSize;
|
511
|
-
|
512
|
-
// We will emit the write barrier unless the stored value is statically
|
513
|
-
// known to be a smi.
|
514
|
-
bool needs_write_barrier = !is_smi(accumulator0());
|
515
|
-
|
516
|
-
// Perform the store. Negative offsets are inobject properties.
|
517
|
-
if (offset < 0) {
|
518
|
-
offset += map->instance_size();
|
519
|
-
__ mov(FieldOperand(receiver_reg(), offset), accumulator0());
|
520
|
-
if (needs_write_barrier) {
|
521
|
-
// Preserve receiver from write barrier.
|
522
|
-
__ mov(scratch0(), receiver_reg());
|
523
|
-
}
|
524
|
-
} else {
|
525
|
-
offset += FixedArray::kHeaderSize;
|
526
|
-
__ mov(scratch0(),
|
527
|
-
FieldOperand(receiver_reg(), JSObject::kPropertiesOffset));
|
528
|
-
__ mov(FieldOperand(scratch0(), offset), accumulator0());
|
529
|
-
}
|
530
|
-
|
531
|
-
if (needs_write_barrier) {
|
532
|
-
if (destination().is(no_reg)) {
|
533
|
-
// After RecordWrite accumulator0 is only accidently a smi, but it is
|
534
|
-
// already marked as not known to be one.
|
535
|
-
__ RecordWrite(scratch0(), offset, accumulator0(), scratch1());
|
536
|
-
} else {
|
537
|
-
// Copy the value to the other accumulator to preserve a copy from the
|
538
|
-
// write barrier. One of the accumulators is available as a scratch
|
539
|
-
// register. Neither is a smi.
|
540
|
-
__ mov(accumulator1(), accumulator0());
|
541
|
-
clear_as_smi(accumulator1());
|
542
|
-
Register value_scratch = other_accumulator(destination());
|
543
|
-
__ RecordWrite(scratch0(), offset, value_scratch, scratch1());
|
544
|
-
}
|
545
|
-
} else if (destination().is(accumulator1())) {
|
546
|
-
__ mov(accumulator1(), accumulator0());
|
547
|
-
// Is a smi because we do not need the write barrier.
|
548
|
-
set_as_smi(accumulator1());
|
549
|
-
}
|
550
|
-
}
|
551
|
-
|
552
|
-
|
553
|
-
void FastCodeGenerator::EmitThisPropertyLoad(Handle<String> name) {
|
554
|
-
ASSERT(!destination().is(no_reg));
|
555
|
-
LookupResult lookup;
|
556
|
-
info()->receiver()->Lookup(*name, &lookup);
|
557
|
-
|
558
|
-
ASSERT(lookup.holder() == *info()->receiver());
|
559
|
-
ASSERT(lookup.type() == FIELD);
|
560
|
-
Handle<Map> map(Handle<HeapObject>::cast(info()->receiver())->map());
|
561
|
-
int index = lookup.GetFieldIndex() - map->inobject_properties();
|
562
|
-
int offset = index * kPointerSize;
|
563
|
-
|
564
|
-
// Perform the load. Negative offsets are inobject properties.
|
565
|
-
if (offset < 0) {
|
566
|
-
offset += map->instance_size();
|
567
|
-
__ mov(destination(), FieldOperand(receiver_reg(), offset));
|
568
|
-
} else {
|
569
|
-
offset += FixedArray::kHeaderSize;
|
570
|
-
__ mov(scratch0(),
|
571
|
-
FieldOperand(receiver_reg(), JSObject::kPropertiesOffset));
|
572
|
-
__ mov(destination(), FieldOperand(scratch0(), offset));
|
573
|
-
}
|
574
|
-
|
575
|
-
// The loaded value is not known to be a smi.
|
576
|
-
clear_as_smi(destination());
|
577
|
-
}
|
578
|
-
|
579
|
-
|
580
|
-
void FastCodeGenerator::EmitBitOr() {
|
581
|
-
if (is_smi(accumulator0()) && is_smi(accumulator1())) {
|
582
|
-
// If both operands are known to be a smi then there is no need to check
|
583
|
-
// the operands or result. There is no need to perform the operation in
|
584
|
-
// an effect context.
|
585
|
-
if (!destination().is(no_reg)) {
|
586
|
-
// Leave the result in the destination register. Bitwise or is
|
587
|
-
// commutative.
|
588
|
-
__ or_(destination(), Operand(other_accumulator(destination())));
|
589
|
-
}
|
590
|
-
} else {
|
591
|
-
// Left is in accumulator1, right in accumulator0.
|
592
|
-
Label* bailout = NULL;
|
593
|
-
if (destination().is(accumulator0())) {
|
594
|
-
__ mov(scratch0(), accumulator0());
|
595
|
-
__ or_(destination(), Operand(accumulator1())); // Or is commutative.
|
596
|
-
__ test(destination(), Immediate(kSmiTagMask));
|
597
|
-
bailout = info()->AddBailout(accumulator1(), scratch0()); // Left, right.
|
598
|
-
} else if (destination().is(accumulator1())) {
|
599
|
-
__ mov(scratch0(), accumulator1());
|
600
|
-
__ or_(destination(), Operand(accumulator0()));
|
601
|
-
__ test(destination(), Immediate(kSmiTagMask));
|
602
|
-
bailout = info()->AddBailout(scratch0(), accumulator0());
|
603
|
-
} else {
|
604
|
-
ASSERT(destination().is(no_reg));
|
605
|
-
__ mov(scratch0(), accumulator1());
|
606
|
-
__ or_(scratch0(), Operand(accumulator0()));
|
607
|
-
__ test(scratch0(), Immediate(kSmiTagMask));
|
608
|
-
bailout = info()->AddBailout(accumulator1(), accumulator0());
|
609
|
-
}
|
610
|
-
__ j(not_zero, bailout, not_taken);
|
611
|
-
}
|
612
|
-
|
613
|
-
// If we didn't bailout, the result (in fact, both inputs too) is known to
|
614
|
-
// be a smi.
|
615
|
-
set_as_smi(accumulator0());
|
616
|
-
set_as_smi(accumulator1());
|
617
|
-
}
|
618
|
-
|
619
|
-
|
620
|
-
void FastCodeGenerator::Generate(CompilationInfo* compilation_info) {
|
621
|
-
ASSERT(info_ == NULL);
|
622
|
-
info_ = compilation_info;
|
623
|
-
Comment cmnt(masm_, "[ function compiled by fast code generator");
|
624
|
-
|
625
|
-
// Save the caller's frame pointer and set up our own.
|
626
|
-
Comment prologue_cmnt(masm(), ";; Prologue");
|
627
|
-
__ push(ebp);
|
628
|
-
__ mov(ebp, esp);
|
629
|
-
__ push(esi); // Context.
|
630
|
-
__ push(edi); // Closure.
|
631
|
-
// Note that we keep a live register reference to esi (context) at this
|
632
|
-
// point.
|
633
|
-
|
634
|
-
Label* bailout_to_beginning = info()->AddBailout();
|
635
|
-
// Receiver (this) is allocated to a fixed register.
|
636
|
-
if (info()->has_this_properties()) {
|
637
|
-
Comment cmnt(masm(), ";; MapCheck(this)");
|
638
|
-
if (FLAG_print_ir) {
|
639
|
-
PrintF("#: MapCheck(this)\n");
|
640
|
-
}
|
641
|
-
ASSERT(info()->has_receiver() && info()->receiver()->IsHeapObject());
|
642
|
-
Handle<HeapObject> object = Handle<HeapObject>::cast(info()->receiver());
|
643
|
-
Handle<Map> map(object->map());
|
644
|
-
EmitLoadReceiver();
|
645
|
-
__ CheckMap(receiver_reg(), map, bailout_to_beginning, false);
|
646
|
-
}
|
647
|
-
|
648
|
-
// If there is a global variable access check if the global object is the
|
649
|
-
// same as at lazy-compilation time.
|
650
|
-
if (info()->has_globals()) {
|
651
|
-
Comment cmnt(masm(), ";; MapCheck(GLOBAL)");
|
652
|
-
if (FLAG_print_ir) {
|
653
|
-
PrintF("#: MapCheck(GLOBAL)\n");
|
654
|
-
}
|
655
|
-
ASSERT(info()->has_global_object());
|
656
|
-
Handle<Map> map(info()->global_object()->map());
|
657
|
-
__ mov(scratch0(), CodeGenerator::GlobalObject());
|
658
|
-
__ CheckMap(scratch0(), map, bailout_to_beginning, true);
|
659
|
-
}
|
660
|
-
|
661
|
-
VisitStatements(function()->body());
|
662
|
-
|
663
|
-
Comment return_cmnt(masm(), ";; Return(<undefined>)");
|
664
|
-
if (FLAG_print_ir) {
|
665
|
-
PrintF("#: Return(<undefined>)\n");
|
666
|
-
}
|
667
|
-
__ mov(eax, Factory::undefined_value());
|
668
|
-
__ mov(esp, ebp);
|
669
|
-
__ pop(ebp);
|
670
|
-
__ ret((scope()->num_parameters() + 1) * kPointerSize);
|
671
|
-
}
|
672
|
-
|
673
|
-
|
674
|
-
void FastCodeGenerator::VisitDeclaration(Declaration* decl) {
|
675
|
-
UNREACHABLE();
|
676
|
-
}
|
677
|
-
|
678
|
-
|
679
|
-
void FastCodeGenerator::VisitBlock(Block* stmt) {
|
680
|
-
VisitStatements(stmt->statements());
|
681
|
-
}
|
682
|
-
|
683
|
-
|
684
|
-
void FastCodeGenerator::VisitExpressionStatement(ExpressionStatement* stmt) {
|
685
|
-
Visit(stmt->expression());
|
686
|
-
}
|
687
|
-
|
688
|
-
|
689
|
-
void FastCodeGenerator::VisitEmptyStatement(EmptyStatement* stmt) {
|
690
|
-
// Nothing to do.
|
691
|
-
}
|
692
|
-
|
693
|
-
|
694
|
-
void FastCodeGenerator::VisitIfStatement(IfStatement* stmt) {
|
695
|
-
UNREACHABLE();
|
696
|
-
}
|
697
|
-
|
698
|
-
|
699
|
-
void FastCodeGenerator::VisitContinueStatement(ContinueStatement* stmt) {
|
700
|
-
UNREACHABLE();
|
701
|
-
}
|
702
|
-
|
703
|
-
|
704
|
-
void FastCodeGenerator::VisitBreakStatement(BreakStatement* stmt) {
|
705
|
-
UNREACHABLE();
|
706
|
-
}
|
707
|
-
|
708
|
-
|
709
|
-
void FastCodeGenerator::VisitReturnStatement(ReturnStatement* stmt) {
|
710
|
-
UNREACHABLE();
|
711
|
-
}
|
712
|
-
|
713
|
-
|
714
|
-
void FastCodeGenerator::VisitWithEnterStatement(WithEnterStatement* stmt) {
|
715
|
-
UNREACHABLE();
|
716
|
-
}
|
717
|
-
|
718
|
-
|
719
|
-
void FastCodeGenerator::VisitWithExitStatement(WithExitStatement* stmt) {
|
720
|
-
UNREACHABLE();
|
721
|
-
}
|
722
|
-
|
723
|
-
|
724
|
-
void FastCodeGenerator::VisitSwitchStatement(SwitchStatement* stmt) {
|
725
|
-
UNREACHABLE();
|
726
|
-
}
|
727
|
-
|
728
|
-
|
729
|
-
void FastCodeGenerator::VisitDoWhileStatement(DoWhileStatement* stmt) {
|
730
|
-
UNREACHABLE();
|
731
|
-
}
|
732
|
-
|
733
|
-
|
734
|
-
void FastCodeGenerator::VisitWhileStatement(WhileStatement* stmt) {
|
735
|
-
UNREACHABLE();
|
736
|
-
}
|
737
|
-
|
738
|
-
|
739
|
-
void FastCodeGenerator::VisitForStatement(ForStatement* stmt) {
|
740
|
-
UNREACHABLE();
|
741
|
-
}
|
742
|
-
|
743
|
-
|
744
|
-
void FastCodeGenerator::VisitForInStatement(ForInStatement* stmt) {
|
745
|
-
UNREACHABLE();
|
746
|
-
}
|
747
|
-
|
748
|
-
|
749
|
-
void FastCodeGenerator::VisitTryCatchStatement(TryCatchStatement* stmt) {
|
750
|
-
UNREACHABLE();
|
751
|
-
}
|
752
|
-
|
753
|
-
|
754
|
-
void FastCodeGenerator::VisitTryFinallyStatement(TryFinallyStatement* stmt) {
|
755
|
-
UNREACHABLE();
|
756
|
-
}
|
757
|
-
|
758
|
-
|
759
|
-
void FastCodeGenerator::VisitDebuggerStatement(DebuggerStatement* stmt) {
|
760
|
-
UNREACHABLE();
|
761
|
-
}
|
762
|
-
|
763
|
-
|
764
|
-
void FastCodeGenerator::VisitFunctionLiteral(FunctionLiteral* expr) {
|
765
|
-
UNREACHABLE();
|
766
|
-
}
|
767
|
-
|
768
|
-
|
769
|
-
void FastCodeGenerator::VisitSharedFunctionInfoLiteral(
|
770
|
-
SharedFunctionInfoLiteral* expr) {
|
771
|
-
UNREACHABLE();
|
772
|
-
}
|
773
|
-
|
774
|
-
|
775
|
-
void FastCodeGenerator::VisitConditional(Conditional* expr) {
|
776
|
-
UNREACHABLE();
|
777
|
-
}
|
778
|
-
|
779
|
-
|
780
|
-
void FastCodeGenerator::VisitSlot(Slot* expr) {
|
781
|
-
UNREACHABLE();
|
782
|
-
}
|
783
|
-
|
784
|
-
|
785
|
-
void FastCodeGenerator::VisitVariableProxy(VariableProxy* expr) {
|
786
|
-
ASSERT(expr->var()->is_global() && !expr->var()->is_this());
|
787
|
-
// Check if we can compile a global variable load directly from the cell.
|
788
|
-
ASSERT(info()->has_global_object());
|
789
|
-
LookupResult lookup;
|
790
|
-
info()->global_object()->Lookup(*expr->name(), &lookup);
|
791
|
-
// We only support normal (non-accessor/interceptor) DontDelete properties
|
792
|
-
// for now.
|
793
|
-
ASSERT(lookup.IsProperty());
|
794
|
-
ASSERT_EQ(NORMAL, lookup.type());
|
795
|
-
ASSERT(lookup.IsDontDelete());
|
796
|
-
Handle<Object> cell(info()->global_object()->GetPropertyCell(&lookup));
|
797
|
-
|
798
|
-
// Global variable lookups do not have side effects, so we do not need to
|
799
|
-
// emit code if we are in an effect context.
|
800
|
-
if (!destination().is(no_reg)) {
|
801
|
-
Comment cmnt(masm(), ";; Global");
|
802
|
-
if (FLAG_print_ir) {
|
803
|
-
SmartPointer<char> name = expr->name()->ToCString();
|
804
|
-
PrintF("%d: t%d = Global(%s)\n", expr->num(),
|
805
|
-
expr->num(), *name);
|
806
|
-
}
|
807
|
-
EmitGlobalVariableLoad(cell);
|
808
|
-
}
|
809
|
-
}
|
810
|
-
|
811
|
-
|
812
|
-
void FastCodeGenerator::VisitLiteral(Literal* expr) {
|
813
|
-
UNREACHABLE();
|
814
|
-
}
|
815
|
-
|
816
|
-
|
817
|
-
void FastCodeGenerator::VisitRegExpLiteral(RegExpLiteral* expr) {
|
818
|
-
UNREACHABLE();
|
819
|
-
}
|
820
|
-
|
821
|
-
|
822
|
-
void FastCodeGenerator::VisitObjectLiteral(ObjectLiteral* expr) {
|
823
|
-
UNREACHABLE();
|
824
|
-
}
|
825
|
-
|
826
|
-
|
827
|
-
void FastCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
828
|
-
UNREACHABLE();
|
829
|
-
}
|
830
|
-
|
831
|
-
|
832
|
-
void FastCodeGenerator::VisitCatchExtensionObject(CatchExtensionObject* expr) {
|
833
|
-
UNREACHABLE();
|
834
|
-
}
|
835
|
-
|
836
|
-
|
837
|
-
void FastCodeGenerator::VisitAssignment(Assignment* expr) {
|
838
|
-
// Known to be a simple this property assignment. Effectively a unary
|
839
|
-
// operation.
|
840
|
-
{ Register my_destination = destination();
|
841
|
-
set_destination(accumulator0());
|
842
|
-
Visit(expr->value());
|
843
|
-
set_destination(my_destination);
|
844
|
-
}
|
845
|
-
|
846
|
-
Property* prop = expr->target()->AsProperty();
|
847
|
-
ASSERT_NOT_NULL(prop);
|
848
|
-
ASSERT_NOT_NULL(prop->obj()->AsVariableProxy());
|
849
|
-
ASSERT(prop->obj()->AsVariableProxy()->var()->is_this());
|
850
|
-
ASSERT(prop->key()->IsPropertyName());
|
851
|
-
Handle<String> name =
|
852
|
-
Handle<String>::cast(prop->key()->AsLiteral()->handle());
|
853
|
-
|
854
|
-
Comment cmnt(masm(), ";; Store to this");
|
855
|
-
if (FLAG_print_ir) {
|
856
|
-
SmartPointer<char> name_string = name->ToCString();
|
857
|
-
PrintF("%d: ", expr->num());
|
858
|
-
if (!destination().is(no_reg)) PrintF("t%d = ", expr->num());
|
859
|
-
PrintF("Store(this, \"%s\", t%d)\n", *name_string,
|
860
|
-
expr->value()->num());
|
861
|
-
}
|
862
|
-
|
863
|
-
EmitThisPropertyStore(name);
|
864
|
-
}
|
865
|
-
|
866
|
-
|
867
|
-
void FastCodeGenerator::VisitThrow(Throw* expr) {
|
868
|
-
UNREACHABLE();
|
869
|
-
}
|
870
|
-
|
871
|
-
|
872
|
-
void FastCodeGenerator::VisitProperty(Property* expr) {
|
873
|
-
ASSERT_NOT_NULL(expr->obj()->AsVariableProxy());
|
874
|
-
ASSERT(expr->obj()->AsVariableProxy()->var()->is_this());
|
875
|
-
ASSERT(expr->key()->IsPropertyName());
|
876
|
-
if (!destination().is(no_reg)) {
|
877
|
-
Handle<String> name =
|
878
|
-
Handle<String>::cast(expr->key()->AsLiteral()->handle());
|
879
|
-
|
880
|
-
Comment cmnt(masm(), ";; Load from this");
|
881
|
-
if (FLAG_print_ir) {
|
882
|
-
SmartPointer<char> name_string = name->ToCString();
|
883
|
-
PrintF("%d: t%d = Load(this, \"%s\")\n",
|
884
|
-
expr->num(), expr->num(), *name_string);
|
885
|
-
}
|
886
|
-
EmitThisPropertyLoad(name);
|
887
|
-
}
|
888
|
-
}
|
889
|
-
|
890
|
-
|
891
|
-
void FastCodeGenerator::VisitCall(Call* expr) {
|
892
|
-
UNREACHABLE();
|
893
|
-
}
|
894
|
-
|
895
|
-
|
896
|
-
void FastCodeGenerator::VisitCallNew(CallNew* expr) {
|
897
|
-
UNREACHABLE();
|
898
|
-
}
|
899
|
-
|
900
|
-
|
901
|
-
void FastCodeGenerator::VisitCallRuntime(CallRuntime* expr) {
|
902
|
-
UNREACHABLE();
|
903
|
-
}
|
904
|
-
|
905
|
-
|
906
|
-
void FastCodeGenerator::VisitUnaryOperation(UnaryOperation* expr) {
|
907
|
-
UNREACHABLE();
|
908
|
-
}
|
909
|
-
|
910
|
-
|
911
|
-
void FastCodeGenerator::VisitCountOperation(CountOperation* expr) {
|
912
|
-
UNREACHABLE();
|
913
|
-
}
|
914
|
-
|
915
|
-
|
916
|
-
void FastCodeGenerator::VisitBinaryOperation(BinaryOperation* expr) {
|
917
|
-
// We support limited binary operations: bitwise OR only allowed to be
|
918
|
-
// nested on the left.
|
919
|
-
ASSERT(expr->op() == Token::BIT_OR);
|
920
|
-
ASSERT(expr->right()->IsLeaf());
|
921
|
-
|
922
|
-
{ Register my_destination = destination();
|
923
|
-
set_destination(accumulator1());
|
924
|
-
Visit(expr->left());
|
925
|
-
set_destination(accumulator0());
|
926
|
-
Visit(expr->right());
|
927
|
-
set_destination(my_destination);
|
928
|
-
}
|
929
|
-
|
930
|
-
Comment cmnt(masm(), ";; BIT_OR");
|
931
|
-
if (FLAG_print_ir) {
|
932
|
-
PrintF("%d: ", expr->num());
|
933
|
-
if (!destination().is(no_reg)) PrintF("t%d = ", expr->num());
|
934
|
-
PrintF("BIT_OR(t%d, t%d)\n", expr->left()->num(), expr->right()->num());
|
935
|
-
}
|
936
|
-
EmitBitOr();
|
937
|
-
}
|
938
|
-
|
939
|
-
|
940
|
-
void FastCodeGenerator::VisitCompareOperation(CompareOperation* expr) {
|
941
|
-
UNREACHABLE();
|
942
|
-
}
|
943
|
-
|
944
|
-
|
945
|
-
void FastCodeGenerator::VisitThisFunction(ThisFunction* expr) {
|
946
|
-
UNREACHABLE();
|
947
|
-
}
|
948
|
-
|
949
|
-
#undef __
|
950
|
-
|
951
|
-
|
952
|
-
} } // namespace v8::internal
|
953
|
-
|
954
|
-
#endif // V8_TARGET_ARCH_IA32
|