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,336 +0,0 @@
|
|
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
|
-
#ifndef V8_EXECUTION_H_
|
29
|
-
#define V8_EXECUTION_H_
|
30
|
-
|
31
|
-
namespace v8 {
|
32
|
-
namespace internal {
|
33
|
-
|
34
|
-
|
35
|
-
// Flag used to set the interrupt causes.
|
36
|
-
enum InterruptFlag {
|
37
|
-
INTERRUPT = 1 << 0,
|
38
|
-
DEBUGBREAK = 1 << 1,
|
39
|
-
DEBUGCOMMAND = 1 << 2,
|
40
|
-
PREEMPT = 1 << 3,
|
41
|
-
TERMINATE = 1 << 4
|
42
|
-
};
|
43
|
-
|
44
|
-
class Execution : public AllStatic {
|
45
|
-
public:
|
46
|
-
// Call a function, the caller supplies a receiver and an array
|
47
|
-
// of arguments. Arguments are Object* type. After function returns,
|
48
|
-
// pointers in 'args' might be invalid.
|
49
|
-
//
|
50
|
-
// *pending_exception tells whether the invoke resulted in
|
51
|
-
// a pending exception.
|
52
|
-
//
|
53
|
-
static Handle<Object> Call(Handle<JSFunction> func,
|
54
|
-
Handle<Object> receiver,
|
55
|
-
int argc,
|
56
|
-
Object*** args,
|
57
|
-
bool* pending_exception);
|
58
|
-
|
59
|
-
// Construct object from function, the caller supplies an array of
|
60
|
-
// arguments. Arguments are Object* type. After function returns,
|
61
|
-
// pointers in 'args' might be invalid.
|
62
|
-
//
|
63
|
-
// *pending_exception tells whether the invoke resulted in
|
64
|
-
// a pending exception.
|
65
|
-
//
|
66
|
-
static Handle<Object> New(Handle<JSFunction> func,
|
67
|
-
int argc,
|
68
|
-
Object*** args,
|
69
|
-
bool* pending_exception);
|
70
|
-
|
71
|
-
// Call a function, just like Call(), but make sure to silently catch
|
72
|
-
// any thrown exceptions. The return value is either the result of
|
73
|
-
// calling the function (if caught exception is false) or the exception
|
74
|
-
// that occurred (if caught exception is true).
|
75
|
-
static Handle<Object> TryCall(Handle<JSFunction> func,
|
76
|
-
Handle<Object> receiver,
|
77
|
-
int argc,
|
78
|
-
Object*** args,
|
79
|
-
bool* caught_exception);
|
80
|
-
|
81
|
-
// ECMA-262 9.2
|
82
|
-
static Handle<Object> ToBoolean(Handle<Object> obj);
|
83
|
-
|
84
|
-
// ECMA-262 9.3
|
85
|
-
static Handle<Object> ToNumber(Handle<Object> obj, bool* exc);
|
86
|
-
|
87
|
-
// ECMA-262 9.4
|
88
|
-
static Handle<Object> ToInteger(Handle<Object> obj, bool* exc);
|
89
|
-
|
90
|
-
// ECMA-262 9.5
|
91
|
-
static Handle<Object> ToInt32(Handle<Object> obj, bool* exc);
|
92
|
-
|
93
|
-
// ECMA-262 9.6
|
94
|
-
static Handle<Object> ToUint32(Handle<Object> obj, bool* exc);
|
95
|
-
|
96
|
-
// ECMA-262 9.8
|
97
|
-
static Handle<Object> ToString(Handle<Object> obj, bool* exc);
|
98
|
-
|
99
|
-
// ECMA-262 9.8
|
100
|
-
static Handle<Object> ToDetailString(Handle<Object> obj, bool* exc);
|
101
|
-
|
102
|
-
// ECMA-262 9.9
|
103
|
-
static Handle<Object> ToObject(Handle<Object> obj, bool* exc);
|
104
|
-
|
105
|
-
// Create a new date object from 'time'.
|
106
|
-
static Handle<Object> NewDate(double time, bool* exc);
|
107
|
-
|
108
|
-
// Used to implement [] notation on strings (calls JS code)
|
109
|
-
static Handle<Object> CharAt(Handle<String> str, uint32_t index);
|
110
|
-
|
111
|
-
static Handle<Object> GetFunctionFor();
|
112
|
-
static Handle<JSFunction> InstantiateFunction(
|
113
|
-
Handle<FunctionTemplateInfo> data, bool* exc);
|
114
|
-
static Handle<JSObject> InstantiateObject(Handle<ObjectTemplateInfo> data,
|
115
|
-
bool* exc);
|
116
|
-
static void ConfigureInstance(Handle<Object> instance,
|
117
|
-
Handle<Object> data,
|
118
|
-
bool* exc);
|
119
|
-
static Handle<String> GetStackTraceLine(Handle<Object> recv,
|
120
|
-
Handle<JSFunction> fun,
|
121
|
-
Handle<Object> pos,
|
122
|
-
Handle<Object> is_global);
|
123
|
-
#ifdef ENABLE_DEBUGGER_SUPPORT
|
124
|
-
static Object* DebugBreakHelper();
|
125
|
-
static void ProcessDebugMesssages(bool debug_command_only);
|
126
|
-
#endif
|
127
|
-
|
128
|
-
// If the stack guard is triggered, but it is not an actual
|
129
|
-
// stack overflow, then handle the interruption accordingly.
|
130
|
-
static Object* HandleStackGuardInterrupt();
|
131
|
-
|
132
|
-
// Get a function delegate (or undefined) for the given non-function
|
133
|
-
// object. Used for support calling objects as functions.
|
134
|
-
static Handle<Object> GetFunctionDelegate(Handle<Object> object);
|
135
|
-
|
136
|
-
// Get a function delegate (or undefined) for the given non-function
|
137
|
-
// object. Used for support calling objects as constructors.
|
138
|
-
static Handle<Object> GetConstructorDelegate(Handle<Object> object);
|
139
|
-
};
|
140
|
-
|
141
|
-
|
142
|
-
class ExecutionAccess;
|
143
|
-
|
144
|
-
|
145
|
-
// StackGuard contains the handling of the limits that are used to limit the
|
146
|
-
// number of nested invocations of JavaScript and the stack size used in each
|
147
|
-
// invocation.
|
148
|
-
class StackGuard : public AllStatic {
|
149
|
-
public:
|
150
|
-
// Pass the address beyond which the stack should not grow. The stack
|
151
|
-
// is assumed to grow downwards.
|
152
|
-
static void SetStackLimit(uintptr_t limit);
|
153
|
-
|
154
|
-
// Threading support.
|
155
|
-
static char* ArchiveStackGuard(char* to);
|
156
|
-
static char* RestoreStackGuard(char* from);
|
157
|
-
static int ArchiveSpacePerThread();
|
158
|
-
static void FreeThreadResources();
|
159
|
-
// Sets up the default stack guard for this thread if it has not
|
160
|
-
// already been set up.
|
161
|
-
static void InitThread(const ExecutionAccess& lock);
|
162
|
-
// Clears the stack guard for this thread so it does not look as if
|
163
|
-
// it has been set up.
|
164
|
-
static void ClearThread(const ExecutionAccess& lock);
|
165
|
-
|
166
|
-
static bool IsStackOverflow();
|
167
|
-
static bool IsPreempted();
|
168
|
-
static void Preempt();
|
169
|
-
static bool IsInterrupted();
|
170
|
-
static void Interrupt();
|
171
|
-
static bool IsTerminateExecution();
|
172
|
-
static void TerminateExecution();
|
173
|
-
#ifdef ENABLE_DEBUGGER_SUPPORT
|
174
|
-
static bool IsDebugBreak();
|
175
|
-
static void DebugBreak();
|
176
|
-
static bool IsDebugCommand();
|
177
|
-
static void DebugCommand();
|
178
|
-
#endif
|
179
|
-
static void Continue(InterruptFlag after_what);
|
180
|
-
|
181
|
-
// This provides an asynchronous read of the stack limits for the current
|
182
|
-
// thread. There are no locks protecting this, but it is assumed that you
|
183
|
-
// have the global V8 lock if you are using multiple V8 threads.
|
184
|
-
static uintptr_t climit() {
|
185
|
-
return thread_local_.climit_;
|
186
|
-
}
|
187
|
-
static uintptr_t jslimit() {
|
188
|
-
return thread_local_.jslimit_;
|
189
|
-
}
|
190
|
-
static uintptr_t real_jslimit() {
|
191
|
-
return thread_local_.real_jslimit_;
|
192
|
-
}
|
193
|
-
static Address address_of_jslimit() {
|
194
|
-
return reinterpret_cast<Address>(&thread_local_.jslimit_);
|
195
|
-
}
|
196
|
-
static Address address_of_real_jslimit() {
|
197
|
-
return reinterpret_cast<Address>(&thread_local_.real_jslimit_);
|
198
|
-
}
|
199
|
-
|
200
|
-
private:
|
201
|
-
// You should hold the ExecutionAccess lock when calling this method.
|
202
|
-
static bool has_pending_interrupts(const ExecutionAccess& lock) {
|
203
|
-
// Sanity check: We shouldn't be asking about pending interrupts
|
204
|
-
// unless we're not postponing them anymore.
|
205
|
-
ASSERT(!should_postpone_interrupts(lock));
|
206
|
-
return thread_local_.interrupt_flags_ != 0;
|
207
|
-
}
|
208
|
-
|
209
|
-
// You should hold the ExecutionAccess lock when calling this method.
|
210
|
-
static bool should_postpone_interrupts(const ExecutionAccess& lock) {
|
211
|
-
return thread_local_.postpone_interrupts_nesting_ > 0;
|
212
|
-
}
|
213
|
-
|
214
|
-
// You should hold the ExecutionAccess lock when calling this method.
|
215
|
-
static void set_interrupt_limits(const ExecutionAccess& lock) {
|
216
|
-
// Ignore attempts to interrupt when interrupts are postponed.
|
217
|
-
if (should_postpone_interrupts(lock)) return;
|
218
|
-
thread_local_.jslimit_ = kInterruptLimit;
|
219
|
-
thread_local_.climit_ = kInterruptLimit;
|
220
|
-
Heap::SetStackLimits();
|
221
|
-
}
|
222
|
-
|
223
|
-
// Reset limits to actual values. For example after handling interrupt.
|
224
|
-
// You should hold the ExecutionAccess lock when calling this method.
|
225
|
-
static void reset_limits(const ExecutionAccess& lock) {
|
226
|
-
thread_local_.jslimit_ = thread_local_.real_jslimit_;
|
227
|
-
thread_local_.climit_ = thread_local_.real_climit_;
|
228
|
-
Heap::SetStackLimits();
|
229
|
-
}
|
230
|
-
|
231
|
-
// Enable or disable interrupts.
|
232
|
-
static void EnableInterrupts();
|
233
|
-
static void DisableInterrupts();
|
234
|
-
|
235
|
-
static const uintptr_t kLimitSize = kPointerSize * 128 * KB;
|
236
|
-
|
237
|
-
#ifdef V8_TARGET_ARCH_X64
|
238
|
-
static const uintptr_t kInterruptLimit = V8_UINT64_C(0xfffffffffffffffe);
|
239
|
-
static const uintptr_t kIllegalLimit = V8_UINT64_C(0xfffffffffffffff8);
|
240
|
-
#else
|
241
|
-
static const uintptr_t kInterruptLimit = 0xfffffffe;
|
242
|
-
static const uintptr_t kIllegalLimit = 0xfffffff8;
|
243
|
-
#endif
|
244
|
-
|
245
|
-
class ThreadLocal {
|
246
|
-
public:
|
247
|
-
ThreadLocal() { Clear(); }
|
248
|
-
// You should hold the ExecutionAccess lock when you call Initialize or
|
249
|
-
// Clear.
|
250
|
-
void Initialize();
|
251
|
-
void Clear();
|
252
|
-
|
253
|
-
// The stack limit is split into a JavaScript and a C++ stack limit. These
|
254
|
-
// two are the same except when running on a simulator where the C++ and
|
255
|
-
// JavaScript stacks are separate. Each of the two stack limits have two
|
256
|
-
// values. The one eith the real_ prefix is the actual stack limit
|
257
|
-
// set for the VM. The one without the real_ prefix has the same value as
|
258
|
-
// the actual stack limit except when there is an interruption (e.g. debug
|
259
|
-
// break or preemption) in which case it is lowered to make stack checks
|
260
|
-
// fail. Both the generated code and the runtime system check against the
|
261
|
-
// one without the real_ prefix.
|
262
|
-
uintptr_t real_jslimit_; // Actual JavaScript stack limit set for the VM.
|
263
|
-
uintptr_t jslimit_;
|
264
|
-
uintptr_t real_climit_; // Actual C++ stack limit set for the VM.
|
265
|
-
uintptr_t climit_;
|
266
|
-
|
267
|
-
int nesting_;
|
268
|
-
int postpone_interrupts_nesting_;
|
269
|
-
int interrupt_flags_;
|
270
|
-
};
|
271
|
-
|
272
|
-
static ThreadLocal thread_local_;
|
273
|
-
|
274
|
-
friend class StackLimitCheck;
|
275
|
-
friend class PostponeInterruptsScope;
|
276
|
-
};
|
277
|
-
|
278
|
-
|
279
|
-
// Support for checking for stack-overflows in C++ code.
|
280
|
-
class StackLimitCheck BASE_EMBEDDED {
|
281
|
-
public:
|
282
|
-
bool HasOverflowed() const {
|
283
|
-
// Stack has overflowed in C++ code only if stack pointer exceeds the C++
|
284
|
-
// stack guard and the limits are not set to interrupt values.
|
285
|
-
// TODO(214): Stack overflows are ignored if a interrupt is pending. This
|
286
|
-
// code should probably always use the initial C++ limit.
|
287
|
-
return (reinterpret_cast<uintptr_t>(this) < StackGuard::climit()) &&
|
288
|
-
StackGuard::IsStackOverflow();
|
289
|
-
}
|
290
|
-
};
|
291
|
-
|
292
|
-
|
293
|
-
// Support for temporarily postponing interrupts. When the outermost
|
294
|
-
// postpone scope is left the interrupts will be re-enabled and any
|
295
|
-
// interrupts that occurred while in the scope will be taken into
|
296
|
-
// account.
|
297
|
-
class PostponeInterruptsScope BASE_EMBEDDED {
|
298
|
-
public:
|
299
|
-
PostponeInterruptsScope() {
|
300
|
-
StackGuard::thread_local_.postpone_interrupts_nesting_++;
|
301
|
-
StackGuard::DisableInterrupts();
|
302
|
-
}
|
303
|
-
|
304
|
-
~PostponeInterruptsScope() {
|
305
|
-
if (--StackGuard::thread_local_.postpone_interrupts_nesting_ == 0) {
|
306
|
-
StackGuard::EnableInterrupts();
|
307
|
-
}
|
308
|
-
}
|
309
|
-
};
|
310
|
-
|
311
|
-
|
312
|
-
class GCExtension : public v8::Extension {
|
313
|
-
public:
|
314
|
-
GCExtension() : v8::Extension("v8/gc", kSource) {}
|
315
|
-
virtual v8::Handle<v8::FunctionTemplate> GetNativeFunction(
|
316
|
-
v8::Handle<v8::String> name);
|
317
|
-
static v8::Handle<v8::Value> GC(const v8::Arguments& args);
|
318
|
-
private:
|
319
|
-
static const char* const kSource;
|
320
|
-
};
|
321
|
-
|
322
|
-
|
323
|
-
class ExternalizeStringExtension : public v8::Extension {
|
324
|
-
public:
|
325
|
-
ExternalizeStringExtension() : v8::Extension("v8/externalize", kSource) {}
|
326
|
-
virtual v8::Handle<v8::FunctionTemplate> GetNativeFunction(
|
327
|
-
v8::Handle<v8::String> name);
|
328
|
-
static v8::Handle<v8::Value> Externalize(const v8::Arguments& args);
|
329
|
-
static v8::Handle<v8::Value> IsAscii(const v8::Arguments& args);
|
330
|
-
private:
|
331
|
-
static const char* const kSource;
|
332
|
-
};
|
333
|
-
|
334
|
-
} } // namespace v8::internal
|
335
|
-
|
336
|
-
#endif // V8_EXECUTION_H_
|
@@ -1,1003 +0,0 @@
|
|
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
|
-
#include "v8.h"
|
29
|
-
|
30
|
-
#include "api.h"
|
31
|
-
#include "debug.h"
|
32
|
-
#include "execution.h"
|
33
|
-
#include "factory.h"
|
34
|
-
#include "macro-assembler.h"
|
35
|
-
|
36
|
-
namespace v8 {
|
37
|
-
namespace internal {
|
38
|
-
|
39
|
-
|
40
|
-
Handle<FixedArray> Factory::NewFixedArray(int size, PretenureFlag pretenure) {
|
41
|
-
ASSERT(0 <= size);
|
42
|
-
CALL_HEAP_FUNCTION(Heap::AllocateFixedArray(size, pretenure), FixedArray);
|
43
|
-
}
|
44
|
-
|
45
|
-
|
46
|
-
Handle<FixedArray> Factory::NewFixedArrayWithHoles(int size,
|
47
|
-
PretenureFlag pretenure) {
|
48
|
-
ASSERT(0 <= size);
|
49
|
-
CALL_HEAP_FUNCTION(Heap::AllocateFixedArrayWithHoles(size, pretenure),
|
50
|
-
FixedArray);
|
51
|
-
}
|
52
|
-
|
53
|
-
|
54
|
-
Handle<StringDictionary> Factory::NewStringDictionary(int at_least_space_for) {
|
55
|
-
ASSERT(0 <= at_least_space_for);
|
56
|
-
CALL_HEAP_FUNCTION(StringDictionary::Allocate(at_least_space_for),
|
57
|
-
StringDictionary);
|
58
|
-
}
|
59
|
-
|
60
|
-
|
61
|
-
Handle<NumberDictionary> Factory::NewNumberDictionary(int at_least_space_for) {
|
62
|
-
ASSERT(0 <= at_least_space_for);
|
63
|
-
CALL_HEAP_FUNCTION(NumberDictionary::Allocate(at_least_space_for),
|
64
|
-
NumberDictionary);
|
65
|
-
}
|
66
|
-
|
67
|
-
|
68
|
-
Handle<DescriptorArray> Factory::NewDescriptorArray(int number_of_descriptors) {
|
69
|
-
ASSERT(0 <= number_of_descriptors);
|
70
|
-
CALL_HEAP_FUNCTION(DescriptorArray::Allocate(number_of_descriptors),
|
71
|
-
DescriptorArray);
|
72
|
-
}
|
73
|
-
|
74
|
-
|
75
|
-
// Symbols are created in the old generation (data space).
|
76
|
-
Handle<String> Factory::LookupSymbol(Vector<const char> string) {
|
77
|
-
CALL_HEAP_FUNCTION(Heap::LookupSymbol(string), String);
|
78
|
-
}
|
79
|
-
|
80
|
-
|
81
|
-
Handle<String> Factory::NewStringFromAscii(Vector<const char> string,
|
82
|
-
PretenureFlag pretenure) {
|
83
|
-
CALL_HEAP_FUNCTION(Heap::AllocateStringFromAscii(string, pretenure), String);
|
84
|
-
}
|
85
|
-
|
86
|
-
Handle<String> Factory::NewStringFromUtf8(Vector<const char> string,
|
87
|
-
PretenureFlag pretenure) {
|
88
|
-
CALL_HEAP_FUNCTION(Heap::AllocateStringFromUtf8(string, pretenure), String);
|
89
|
-
}
|
90
|
-
|
91
|
-
|
92
|
-
Handle<String> Factory::NewStringFromTwoByte(Vector<const uc16> string,
|
93
|
-
PretenureFlag pretenure) {
|
94
|
-
CALL_HEAP_FUNCTION(Heap::AllocateStringFromTwoByte(string, pretenure),
|
95
|
-
String);
|
96
|
-
}
|
97
|
-
|
98
|
-
|
99
|
-
Handle<String> Factory::NewRawAsciiString(int length,
|
100
|
-
PretenureFlag pretenure) {
|
101
|
-
CALL_HEAP_FUNCTION(Heap::AllocateRawAsciiString(length, pretenure), String);
|
102
|
-
}
|
103
|
-
|
104
|
-
|
105
|
-
Handle<String> Factory::NewRawTwoByteString(int length,
|
106
|
-
PretenureFlag pretenure) {
|
107
|
-
CALL_HEAP_FUNCTION(Heap::AllocateRawTwoByteString(length, pretenure), String);
|
108
|
-
}
|
109
|
-
|
110
|
-
|
111
|
-
Handle<String> Factory::NewConsString(Handle<String> first,
|
112
|
-
Handle<String> second) {
|
113
|
-
CALL_HEAP_FUNCTION(Heap::AllocateConsString(*first, *second), String);
|
114
|
-
}
|
115
|
-
|
116
|
-
|
117
|
-
Handle<String> Factory::NewSubString(Handle<String> str,
|
118
|
-
int begin,
|
119
|
-
int end) {
|
120
|
-
CALL_HEAP_FUNCTION(str->SubString(begin, end), String);
|
121
|
-
}
|
122
|
-
|
123
|
-
|
124
|
-
Handle<String> Factory::NewExternalStringFromAscii(
|
125
|
-
ExternalAsciiString::Resource* resource) {
|
126
|
-
CALL_HEAP_FUNCTION(Heap::AllocateExternalStringFromAscii(resource), String);
|
127
|
-
}
|
128
|
-
|
129
|
-
|
130
|
-
Handle<String> Factory::NewExternalStringFromTwoByte(
|
131
|
-
ExternalTwoByteString::Resource* resource) {
|
132
|
-
CALL_HEAP_FUNCTION(Heap::AllocateExternalStringFromTwoByte(resource), String);
|
133
|
-
}
|
134
|
-
|
135
|
-
|
136
|
-
Handle<Context> Factory::NewGlobalContext() {
|
137
|
-
CALL_HEAP_FUNCTION(Heap::AllocateGlobalContext(), Context);
|
138
|
-
}
|
139
|
-
|
140
|
-
|
141
|
-
Handle<Context> Factory::NewFunctionContext(int length,
|
142
|
-
Handle<JSFunction> closure) {
|
143
|
-
CALL_HEAP_FUNCTION(Heap::AllocateFunctionContext(length, *closure), Context);
|
144
|
-
}
|
145
|
-
|
146
|
-
|
147
|
-
Handle<Context> Factory::NewWithContext(Handle<Context> previous,
|
148
|
-
Handle<JSObject> extension,
|
149
|
-
bool is_catch_context) {
|
150
|
-
CALL_HEAP_FUNCTION(Heap::AllocateWithContext(*previous,
|
151
|
-
*extension,
|
152
|
-
is_catch_context),
|
153
|
-
Context);
|
154
|
-
}
|
155
|
-
|
156
|
-
|
157
|
-
Handle<Struct> Factory::NewStruct(InstanceType type) {
|
158
|
-
CALL_HEAP_FUNCTION(Heap::AllocateStruct(type), Struct);
|
159
|
-
}
|
160
|
-
|
161
|
-
|
162
|
-
Handle<AccessorInfo> Factory::NewAccessorInfo() {
|
163
|
-
Handle<AccessorInfo> info =
|
164
|
-
Handle<AccessorInfo>::cast(NewStruct(ACCESSOR_INFO_TYPE));
|
165
|
-
info->set_flag(0); // Must clear the flag, it was initialized as undefined.
|
166
|
-
return info;
|
167
|
-
}
|
168
|
-
|
169
|
-
|
170
|
-
Handle<Script> Factory::NewScript(Handle<String> source) {
|
171
|
-
// Generate id for this script.
|
172
|
-
int id;
|
173
|
-
if (Heap::last_script_id()->IsUndefined()) {
|
174
|
-
// Script ids start from one.
|
175
|
-
id = 1;
|
176
|
-
} else {
|
177
|
-
// Increment id, wrap when positive smi is exhausted.
|
178
|
-
id = Smi::cast(Heap::last_script_id())->value();
|
179
|
-
id++;
|
180
|
-
if (!Smi::IsValid(id)) {
|
181
|
-
id = 0;
|
182
|
-
}
|
183
|
-
}
|
184
|
-
Heap::SetLastScriptId(Smi::FromInt(id));
|
185
|
-
|
186
|
-
// Create and initialize script object.
|
187
|
-
Handle<Proxy> wrapper = Factory::NewProxy(0, TENURED);
|
188
|
-
Handle<Script> script = Handle<Script>::cast(NewStruct(SCRIPT_TYPE));
|
189
|
-
script->set_source(*source);
|
190
|
-
script->set_name(Heap::undefined_value());
|
191
|
-
script->set_id(Heap::last_script_id());
|
192
|
-
script->set_line_offset(Smi::FromInt(0));
|
193
|
-
script->set_column_offset(Smi::FromInt(0));
|
194
|
-
script->set_data(Heap::undefined_value());
|
195
|
-
script->set_context_data(Heap::undefined_value());
|
196
|
-
script->set_type(Smi::FromInt(Script::TYPE_NORMAL));
|
197
|
-
script->set_compilation_type(Smi::FromInt(Script::COMPILATION_TYPE_HOST));
|
198
|
-
script->set_wrapper(*wrapper);
|
199
|
-
script->set_line_ends(Heap::undefined_value());
|
200
|
-
script->set_eval_from_shared(Heap::undefined_value());
|
201
|
-
script->set_eval_from_instructions_offset(Smi::FromInt(0));
|
202
|
-
|
203
|
-
return script;
|
204
|
-
}
|
205
|
-
|
206
|
-
|
207
|
-
Handle<Proxy> Factory::NewProxy(Address addr, PretenureFlag pretenure) {
|
208
|
-
CALL_HEAP_FUNCTION(Heap::AllocateProxy(addr, pretenure), Proxy);
|
209
|
-
}
|
210
|
-
|
211
|
-
|
212
|
-
Handle<Proxy> Factory::NewProxy(const AccessorDescriptor* desc) {
|
213
|
-
return NewProxy((Address) desc, TENURED);
|
214
|
-
}
|
215
|
-
|
216
|
-
|
217
|
-
Handle<ByteArray> Factory::NewByteArray(int length, PretenureFlag pretenure) {
|
218
|
-
ASSERT(0 <= length);
|
219
|
-
CALL_HEAP_FUNCTION(Heap::AllocateByteArray(length, pretenure), ByteArray);
|
220
|
-
}
|
221
|
-
|
222
|
-
|
223
|
-
Handle<PixelArray> Factory::NewPixelArray(int length,
|
224
|
-
uint8_t* external_pointer,
|
225
|
-
PretenureFlag pretenure) {
|
226
|
-
ASSERT(0 <= length);
|
227
|
-
CALL_HEAP_FUNCTION(Heap::AllocatePixelArray(length,
|
228
|
-
external_pointer,
|
229
|
-
pretenure), PixelArray);
|
230
|
-
}
|
231
|
-
|
232
|
-
|
233
|
-
Handle<ExternalArray> Factory::NewExternalArray(int length,
|
234
|
-
ExternalArrayType array_type,
|
235
|
-
void* external_pointer,
|
236
|
-
PretenureFlag pretenure) {
|
237
|
-
ASSERT(0 <= length);
|
238
|
-
CALL_HEAP_FUNCTION(Heap::AllocateExternalArray(length,
|
239
|
-
array_type,
|
240
|
-
external_pointer,
|
241
|
-
pretenure), ExternalArray);
|
242
|
-
}
|
243
|
-
|
244
|
-
|
245
|
-
Handle<Map> Factory::NewMap(InstanceType type, int instance_size) {
|
246
|
-
CALL_HEAP_FUNCTION(Heap::AllocateMap(type, instance_size), Map);
|
247
|
-
}
|
248
|
-
|
249
|
-
|
250
|
-
Handle<JSObject> Factory::NewFunctionPrototype(Handle<JSFunction> function) {
|
251
|
-
CALL_HEAP_FUNCTION(Heap::AllocateFunctionPrototype(*function), JSObject);
|
252
|
-
}
|
253
|
-
|
254
|
-
|
255
|
-
Handle<Map> Factory::CopyMapDropDescriptors(Handle<Map> src) {
|
256
|
-
CALL_HEAP_FUNCTION(src->CopyDropDescriptors(), Map);
|
257
|
-
}
|
258
|
-
|
259
|
-
|
260
|
-
Handle<Map> Factory::CopyMap(Handle<Map> src,
|
261
|
-
int extra_inobject_properties) {
|
262
|
-
Handle<Map> copy = CopyMapDropDescriptors(src);
|
263
|
-
// Check that we do not overflow the instance size when adding the
|
264
|
-
// extra inobject properties.
|
265
|
-
int instance_size_delta = extra_inobject_properties * kPointerSize;
|
266
|
-
int max_instance_size_delta =
|
267
|
-
JSObject::kMaxInstanceSize - copy->instance_size();
|
268
|
-
if (instance_size_delta > max_instance_size_delta) {
|
269
|
-
// If the instance size overflows, we allocate as many properties
|
270
|
-
// as we can as inobject properties.
|
271
|
-
instance_size_delta = max_instance_size_delta;
|
272
|
-
extra_inobject_properties = max_instance_size_delta >> kPointerSizeLog2;
|
273
|
-
}
|
274
|
-
// Adjust the map with the extra inobject properties.
|
275
|
-
int inobject_properties =
|
276
|
-
copy->inobject_properties() + extra_inobject_properties;
|
277
|
-
copy->set_inobject_properties(inobject_properties);
|
278
|
-
copy->set_unused_property_fields(inobject_properties);
|
279
|
-
copy->set_instance_size(copy->instance_size() + instance_size_delta);
|
280
|
-
copy->set_scavenger(Heap::GetScavenger(copy->instance_type(),
|
281
|
-
copy->instance_size()));
|
282
|
-
return copy;
|
283
|
-
}
|
284
|
-
|
285
|
-
|
286
|
-
Handle<Map> Factory::CopyMapDropTransitions(Handle<Map> src) {
|
287
|
-
CALL_HEAP_FUNCTION(src->CopyDropTransitions(), Map);
|
288
|
-
}
|
289
|
-
|
290
|
-
|
291
|
-
Handle<Map> Factory::GetFastElementsMap(Handle<Map> src) {
|
292
|
-
CALL_HEAP_FUNCTION(src->GetFastElementsMap(), Map);
|
293
|
-
}
|
294
|
-
|
295
|
-
|
296
|
-
Handle<Map> Factory::GetSlowElementsMap(Handle<Map> src) {
|
297
|
-
CALL_HEAP_FUNCTION(src->GetSlowElementsMap(), Map);
|
298
|
-
}
|
299
|
-
|
300
|
-
|
301
|
-
Handle<FixedArray> Factory::CopyFixedArray(Handle<FixedArray> array) {
|
302
|
-
CALL_HEAP_FUNCTION(array->Copy(), FixedArray);
|
303
|
-
}
|
304
|
-
|
305
|
-
|
306
|
-
Handle<JSFunction> Factory::BaseNewFunctionFromSharedFunctionInfo(
|
307
|
-
Handle<SharedFunctionInfo> function_info,
|
308
|
-
Handle<Map> function_map,
|
309
|
-
PretenureFlag pretenure) {
|
310
|
-
CALL_HEAP_FUNCTION(Heap::AllocateFunction(*function_map,
|
311
|
-
*function_info,
|
312
|
-
Heap::the_hole_value(),
|
313
|
-
pretenure),
|
314
|
-
JSFunction);
|
315
|
-
}
|
316
|
-
|
317
|
-
|
318
|
-
Handle<JSFunction> Factory::NewFunctionFromSharedFunctionInfo(
|
319
|
-
Handle<SharedFunctionInfo> function_info,
|
320
|
-
Handle<Context> context,
|
321
|
-
PretenureFlag pretenure) {
|
322
|
-
Handle<JSFunction> result = BaseNewFunctionFromSharedFunctionInfo(
|
323
|
-
function_info, Top::function_map(), pretenure);
|
324
|
-
result->set_context(*context);
|
325
|
-
int number_of_literals = function_info->num_literals();
|
326
|
-
Handle<FixedArray> literals =
|
327
|
-
Factory::NewFixedArray(number_of_literals, pretenure);
|
328
|
-
if (number_of_literals > 0) {
|
329
|
-
// Store the object, regexp and array functions in the literals
|
330
|
-
// array prefix. These functions will be used when creating
|
331
|
-
// object, regexp and array literals in this function.
|
332
|
-
literals->set(JSFunction::kLiteralGlobalContextIndex,
|
333
|
-
context->global_context());
|
334
|
-
}
|
335
|
-
result->set_literals(*literals);
|
336
|
-
return result;
|
337
|
-
}
|
338
|
-
|
339
|
-
|
340
|
-
Handle<Object> Factory::NewNumber(double value,
|
341
|
-
PretenureFlag pretenure) {
|
342
|
-
CALL_HEAP_FUNCTION(Heap::NumberFromDouble(value, pretenure), Object);
|
343
|
-
}
|
344
|
-
|
345
|
-
|
346
|
-
Handle<Object> Factory::NewNumberFromInt(int value) {
|
347
|
-
CALL_HEAP_FUNCTION(Heap::NumberFromInt32(value), Object);
|
348
|
-
}
|
349
|
-
|
350
|
-
|
351
|
-
Handle<Object> Factory::NewNumberFromUint(uint32_t value) {
|
352
|
-
CALL_HEAP_FUNCTION(Heap::NumberFromUint32(value), Object);
|
353
|
-
}
|
354
|
-
|
355
|
-
|
356
|
-
Handle<JSObject> Factory::NewNeanderObject() {
|
357
|
-
CALL_HEAP_FUNCTION(Heap::AllocateJSObjectFromMap(Heap::neander_map()),
|
358
|
-
JSObject);
|
359
|
-
}
|
360
|
-
|
361
|
-
|
362
|
-
Handle<Object> Factory::NewTypeError(const char* type,
|
363
|
-
Vector< Handle<Object> > args) {
|
364
|
-
return NewError("MakeTypeError", type, args);
|
365
|
-
}
|
366
|
-
|
367
|
-
|
368
|
-
Handle<Object> Factory::NewTypeError(Handle<String> message) {
|
369
|
-
return NewError("$TypeError", message);
|
370
|
-
}
|
371
|
-
|
372
|
-
|
373
|
-
Handle<Object> Factory::NewRangeError(const char* type,
|
374
|
-
Vector< Handle<Object> > args) {
|
375
|
-
return NewError("MakeRangeError", type, args);
|
376
|
-
}
|
377
|
-
|
378
|
-
|
379
|
-
Handle<Object> Factory::NewRangeError(Handle<String> message) {
|
380
|
-
return NewError("$RangeError", message);
|
381
|
-
}
|
382
|
-
|
383
|
-
|
384
|
-
Handle<Object> Factory::NewSyntaxError(const char* type, Handle<JSArray> args) {
|
385
|
-
return NewError("MakeSyntaxError", type, args);
|
386
|
-
}
|
387
|
-
|
388
|
-
|
389
|
-
Handle<Object> Factory::NewSyntaxError(Handle<String> message) {
|
390
|
-
return NewError("$SyntaxError", message);
|
391
|
-
}
|
392
|
-
|
393
|
-
|
394
|
-
Handle<Object> Factory::NewReferenceError(const char* type,
|
395
|
-
Vector< Handle<Object> > args) {
|
396
|
-
return NewError("MakeReferenceError", type, args);
|
397
|
-
}
|
398
|
-
|
399
|
-
|
400
|
-
Handle<Object> Factory::NewReferenceError(Handle<String> message) {
|
401
|
-
return NewError("$ReferenceError", message);
|
402
|
-
}
|
403
|
-
|
404
|
-
|
405
|
-
Handle<Object> Factory::NewError(const char* maker, const char* type,
|
406
|
-
Vector< Handle<Object> > args) {
|
407
|
-
v8::HandleScope scope; // Instantiate a closeable HandleScope for EscapeFrom.
|
408
|
-
Handle<FixedArray> array = Factory::NewFixedArray(args.length());
|
409
|
-
for (int i = 0; i < args.length(); i++) {
|
410
|
-
array->set(i, *args[i]);
|
411
|
-
}
|
412
|
-
Handle<JSArray> object = Factory::NewJSArrayWithElements(array);
|
413
|
-
Handle<Object> result = NewError(maker, type, object);
|
414
|
-
return result.EscapeFrom(&scope);
|
415
|
-
}
|
416
|
-
|
417
|
-
|
418
|
-
Handle<Object> Factory::NewEvalError(const char* type,
|
419
|
-
Vector< Handle<Object> > args) {
|
420
|
-
return NewError("MakeEvalError", type, args);
|
421
|
-
}
|
422
|
-
|
423
|
-
|
424
|
-
Handle<Object> Factory::NewError(const char* type,
|
425
|
-
Vector< Handle<Object> > args) {
|
426
|
-
return NewError("MakeError", type, args);
|
427
|
-
}
|
428
|
-
|
429
|
-
|
430
|
-
Handle<Object> Factory::NewError(const char* maker,
|
431
|
-
const char* type,
|
432
|
-
Handle<JSArray> args) {
|
433
|
-
Handle<String> make_str = Factory::LookupAsciiSymbol(maker);
|
434
|
-
Handle<Object> fun_obj(Top::builtins()->GetProperty(*make_str));
|
435
|
-
// If the builtins haven't been properly configured yet this error
|
436
|
-
// constructor may not have been defined. Bail out.
|
437
|
-
if (!fun_obj->IsJSFunction())
|
438
|
-
return Factory::undefined_value();
|
439
|
-
Handle<JSFunction> fun = Handle<JSFunction>::cast(fun_obj);
|
440
|
-
Handle<Object> type_obj = Factory::LookupAsciiSymbol(type);
|
441
|
-
Object** argv[2] = { type_obj.location(),
|
442
|
-
Handle<Object>::cast(args).location() };
|
443
|
-
|
444
|
-
// Invoke the JavaScript factory method. If an exception is thrown while
|
445
|
-
// running the factory method, use the exception as the result.
|
446
|
-
bool caught_exception;
|
447
|
-
Handle<Object> result = Execution::TryCall(fun,
|
448
|
-
Top::builtins(),
|
449
|
-
2,
|
450
|
-
argv,
|
451
|
-
&caught_exception);
|
452
|
-
return result;
|
453
|
-
}
|
454
|
-
|
455
|
-
|
456
|
-
Handle<Object> Factory::NewError(Handle<String> message) {
|
457
|
-
return NewError("$Error", message);
|
458
|
-
}
|
459
|
-
|
460
|
-
|
461
|
-
Handle<Object> Factory::NewError(const char* constructor,
|
462
|
-
Handle<String> message) {
|
463
|
-
Handle<String> constr = Factory::LookupAsciiSymbol(constructor);
|
464
|
-
Handle<JSFunction> fun =
|
465
|
-
Handle<JSFunction>(
|
466
|
-
JSFunction::cast(
|
467
|
-
Top::builtins()->GetProperty(*constr)));
|
468
|
-
Object** argv[1] = { Handle<Object>::cast(message).location() };
|
469
|
-
|
470
|
-
// Invoke the JavaScript factory method. If an exception is thrown while
|
471
|
-
// running the factory method, use the exception as the result.
|
472
|
-
bool caught_exception;
|
473
|
-
Handle<Object> result = Execution::TryCall(fun,
|
474
|
-
Top::builtins(),
|
475
|
-
1,
|
476
|
-
argv,
|
477
|
-
&caught_exception);
|
478
|
-
return result;
|
479
|
-
}
|
480
|
-
|
481
|
-
|
482
|
-
Handle<JSFunction> Factory::NewFunction(Handle<String> name,
|
483
|
-
InstanceType type,
|
484
|
-
int instance_size,
|
485
|
-
Handle<Code> code,
|
486
|
-
bool force_initial_map) {
|
487
|
-
// Allocate the function
|
488
|
-
Handle<JSFunction> function = NewFunction(name, the_hole_value());
|
489
|
-
function->set_code(*code);
|
490
|
-
|
491
|
-
if (force_initial_map ||
|
492
|
-
type != JS_OBJECT_TYPE ||
|
493
|
-
instance_size != JSObject::kHeaderSize) {
|
494
|
-
Handle<Map> initial_map = NewMap(type, instance_size);
|
495
|
-
Handle<JSObject> prototype = NewFunctionPrototype(function);
|
496
|
-
initial_map->set_prototype(*prototype);
|
497
|
-
function->set_initial_map(*initial_map);
|
498
|
-
initial_map->set_constructor(*function);
|
499
|
-
} else {
|
500
|
-
ASSERT(!function->has_initial_map());
|
501
|
-
ASSERT(!function->has_prototype());
|
502
|
-
}
|
503
|
-
|
504
|
-
return function;
|
505
|
-
}
|
506
|
-
|
507
|
-
|
508
|
-
Handle<JSFunction> Factory::NewFunctionWithPrototype(Handle<String> name,
|
509
|
-
InstanceType type,
|
510
|
-
int instance_size,
|
511
|
-
Handle<JSObject> prototype,
|
512
|
-
Handle<Code> code,
|
513
|
-
bool force_initial_map) {
|
514
|
-
// Allocate the function
|
515
|
-
Handle<JSFunction> function = NewFunction(name, prototype);
|
516
|
-
|
517
|
-
function->set_code(*code);
|
518
|
-
|
519
|
-
if (force_initial_map ||
|
520
|
-
type != JS_OBJECT_TYPE ||
|
521
|
-
instance_size != JSObject::kHeaderSize) {
|
522
|
-
Handle<Map> initial_map = NewMap(type, instance_size);
|
523
|
-
function->set_initial_map(*initial_map);
|
524
|
-
initial_map->set_constructor(*function);
|
525
|
-
}
|
526
|
-
|
527
|
-
// Set function.prototype and give the prototype a constructor
|
528
|
-
// property that refers to the function.
|
529
|
-
SetPrototypeProperty(function, prototype);
|
530
|
-
SetProperty(prototype, Factory::constructor_symbol(), function, DONT_ENUM);
|
531
|
-
return function;
|
532
|
-
}
|
533
|
-
|
534
|
-
|
535
|
-
Handle<JSFunction> Factory::NewFunctionWithoutPrototype(Handle<String> name,
|
536
|
-
Handle<Code> code) {
|
537
|
-
Handle<JSFunction> function = NewFunctionWithoutPrototype(name);
|
538
|
-
function->set_code(*code);
|
539
|
-
ASSERT(!function->has_initial_map());
|
540
|
-
ASSERT(!function->has_prototype());
|
541
|
-
return function;
|
542
|
-
}
|
543
|
-
|
544
|
-
|
545
|
-
Handle<Code> Factory::NewCode(const CodeDesc& desc,
|
546
|
-
Code::Flags flags,
|
547
|
-
Handle<Object> self_ref) {
|
548
|
-
CALL_HEAP_FUNCTION(Heap::CreateCode(desc, flags, self_ref), Code);
|
549
|
-
}
|
550
|
-
|
551
|
-
|
552
|
-
Handle<Code> Factory::CopyCode(Handle<Code> code) {
|
553
|
-
CALL_HEAP_FUNCTION(Heap::CopyCode(*code), Code);
|
554
|
-
}
|
555
|
-
|
556
|
-
|
557
|
-
Handle<Code> Factory::CopyCode(Handle<Code> code, Vector<byte> reloc_info) {
|
558
|
-
CALL_HEAP_FUNCTION(Heap::CopyCode(*code, reloc_info), Code);
|
559
|
-
}
|
560
|
-
|
561
|
-
|
562
|
-
static inline Object* DoCopyInsert(DescriptorArray* array,
|
563
|
-
String* key,
|
564
|
-
Object* value,
|
565
|
-
PropertyAttributes attributes) {
|
566
|
-
CallbacksDescriptor desc(key, value, attributes);
|
567
|
-
Object* obj = array->CopyInsert(&desc, REMOVE_TRANSITIONS);
|
568
|
-
return obj;
|
569
|
-
}
|
570
|
-
|
571
|
-
|
572
|
-
// Allocate the new array.
|
573
|
-
Handle<DescriptorArray> Factory::CopyAppendProxyDescriptor(
|
574
|
-
Handle<DescriptorArray> array,
|
575
|
-
Handle<String> key,
|
576
|
-
Handle<Object> value,
|
577
|
-
PropertyAttributes attributes) {
|
578
|
-
CALL_HEAP_FUNCTION(DoCopyInsert(*array, *key, *value, attributes),
|
579
|
-
DescriptorArray);
|
580
|
-
}
|
581
|
-
|
582
|
-
|
583
|
-
Handle<String> Factory::SymbolFromString(Handle<String> value) {
|
584
|
-
CALL_HEAP_FUNCTION(Heap::LookupSymbol(*value), String);
|
585
|
-
}
|
586
|
-
|
587
|
-
|
588
|
-
Handle<DescriptorArray> Factory::CopyAppendCallbackDescriptors(
|
589
|
-
Handle<DescriptorArray> array,
|
590
|
-
Handle<Object> descriptors) {
|
591
|
-
v8::NeanderArray callbacks(descriptors);
|
592
|
-
int nof_callbacks = callbacks.length();
|
593
|
-
Handle<DescriptorArray> result =
|
594
|
-
NewDescriptorArray(array->number_of_descriptors() + nof_callbacks);
|
595
|
-
|
596
|
-
// Number of descriptors added to the result so far.
|
597
|
-
int descriptor_count = 0;
|
598
|
-
|
599
|
-
// Copy the descriptors from the array.
|
600
|
-
for (int i = 0; i < array->number_of_descriptors(); i++) {
|
601
|
-
if (array->GetType(i) != NULL_DESCRIPTOR) {
|
602
|
-
result->CopyFrom(descriptor_count++, *array, i);
|
603
|
-
}
|
604
|
-
}
|
605
|
-
|
606
|
-
// Number of duplicates detected.
|
607
|
-
int duplicates = 0;
|
608
|
-
|
609
|
-
// Fill in new callback descriptors. Process the callbacks from
|
610
|
-
// back to front so that the last callback with a given name takes
|
611
|
-
// precedence over previously added callbacks with that name.
|
612
|
-
for (int i = nof_callbacks - 1; i >= 0; i--) {
|
613
|
-
Handle<AccessorInfo> entry =
|
614
|
-
Handle<AccessorInfo>(AccessorInfo::cast(callbacks.get(i)));
|
615
|
-
// Ensure the key is a symbol before writing into the instance descriptor.
|
616
|
-
Handle<String> key =
|
617
|
-
SymbolFromString(Handle<String>(String::cast(entry->name())));
|
618
|
-
// Check if a descriptor with this name already exists before writing.
|
619
|
-
if (result->LinearSearch(*key, descriptor_count) ==
|
620
|
-
DescriptorArray::kNotFound) {
|
621
|
-
CallbacksDescriptor desc(*key, *entry, entry->property_attributes());
|
622
|
-
result->Set(descriptor_count, &desc);
|
623
|
-
descriptor_count++;
|
624
|
-
} else {
|
625
|
-
duplicates++;
|
626
|
-
}
|
627
|
-
}
|
628
|
-
|
629
|
-
// If duplicates were detected, allocate a result of the right size
|
630
|
-
// and transfer the elements.
|
631
|
-
if (duplicates > 0) {
|
632
|
-
int number_of_descriptors = result->number_of_descriptors() - duplicates;
|
633
|
-
Handle<DescriptorArray> new_result =
|
634
|
-
NewDescriptorArray(number_of_descriptors);
|
635
|
-
for (int i = 0; i < number_of_descriptors; i++) {
|
636
|
-
new_result->CopyFrom(i, *result, i);
|
637
|
-
}
|
638
|
-
result = new_result;
|
639
|
-
}
|
640
|
-
|
641
|
-
// Sort the result before returning.
|
642
|
-
result->Sort();
|
643
|
-
return result;
|
644
|
-
}
|
645
|
-
|
646
|
-
|
647
|
-
Handle<JSObject> Factory::NewJSObject(Handle<JSFunction> constructor,
|
648
|
-
PretenureFlag pretenure) {
|
649
|
-
CALL_HEAP_FUNCTION(Heap::AllocateJSObject(*constructor, pretenure), JSObject);
|
650
|
-
}
|
651
|
-
|
652
|
-
|
653
|
-
Handle<GlobalObject> Factory::NewGlobalObject(
|
654
|
-
Handle<JSFunction> constructor) {
|
655
|
-
CALL_HEAP_FUNCTION(Heap::AllocateGlobalObject(*constructor),
|
656
|
-
GlobalObject);
|
657
|
-
}
|
658
|
-
|
659
|
-
|
660
|
-
|
661
|
-
Handle<JSObject> Factory::NewJSObjectFromMap(Handle<Map> map) {
|
662
|
-
CALL_HEAP_FUNCTION(Heap::AllocateJSObjectFromMap(*map, NOT_TENURED),
|
663
|
-
JSObject);
|
664
|
-
}
|
665
|
-
|
666
|
-
|
667
|
-
Handle<JSArray> Factory::NewJSArray(int length,
|
668
|
-
PretenureFlag pretenure) {
|
669
|
-
Handle<JSObject> obj = NewJSObject(Top::array_function(), pretenure);
|
670
|
-
CALL_HEAP_FUNCTION(Handle<JSArray>::cast(obj)->Initialize(length), JSArray);
|
671
|
-
}
|
672
|
-
|
673
|
-
|
674
|
-
Handle<JSArray> Factory::NewJSArrayWithElements(Handle<FixedArray> elements,
|
675
|
-
PretenureFlag pretenure) {
|
676
|
-
Handle<JSArray> result =
|
677
|
-
Handle<JSArray>::cast(NewJSObject(Top::array_function(), pretenure));
|
678
|
-
result->SetContent(*elements);
|
679
|
-
return result;
|
680
|
-
}
|
681
|
-
|
682
|
-
|
683
|
-
Handle<SharedFunctionInfo> Factory::NewSharedFunctionInfo(
|
684
|
-
Handle<String> name,
|
685
|
-
int number_of_literals,
|
686
|
-
Handle<Code> code,
|
687
|
-
Handle<SerializedScopeInfo> scope_info) {
|
688
|
-
Handle<SharedFunctionInfo> shared = NewSharedFunctionInfo(name);
|
689
|
-
shared->set_code(*code);
|
690
|
-
shared->set_scope_info(*scope_info);
|
691
|
-
int literals_array_size = number_of_literals;
|
692
|
-
// If the function contains object, regexp or array literals,
|
693
|
-
// allocate extra space for a literals array prefix containing the
|
694
|
-
// context.
|
695
|
-
if (number_of_literals > 0) {
|
696
|
-
literals_array_size += JSFunction::kLiteralsPrefixSize;
|
697
|
-
}
|
698
|
-
shared->set_num_literals(literals_array_size);
|
699
|
-
return shared;
|
700
|
-
}
|
701
|
-
|
702
|
-
|
703
|
-
Handle<SharedFunctionInfo> Factory::NewSharedFunctionInfo(Handle<String> name) {
|
704
|
-
CALL_HEAP_FUNCTION(Heap::AllocateSharedFunctionInfo(*name),
|
705
|
-
SharedFunctionInfo);
|
706
|
-
}
|
707
|
-
|
708
|
-
|
709
|
-
Handle<String> Factory::NumberToString(Handle<Object> number) {
|
710
|
-
CALL_HEAP_FUNCTION(Heap::NumberToString(*number), String);
|
711
|
-
}
|
712
|
-
|
713
|
-
|
714
|
-
Handle<NumberDictionary> Factory::DictionaryAtNumberPut(
|
715
|
-
Handle<NumberDictionary> dictionary,
|
716
|
-
uint32_t key,
|
717
|
-
Handle<Object> value) {
|
718
|
-
CALL_HEAP_FUNCTION(dictionary->AtNumberPut(key, *value), NumberDictionary);
|
719
|
-
}
|
720
|
-
|
721
|
-
|
722
|
-
Handle<JSFunction> Factory::NewFunctionHelper(Handle<String> name,
|
723
|
-
Handle<Object> prototype) {
|
724
|
-
Handle<SharedFunctionInfo> function_share = NewSharedFunctionInfo(name);
|
725
|
-
CALL_HEAP_FUNCTION(Heap::AllocateFunction(*Top::function_map(),
|
726
|
-
*function_share,
|
727
|
-
*prototype),
|
728
|
-
JSFunction);
|
729
|
-
}
|
730
|
-
|
731
|
-
|
732
|
-
Handle<JSFunction> Factory::NewFunction(Handle<String> name,
|
733
|
-
Handle<Object> prototype) {
|
734
|
-
Handle<JSFunction> fun = NewFunctionHelper(name, prototype);
|
735
|
-
fun->set_context(Top::context()->global_context());
|
736
|
-
return fun;
|
737
|
-
}
|
738
|
-
|
739
|
-
|
740
|
-
Handle<JSFunction> Factory::NewFunctionWithoutPrototypeHelper(
|
741
|
-
Handle<String> name) {
|
742
|
-
Handle<SharedFunctionInfo> function_share = NewSharedFunctionInfo(name);
|
743
|
-
CALL_HEAP_FUNCTION(Heap::AllocateFunction(
|
744
|
-
*Top::function_without_prototype_map(),
|
745
|
-
*function_share,
|
746
|
-
*the_hole_value()),
|
747
|
-
JSFunction);
|
748
|
-
}
|
749
|
-
|
750
|
-
|
751
|
-
Handle<JSFunction> Factory::NewFunctionWithoutPrototype(Handle<String> name) {
|
752
|
-
Handle<JSFunction> fun = NewFunctionWithoutPrototypeHelper(name);
|
753
|
-
fun->set_context(Top::context()->global_context());
|
754
|
-
return fun;
|
755
|
-
}
|
756
|
-
|
757
|
-
|
758
|
-
Handle<Object> Factory::ToObject(Handle<Object> object) {
|
759
|
-
CALL_HEAP_FUNCTION(object->ToObject(), Object);
|
760
|
-
}
|
761
|
-
|
762
|
-
|
763
|
-
Handle<Object> Factory::ToObject(Handle<Object> object,
|
764
|
-
Handle<Context> global_context) {
|
765
|
-
CALL_HEAP_FUNCTION(object->ToObject(*global_context), Object);
|
766
|
-
}
|
767
|
-
|
768
|
-
|
769
|
-
#ifdef ENABLE_DEBUGGER_SUPPORT
|
770
|
-
Handle<DebugInfo> Factory::NewDebugInfo(Handle<SharedFunctionInfo> shared) {
|
771
|
-
// Get the original code of the function.
|
772
|
-
Handle<Code> code(shared->code());
|
773
|
-
|
774
|
-
// Create a copy of the code before allocating the debug info object to avoid
|
775
|
-
// allocation while setting up the debug info object.
|
776
|
-
Handle<Code> original_code(*Factory::CopyCode(code));
|
777
|
-
|
778
|
-
// Allocate initial fixed array for active break points before allocating the
|
779
|
-
// debug info object to avoid allocation while setting up the debug info
|
780
|
-
// object.
|
781
|
-
Handle<FixedArray> break_points(
|
782
|
-
Factory::NewFixedArray(Debug::kEstimatedNofBreakPointsInFunction));
|
783
|
-
|
784
|
-
// Create and set up the debug info object. Debug info contains function, a
|
785
|
-
// copy of the original code, the executing code and initial fixed array for
|
786
|
-
// active break points.
|
787
|
-
Handle<DebugInfo> debug_info =
|
788
|
-
Handle<DebugInfo>::cast(Factory::NewStruct(DEBUG_INFO_TYPE));
|
789
|
-
debug_info->set_shared(*shared);
|
790
|
-
debug_info->set_original_code(*original_code);
|
791
|
-
debug_info->set_code(*code);
|
792
|
-
debug_info->set_break_points(*break_points);
|
793
|
-
|
794
|
-
// Link debug info to function.
|
795
|
-
shared->set_debug_info(*debug_info);
|
796
|
-
|
797
|
-
return debug_info;
|
798
|
-
}
|
799
|
-
#endif
|
800
|
-
|
801
|
-
|
802
|
-
Handle<JSObject> Factory::NewArgumentsObject(Handle<Object> callee,
|
803
|
-
int length) {
|
804
|
-
CALL_HEAP_FUNCTION(Heap::AllocateArgumentsObject(*callee, length), JSObject);
|
805
|
-
}
|
806
|
-
|
807
|
-
|
808
|
-
Handle<JSFunction> Factory::CreateApiFunction(
|
809
|
-
Handle<FunctionTemplateInfo> obj, ApiInstanceType instance_type) {
|
810
|
-
Handle<Code> code = Handle<Code>(Builtins::builtin(Builtins::HandleApiCall));
|
811
|
-
Handle<Code> construct_stub =
|
812
|
-
Handle<Code>(Builtins::builtin(Builtins::JSConstructStubApi));
|
813
|
-
|
814
|
-
int internal_field_count = 0;
|
815
|
-
if (!obj->instance_template()->IsUndefined()) {
|
816
|
-
Handle<ObjectTemplateInfo> instance_template =
|
817
|
-
Handle<ObjectTemplateInfo>(
|
818
|
-
ObjectTemplateInfo::cast(obj->instance_template()));
|
819
|
-
internal_field_count =
|
820
|
-
Smi::cast(instance_template->internal_field_count())->value();
|
821
|
-
}
|
822
|
-
|
823
|
-
int instance_size = kPointerSize * internal_field_count;
|
824
|
-
InstanceType type = INVALID_TYPE;
|
825
|
-
switch (instance_type) {
|
826
|
-
case JavaScriptObject:
|
827
|
-
type = JS_OBJECT_TYPE;
|
828
|
-
instance_size += JSObject::kHeaderSize;
|
829
|
-
break;
|
830
|
-
case InnerGlobalObject:
|
831
|
-
type = JS_GLOBAL_OBJECT_TYPE;
|
832
|
-
instance_size += JSGlobalObject::kSize;
|
833
|
-
break;
|
834
|
-
case OuterGlobalObject:
|
835
|
-
type = JS_GLOBAL_PROXY_TYPE;
|
836
|
-
instance_size += JSGlobalProxy::kSize;
|
837
|
-
break;
|
838
|
-
default:
|
839
|
-
break;
|
840
|
-
}
|
841
|
-
ASSERT(type != INVALID_TYPE);
|
842
|
-
|
843
|
-
Handle<JSFunction> result =
|
844
|
-
Factory::NewFunction(Factory::empty_symbol(),
|
845
|
-
type,
|
846
|
-
instance_size,
|
847
|
-
code,
|
848
|
-
true);
|
849
|
-
// Set class name.
|
850
|
-
Handle<Object> class_name = Handle<Object>(obj->class_name());
|
851
|
-
if (class_name->IsString()) {
|
852
|
-
result->shared()->set_instance_class_name(*class_name);
|
853
|
-
result->shared()->set_name(*class_name);
|
854
|
-
}
|
855
|
-
|
856
|
-
Handle<Map> map = Handle<Map>(result->initial_map());
|
857
|
-
|
858
|
-
// Mark as undetectable if needed.
|
859
|
-
if (obj->undetectable()) {
|
860
|
-
map->set_is_undetectable();
|
861
|
-
}
|
862
|
-
|
863
|
-
// Mark as hidden for the __proto__ accessor if needed.
|
864
|
-
if (obj->hidden_prototype()) {
|
865
|
-
map->set_is_hidden_prototype();
|
866
|
-
}
|
867
|
-
|
868
|
-
// Mark as needs_access_check if needed.
|
869
|
-
if (obj->needs_access_check()) {
|
870
|
-
map->set_is_access_check_needed(true);
|
871
|
-
}
|
872
|
-
|
873
|
-
// Set interceptor information in the map.
|
874
|
-
if (!obj->named_property_handler()->IsUndefined()) {
|
875
|
-
map->set_has_named_interceptor();
|
876
|
-
}
|
877
|
-
if (!obj->indexed_property_handler()->IsUndefined()) {
|
878
|
-
map->set_has_indexed_interceptor();
|
879
|
-
}
|
880
|
-
|
881
|
-
// Set instance call-as-function information in the map.
|
882
|
-
if (!obj->instance_call_handler()->IsUndefined()) {
|
883
|
-
map->set_has_instance_call_handler();
|
884
|
-
}
|
885
|
-
|
886
|
-
result->shared()->set_function_data(*obj);
|
887
|
-
result->shared()->set_construct_stub(*construct_stub);
|
888
|
-
result->shared()->DontAdaptArguments();
|
889
|
-
|
890
|
-
// Recursively copy parent templates' accessors, 'data' may be modified.
|
891
|
-
Handle<DescriptorArray> array =
|
892
|
-
Handle<DescriptorArray>(map->instance_descriptors());
|
893
|
-
while (true) {
|
894
|
-
Handle<Object> props = Handle<Object>(obj->property_accessors());
|
895
|
-
if (!props->IsUndefined()) {
|
896
|
-
array = Factory::CopyAppendCallbackDescriptors(array, props);
|
897
|
-
}
|
898
|
-
Handle<Object> parent = Handle<Object>(obj->parent_template());
|
899
|
-
if (parent->IsUndefined()) break;
|
900
|
-
obj = Handle<FunctionTemplateInfo>::cast(parent);
|
901
|
-
}
|
902
|
-
if (!array->IsEmpty()) {
|
903
|
-
map->set_instance_descriptors(*array);
|
904
|
-
}
|
905
|
-
|
906
|
-
ASSERT(result->shared()->IsApiFunction());
|
907
|
-
return result;
|
908
|
-
}
|
909
|
-
|
910
|
-
|
911
|
-
Handle<MapCache> Factory::NewMapCache(int at_least_space_for) {
|
912
|
-
CALL_HEAP_FUNCTION(MapCache::Allocate(at_least_space_for), MapCache);
|
913
|
-
}
|
914
|
-
|
915
|
-
|
916
|
-
static Object* UpdateMapCacheWith(Context* context,
|
917
|
-
FixedArray* keys,
|
918
|
-
Map* map) {
|
919
|
-
Object* result = MapCache::cast(context->map_cache())->Put(keys, map);
|
920
|
-
if (!result->IsFailure()) context->set_map_cache(MapCache::cast(result));
|
921
|
-
return result;
|
922
|
-
}
|
923
|
-
|
924
|
-
|
925
|
-
Handle<MapCache> Factory::AddToMapCache(Handle<Context> context,
|
926
|
-
Handle<FixedArray> keys,
|
927
|
-
Handle<Map> map) {
|
928
|
-
CALL_HEAP_FUNCTION(UpdateMapCacheWith(*context, *keys, *map), MapCache);
|
929
|
-
}
|
930
|
-
|
931
|
-
|
932
|
-
Handle<Map> Factory::ObjectLiteralMapFromCache(Handle<Context> context,
|
933
|
-
Handle<FixedArray> keys) {
|
934
|
-
if (context->map_cache()->IsUndefined()) {
|
935
|
-
// Allocate the new map cache for the global context.
|
936
|
-
Handle<MapCache> new_cache = NewMapCache(24);
|
937
|
-
context->set_map_cache(*new_cache);
|
938
|
-
}
|
939
|
-
// Check to see whether there is a matching element in the cache.
|
940
|
-
Handle<MapCache> cache =
|
941
|
-
Handle<MapCache>(MapCache::cast(context->map_cache()));
|
942
|
-
Handle<Object> result = Handle<Object>(cache->Lookup(*keys));
|
943
|
-
if (result->IsMap()) return Handle<Map>::cast(result);
|
944
|
-
// Create a new map and add it to the cache.
|
945
|
-
Handle<Map> map =
|
946
|
-
CopyMap(Handle<Map>(context->object_function()->initial_map()),
|
947
|
-
keys->length());
|
948
|
-
AddToMapCache(context, keys, map);
|
949
|
-
return Handle<Map>(map);
|
950
|
-
}
|
951
|
-
|
952
|
-
|
953
|
-
void Factory::SetRegExpAtomData(Handle<JSRegExp> regexp,
|
954
|
-
JSRegExp::Type type,
|
955
|
-
Handle<String> source,
|
956
|
-
JSRegExp::Flags flags,
|
957
|
-
Handle<Object> data) {
|
958
|
-
Handle<FixedArray> store = NewFixedArray(JSRegExp::kAtomDataSize);
|
959
|
-
|
960
|
-
store->set(JSRegExp::kTagIndex, Smi::FromInt(type));
|
961
|
-
store->set(JSRegExp::kSourceIndex, *source);
|
962
|
-
store->set(JSRegExp::kFlagsIndex, Smi::FromInt(flags.value()));
|
963
|
-
store->set(JSRegExp::kAtomPatternIndex, *data);
|
964
|
-
regexp->set_data(*store);
|
965
|
-
}
|
966
|
-
|
967
|
-
void Factory::SetRegExpIrregexpData(Handle<JSRegExp> regexp,
|
968
|
-
JSRegExp::Type type,
|
969
|
-
Handle<String> source,
|
970
|
-
JSRegExp::Flags flags,
|
971
|
-
int capture_count) {
|
972
|
-
Handle<FixedArray> store = NewFixedArray(JSRegExp::kIrregexpDataSize);
|
973
|
-
|
974
|
-
store->set(JSRegExp::kTagIndex, Smi::FromInt(type));
|
975
|
-
store->set(JSRegExp::kSourceIndex, *source);
|
976
|
-
store->set(JSRegExp::kFlagsIndex, Smi::FromInt(flags.value()));
|
977
|
-
store->set(JSRegExp::kIrregexpASCIICodeIndex, Heap::the_hole_value());
|
978
|
-
store->set(JSRegExp::kIrregexpUC16CodeIndex, Heap::the_hole_value());
|
979
|
-
store->set(JSRegExp::kIrregexpMaxRegisterCountIndex, Smi::FromInt(0));
|
980
|
-
store->set(JSRegExp::kIrregexpCaptureCountIndex,
|
981
|
-
Smi::FromInt(capture_count));
|
982
|
-
regexp->set_data(*store);
|
983
|
-
}
|
984
|
-
|
985
|
-
|
986
|
-
|
987
|
-
void Factory::ConfigureInstance(Handle<FunctionTemplateInfo> desc,
|
988
|
-
Handle<JSObject> instance,
|
989
|
-
bool* pending_exception) {
|
990
|
-
// Configure the instance by adding the properties specified by the
|
991
|
-
// instance template.
|
992
|
-
Handle<Object> instance_template = Handle<Object>(desc->instance_template());
|
993
|
-
if (!instance_template->IsUndefined()) {
|
994
|
-
Execution::ConfigureInstance(instance,
|
995
|
-
instance_template,
|
996
|
-
pending_exception);
|
997
|
-
} else {
|
998
|
-
*pending_exception = false;
|
999
|
-
}
|
1000
|
-
}
|
1001
|
-
|
1002
|
-
|
1003
|
-
} } // namespace v8::internal
|