therubyracer 0.4.9-x86-linux
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/.gitignore +11 -0
- data/.gitmodules +3 -0
- data/Doxyfile +1514 -0
- data/History.txt +43 -0
- data/README.rdoc +157 -0
- data/Rakefile +51 -0
- data/docs/data_conversion.txt +18 -0
- data/ext/v8/callbacks.cpp +160 -0
- data/ext/v8/callbacks.h +14 -0
- data/ext/v8/convert_ruby.cpp +8 -0
- data/ext/v8/convert_ruby.h +99 -0
- data/ext/v8/convert_string.cpp +10 -0
- data/ext/v8/convert_string.h +73 -0
- data/ext/v8/convert_v8.cpp +9 -0
- data/ext/v8/convert_v8.h +121 -0
- data/ext/v8/converters.cpp +83 -0
- data/ext/v8/converters.h +23 -0
- data/ext/v8/extconf.rb +36 -0
- data/ext/v8/upstream/2.0.6/.gitignore +26 -0
- data/ext/v8/upstream/2.0.6/AUTHORS +23 -0
- data/ext/v8/upstream/2.0.6/ChangeLog +1479 -0
- data/ext/v8/upstream/2.0.6/LICENSE +55 -0
- data/ext/v8/upstream/2.0.6/SConstruct +1028 -0
- data/ext/v8/upstream/2.0.6/include/v8-debug.h +275 -0
- data/ext/v8/upstream/2.0.6/include/v8.h +3236 -0
- data/ext/v8/upstream/2.0.6/src/SConscript +283 -0
- data/ext/v8/upstream/2.0.6/src/accessors.cc +695 -0
- data/ext/v8/upstream/2.0.6/src/accessors.h +114 -0
- data/ext/v8/upstream/2.0.6/src/allocation.cc +198 -0
- data/ext/v8/upstream/2.0.6/src/allocation.h +169 -0
- data/ext/v8/upstream/2.0.6/src/api.cc +3831 -0
- data/ext/v8/upstream/2.0.6/src/api.h +479 -0
- data/ext/v8/upstream/2.0.6/src/apinatives.js +110 -0
- data/ext/v8/upstream/2.0.6/src/apiutils.h +69 -0
- data/ext/v8/upstream/2.0.6/src/arguments.h +97 -0
- data/ext/v8/upstream/2.0.6/src/arm/assembler-arm-inl.h +277 -0
- data/ext/v8/upstream/2.0.6/src/arm/assembler-arm.cc +1821 -0
- data/ext/v8/upstream/2.0.6/src/arm/assembler-arm.h +1027 -0
- data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2-inl.h +267 -0
- data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2.cc +1821 -0
- data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2.h +1027 -0
- data/ext/v8/upstream/2.0.6/src/arm/builtins-arm.cc +1271 -0
- data/ext/v8/upstream/2.0.6/src/arm/codegen-arm-inl.h +74 -0
- data/ext/v8/upstream/2.0.6/src/arm/codegen-arm.cc +6682 -0
- data/ext/v8/upstream/2.0.6/src/arm/codegen-arm.h +535 -0
- data/ext/v8/upstream/2.0.6/src/arm/constants-arm.cc +112 -0
- data/ext/v8/upstream/2.0.6/src/arm/constants-arm.h +347 -0
- data/ext/v8/upstream/2.0.6/src/arm/cpu-arm.cc +132 -0
- data/ext/v8/upstream/2.0.6/src/arm/debug-arm.cc +213 -0
- data/ext/v8/upstream/2.0.6/src/arm/disasm-arm.cc +1166 -0
- data/ext/v8/upstream/2.0.6/src/arm/fast-codegen-arm.cc +1698 -0
- data/ext/v8/upstream/2.0.6/src/arm/frames-arm.cc +123 -0
- data/ext/v8/upstream/2.0.6/src/arm/frames-arm.h +162 -0
- data/ext/v8/upstream/2.0.6/src/arm/ic-arm.cc +849 -0
- data/ext/v8/upstream/2.0.6/src/arm/jump-target-arm.cc +238 -0
- data/ext/v8/upstream/2.0.6/src/arm/macro-assembler-arm.cc +1259 -0
- data/ext/v8/upstream/2.0.6/src/arm/macro-assembler-arm.h +423 -0
- data/ext/v8/upstream/2.0.6/src/arm/regexp-macro-assembler-arm.cc +1266 -0
- data/ext/v8/upstream/2.0.6/src/arm/regexp-macro-assembler-arm.h +282 -0
- data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm-inl.h +103 -0
- data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm.cc +59 -0
- data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm.h +43 -0
- data/ext/v8/upstream/2.0.6/src/arm/simulator-arm.cc +2264 -0
- data/ext/v8/upstream/2.0.6/src/arm/simulator-arm.h +306 -0
- data/ext/v8/upstream/2.0.6/src/arm/stub-cache-arm.cc +1516 -0
- data/ext/v8/upstream/2.0.6/src/arm/virtual-frame-arm.cc +412 -0
- data/ext/v8/upstream/2.0.6/src/arm/virtual-frame-arm.h +532 -0
- data/ext/v8/upstream/2.0.6/src/array.js +1154 -0
- data/ext/v8/upstream/2.0.6/src/assembler.cc +772 -0
- data/ext/v8/upstream/2.0.6/src/assembler.h +525 -0
- data/ext/v8/upstream/2.0.6/src/ast.cc +512 -0
- data/ext/v8/upstream/2.0.6/src/ast.h +1820 -0
- data/ext/v8/upstream/2.0.6/src/bootstrapper.cc +1680 -0
- data/ext/v8/upstream/2.0.6/src/bootstrapper.h +103 -0
- data/ext/v8/upstream/2.0.6/src/builtins.cc +851 -0
- data/ext/v8/upstream/2.0.6/src/builtins.h +245 -0
- data/ext/v8/upstream/2.0.6/src/bytecodes-irregexp.h +104 -0
- data/ext/v8/upstream/2.0.6/src/char-predicates-inl.h +86 -0
- data/ext/v8/upstream/2.0.6/src/char-predicates.h +65 -0
- data/ext/v8/upstream/2.0.6/src/checks.cc +100 -0
- data/ext/v8/upstream/2.0.6/src/checks.h +284 -0
- data/ext/v8/upstream/2.0.6/src/code-stubs.cc +164 -0
- data/ext/v8/upstream/2.0.6/src/code-stubs.h +164 -0
- data/ext/v8/upstream/2.0.6/src/code.h +68 -0
- data/ext/v8/upstream/2.0.6/src/codegen-inl.h +88 -0
- data/ext/v8/upstream/2.0.6/src/codegen.cc +504 -0
- data/ext/v8/upstream/2.0.6/src/codegen.h +522 -0
- data/ext/v8/upstream/2.0.6/src/compilation-cache.cc +490 -0
- data/ext/v8/upstream/2.0.6/src/compilation-cache.h +98 -0
- data/ext/v8/upstream/2.0.6/src/compiler.cc +1132 -0
- data/ext/v8/upstream/2.0.6/src/compiler.h +107 -0
- data/ext/v8/upstream/2.0.6/src/contexts.cc +256 -0
- data/ext/v8/upstream/2.0.6/src/contexts.h +345 -0
- data/ext/v8/upstream/2.0.6/src/conversions-inl.h +95 -0
- data/ext/v8/upstream/2.0.6/src/conversions.cc +709 -0
- data/ext/v8/upstream/2.0.6/src/conversions.h +118 -0
- data/ext/v8/upstream/2.0.6/src/counters.cc +78 -0
- data/ext/v8/upstream/2.0.6/src/counters.h +239 -0
- data/ext/v8/upstream/2.0.6/src/cpu.h +65 -0
- data/ext/v8/upstream/2.0.6/src/d8-debug.cc +345 -0
- data/ext/v8/upstream/2.0.6/src/d8-debug.h +155 -0
- data/ext/v8/upstream/2.0.6/src/d8-posix.cc +675 -0
- data/ext/v8/upstream/2.0.6/src/d8-readline.cc +128 -0
- data/ext/v8/upstream/2.0.6/src/d8-windows.cc +42 -0
- data/ext/v8/upstream/2.0.6/src/d8.cc +776 -0
- data/ext/v8/upstream/2.0.6/src/d8.h +225 -0
- data/ext/v8/upstream/2.0.6/src/d8.js +1625 -0
- data/ext/v8/upstream/2.0.6/src/date-delay.js +1138 -0
- data/ext/v8/upstream/2.0.6/src/dateparser-inl.h +114 -0
- data/ext/v8/upstream/2.0.6/src/dateparser.cc +186 -0
- data/ext/v8/upstream/2.0.6/src/dateparser.h +240 -0
- data/ext/v8/upstream/2.0.6/src/debug-agent.cc +425 -0
- data/ext/v8/upstream/2.0.6/src/debug-agent.h +129 -0
- data/ext/v8/upstream/2.0.6/src/debug-delay.js +2073 -0
- data/ext/v8/upstream/2.0.6/src/debug.cc +2751 -0
- data/ext/v8/upstream/2.0.6/src/debug.h +866 -0
- data/ext/v8/upstream/2.0.6/src/disasm.h +77 -0
- data/ext/v8/upstream/2.0.6/src/disassembler.cc +318 -0
- data/ext/v8/upstream/2.0.6/src/disassembler.h +56 -0
- data/ext/v8/upstream/2.0.6/src/dtoa-config.c +91 -0
- data/ext/v8/upstream/2.0.6/src/execution.cc +701 -0
- data/ext/v8/upstream/2.0.6/src/execution.h +312 -0
- data/ext/v8/upstream/2.0.6/src/factory.cc +957 -0
- data/ext/v8/upstream/2.0.6/src/factory.h +393 -0
- data/ext/v8/upstream/2.0.6/src/fast-codegen.cc +725 -0
- data/ext/v8/upstream/2.0.6/src/fast-codegen.h +371 -0
- data/ext/v8/upstream/2.0.6/src/flag-definitions.h +426 -0
- data/ext/v8/upstream/2.0.6/src/flags.cc +555 -0
- data/ext/v8/upstream/2.0.6/src/flags.h +81 -0
- data/ext/v8/upstream/2.0.6/src/frame-element.cc +45 -0
- data/ext/v8/upstream/2.0.6/src/frame-element.h +235 -0
- data/ext/v8/upstream/2.0.6/src/frames-inl.h +215 -0
- data/ext/v8/upstream/2.0.6/src/frames.cc +749 -0
- data/ext/v8/upstream/2.0.6/src/frames.h +659 -0
- data/ext/v8/upstream/2.0.6/src/func-name-inferrer.cc +76 -0
- data/ext/v8/upstream/2.0.6/src/func-name-inferrer.h +135 -0
- data/ext/v8/upstream/2.0.6/src/global-handles.cc +516 -0
- data/ext/v8/upstream/2.0.6/src/global-handles.h +180 -0
- data/ext/v8/upstream/2.0.6/src/globals.h +608 -0
- data/ext/v8/upstream/2.0.6/src/handles-inl.h +76 -0
- data/ext/v8/upstream/2.0.6/src/handles.cc +811 -0
- data/ext/v8/upstream/2.0.6/src/handles.h +367 -0
- data/ext/v8/upstream/2.0.6/src/hashmap.cc +226 -0
- data/ext/v8/upstream/2.0.6/src/hashmap.h +120 -0
- data/ext/v8/upstream/2.0.6/src/heap-inl.h +407 -0
- data/ext/v8/upstream/2.0.6/src/heap-profiler.cc +695 -0
- data/ext/v8/upstream/2.0.6/src/heap-profiler.h +277 -0
- data/ext/v8/upstream/2.0.6/src/heap.cc +4204 -0
- data/ext/v8/upstream/2.0.6/src/heap.h +1704 -0
- data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32-inl.h +325 -0
- data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32.cc +2375 -0
- data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32.h +914 -0
- data/ext/v8/upstream/2.0.6/src/ia32/builtins-ia32.cc +1222 -0
- data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32-inl.h +46 -0
- data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32.cc +9770 -0
- data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32.h +834 -0
- data/ext/v8/upstream/2.0.6/src/ia32/cpu-ia32.cc +79 -0
- data/ext/v8/upstream/2.0.6/src/ia32/debug-ia32.cc +208 -0
- data/ext/v8/upstream/2.0.6/src/ia32/disasm-ia32.cc +1357 -0
- data/ext/v8/upstream/2.0.6/src/ia32/fast-codegen-ia32.cc +1813 -0
- data/ext/v8/upstream/2.0.6/src/ia32/frames-ia32.cc +111 -0
- data/ext/v8/upstream/2.0.6/src/ia32/frames-ia32.h +135 -0
- data/ext/v8/upstream/2.0.6/src/ia32/ic-ia32.cc +1490 -0
- data/ext/v8/upstream/2.0.6/src/ia32/jump-target-ia32.cc +432 -0
- data/ext/v8/upstream/2.0.6/src/ia32/macro-assembler-ia32.cc +1517 -0
- data/ext/v8/upstream/2.0.6/src/ia32/macro-assembler-ia32.h +528 -0
- data/ext/v8/upstream/2.0.6/src/ia32/regexp-macro-assembler-ia32.cc +1219 -0
- data/ext/v8/upstream/2.0.6/src/ia32/regexp-macro-assembler-ia32.h +230 -0
- data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32-inl.h +82 -0
- data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32.cc +99 -0
- data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32.h +43 -0
- data/ext/v8/upstream/2.0.6/src/ia32/simulator-ia32.cc +30 -0
- data/ext/v8/upstream/2.0.6/src/ia32/simulator-ia32.h +62 -0
- data/ext/v8/upstream/2.0.6/src/ia32/stub-cache-ia32.cc +1961 -0
- data/ext/v8/upstream/2.0.6/src/ia32/virtual-frame-ia32.cc +1105 -0
- data/ext/v8/upstream/2.0.6/src/ia32/virtual-frame-ia32.h +580 -0
- data/ext/v8/upstream/2.0.6/src/ic-inl.h +93 -0
- data/ext/v8/upstream/2.0.6/src/ic.cc +1426 -0
- data/ext/v8/upstream/2.0.6/src/ic.h +443 -0
- data/ext/v8/upstream/2.0.6/src/interpreter-irregexp.cc +646 -0
- data/ext/v8/upstream/2.0.6/src/interpreter-irregexp.h +48 -0
- data/ext/v8/upstream/2.0.6/src/json-delay.js +254 -0
- data/ext/v8/upstream/2.0.6/src/jsregexp.cc +5234 -0
- data/ext/v8/upstream/2.0.6/src/jsregexp.h +1439 -0
- data/ext/v8/upstream/2.0.6/src/jump-target-inl.h +49 -0
- data/ext/v8/upstream/2.0.6/src/jump-target.cc +383 -0
- data/ext/v8/upstream/2.0.6/src/jump-target.h +280 -0
- data/ext/v8/upstream/2.0.6/src/list-inl.h +166 -0
- data/ext/v8/upstream/2.0.6/src/list.h +158 -0
- data/ext/v8/upstream/2.0.6/src/log-inl.h +126 -0
- data/ext/v8/upstream/2.0.6/src/log-utils.cc +503 -0
- data/ext/v8/upstream/2.0.6/src/log-utils.h +292 -0
- data/ext/v8/upstream/2.0.6/src/log.cc +1457 -0
- data/ext/v8/upstream/2.0.6/src/log.h +371 -0
- data/ext/v8/upstream/2.0.6/src/macro-assembler.h +93 -0
- data/ext/v8/upstream/2.0.6/src/macros.py +137 -0
- data/ext/v8/upstream/2.0.6/src/mark-compact.cc +2007 -0
- data/ext/v8/upstream/2.0.6/src/mark-compact.h +442 -0
- data/ext/v8/upstream/2.0.6/src/math.js +263 -0
- data/ext/v8/upstream/2.0.6/src/memory.h +74 -0
- data/ext/v8/upstream/2.0.6/src/messages.cc +177 -0
- data/ext/v8/upstream/2.0.6/src/messages.h +112 -0
- data/ext/v8/upstream/2.0.6/src/messages.js +937 -0
- data/ext/v8/upstream/2.0.6/src/mirror-delay.js +2332 -0
- data/ext/v8/upstream/2.0.6/src/mksnapshot.cc +169 -0
- data/ext/v8/upstream/2.0.6/src/natives.h +63 -0
- data/ext/v8/upstream/2.0.6/src/objects-debug.cc +1317 -0
- data/ext/v8/upstream/2.0.6/src/objects-inl.h +3044 -0
- data/ext/v8/upstream/2.0.6/src/objects.cc +8306 -0
- data/ext/v8/upstream/2.0.6/src/objects.h +4960 -0
- data/ext/v8/upstream/2.0.6/src/oprofile-agent.cc +116 -0
- data/ext/v8/upstream/2.0.6/src/oprofile-agent.h +69 -0
- data/ext/v8/upstream/2.0.6/src/parser.cc +4810 -0
- data/ext/v8/upstream/2.0.6/src/parser.h +195 -0
- data/ext/v8/upstream/2.0.6/src/platform-freebsd.cc +645 -0
- data/ext/v8/upstream/2.0.6/src/platform-linux.cc +808 -0
- data/ext/v8/upstream/2.0.6/src/platform-macos.cc +643 -0
- data/ext/v8/upstream/2.0.6/src/platform-nullos.cc +454 -0
- data/ext/v8/upstream/2.0.6/src/platform-openbsd.cc +597 -0
- data/ext/v8/upstream/2.0.6/src/platform-posix.cc +380 -0
- data/ext/v8/upstream/2.0.6/src/platform-win32.cc +1908 -0
- data/ext/v8/upstream/2.0.6/src/platform.h +556 -0
- data/ext/v8/upstream/2.0.6/src/prettyprinter.cc +1511 -0
- data/ext/v8/upstream/2.0.6/src/prettyprinter.h +219 -0
- data/ext/v8/upstream/2.0.6/src/property.cc +96 -0
- data/ext/v8/upstream/2.0.6/src/property.h +327 -0
- data/ext/v8/upstream/2.0.6/src/regexp-delay.js +406 -0
- data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp-inl.h +78 -0
- data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp.cc +464 -0
- data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp.h +141 -0
- data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-tracer.cc +356 -0
- data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-tracer.h +103 -0
- data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler.cc +240 -0
- data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler.h +220 -0
- data/ext/v8/upstream/2.0.6/src/regexp-stack.cc +103 -0
- data/ext/v8/upstream/2.0.6/src/regexp-stack.h +123 -0
- data/ext/v8/upstream/2.0.6/src/register-allocator-inl.h +74 -0
- data/ext/v8/upstream/2.0.6/src/register-allocator.cc +100 -0
- data/ext/v8/upstream/2.0.6/src/register-allocator.h +295 -0
- data/ext/v8/upstream/2.0.6/src/rewriter.cc +855 -0
- data/ext/v8/upstream/2.0.6/src/rewriter.h +54 -0
- data/ext/v8/upstream/2.0.6/src/runtime.cc +8163 -0
- data/ext/v8/upstream/2.0.6/src/runtime.h +432 -0
- data/ext/v8/upstream/2.0.6/src/runtime.js +626 -0
- data/ext/v8/upstream/2.0.6/src/scanner.cc +1098 -0
- data/ext/v8/upstream/2.0.6/src/scanner.h +425 -0
- data/ext/v8/upstream/2.0.6/src/scopeinfo.cc +649 -0
- data/ext/v8/upstream/2.0.6/src/scopeinfo.h +236 -0
- data/ext/v8/upstream/2.0.6/src/scopes.cc +963 -0
- data/ext/v8/upstream/2.0.6/src/scopes.h +401 -0
- data/ext/v8/upstream/2.0.6/src/serialize.cc +1260 -0
- data/ext/v8/upstream/2.0.6/src/serialize.h +404 -0
- data/ext/v8/upstream/2.0.6/src/shell.h +55 -0
- data/ext/v8/upstream/2.0.6/src/simulator.h +41 -0
- data/ext/v8/upstream/2.0.6/src/smart-pointer.h +109 -0
- data/ext/v8/upstream/2.0.6/src/snapshot-common.cc +97 -0
- data/ext/v8/upstream/2.0.6/src/snapshot-empty.cc +40 -0
- data/ext/v8/upstream/2.0.6/src/snapshot.h +59 -0
- data/ext/v8/upstream/2.0.6/src/spaces-inl.h +372 -0
- data/ext/v8/upstream/2.0.6/src/spaces.cc +2864 -0
- data/ext/v8/upstream/2.0.6/src/spaces.h +2072 -0
- data/ext/v8/upstream/2.0.6/src/string-stream.cc +584 -0
- data/ext/v8/upstream/2.0.6/src/string-stream.h +189 -0
- data/ext/v8/upstream/2.0.6/src/string.js +901 -0
- data/ext/v8/upstream/2.0.6/src/stub-cache.cc +1108 -0
- data/ext/v8/upstream/2.0.6/src/stub-cache.h +578 -0
- data/ext/v8/upstream/2.0.6/src/third_party/dtoa/COPYING +15 -0
- data/ext/v8/upstream/2.0.6/src/third_party/dtoa/dtoa.c +3330 -0
- data/ext/v8/upstream/2.0.6/src/third_party/valgrind/valgrind.h +3925 -0
- data/ext/v8/upstream/2.0.6/src/token.cc +56 -0
- data/ext/v8/upstream/2.0.6/src/token.h +270 -0
- data/ext/v8/upstream/2.0.6/src/top.cc +991 -0
- data/ext/v8/upstream/2.0.6/src/top.h +459 -0
- data/ext/v8/upstream/2.0.6/src/unicode-inl.h +238 -0
- data/ext/v8/upstream/2.0.6/src/unicode.cc +749 -0
- data/ext/v8/upstream/2.0.6/src/unicode.h +279 -0
- data/ext/v8/upstream/2.0.6/src/uri.js +415 -0
- data/ext/v8/upstream/2.0.6/src/usage-analyzer.cc +426 -0
- data/ext/v8/upstream/2.0.6/src/usage-analyzer.h +40 -0
- data/ext/v8/upstream/2.0.6/src/utils.cc +322 -0
- data/ext/v8/upstream/2.0.6/src/utils.h +592 -0
- data/ext/v8/upstream/2.0.6/src/v8-counters.cc +55 -0
- data/ext/v8/upstream/2.0.6/src/v8-counters.h +198 -0
- data/ext/v8/upstream/2.0.6/src/v8.cc +193 -0
- data/ext/v8/upstream/2.0.6/src/v8.h +119 -0
- data/ext/v8/upstream/2.0.6/src/v8natives.js +846 -0
- data/ext/v8/upstream/2.0.6/src/v8threads.cc +450 -0
- data/ext/v8/upstream/2.0.6/src/v8threads.h +144 -0
- data/ext/v8/upstream/2.0.6/src/variables.cc +163 -0
- data/ext/v8/upstream/2.0.6/src/variables.h +235 -0
- data/ext/v8/upstream/2.0.6/src/version.cc +88 -0
- data/ext/v8/upstream/2.0.6/src/version.h +64 -0
- data/ext/v8/upstream/2.0.6/src/virtual-frame.cc +381 -0
- data/ext/v8/upstream/2.0.6/src/virtual-frame.h +44 -0
- data/ext/v8/upstream/2.0.6/src/x64/assembler-x64-inl.h +352 -0
- data/ext/v8/upstream/2.0.6/src/x64/assembler-x64.cc +2539 -0
- data/ext/v8/upstream/2.0.6/src/x64/assembler-x64.h +1399 -0
- data/ext/v8/upstream/2.0.6/src/x64/builtins-x64.cc +1255 -0
- data/ext/v8/upstream/2.0.6/src/x64/codegen-x64-inl.h +46 -0
- data/ext/v8/upstream/2.0.6/src/x64/codegen-x64.cc +8223 -0
- data/ext/v8/upstream/2.0.6/src/x64/codegen-x64.h +785 -0
- data/ext/v8/upstream/2.0.6/src/x64/cpu-x64.cc +79 -0
- data/ext/v8/upstream/2.0.6/src/x64/debug-x64.cc +202 -0
- data/ext/v8/upstream/2.0.6/src/x64/disasm-x64.cc +1596 -0
- data/ext/v8/upstream/2.0.6/src/x64/fast-codegen-x64.cc +1820 -0
- data/ext/v8/upstream/2.0.6/src/x64/frames-x64.cc +109 -0
- data/ext/v8/upstream/2.0.6/src/x64/frames-x64.h +121 -0
- data/ext/v8/upstream/2.0.6/src/x64/ic-x64.cc +1392 -0
- data/ext/v8/upstream/2.0.6/src/x64/jump-target-x64.cc +432 -0
- data/ext/v8/upstream/2.0.6/src/x64/macro-assembler-x64.cc +2409 -0
- data/ext/v8/upstream/2.0.6/src/x64/macro-assembler-x64.h +765 -0
- data/ext/v8/upstream/2.0.6/src/x64/regexp-macro-assembler-x64.cc +1337 -0
- data/ext/v8/upstream/2.0.6/src/x64/regexp-macro-assembler-x64.h +295 -0
- data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64-inl.h +86 -0
- data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64.cc +84 -0
- data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64.h +43 -0
- data/ext/v8/upstream/2.0.6/src/x64/simulator-x64.cc +27 -0
- data/ext/v8/upstream/2.0.6/src/x64/simulator-x64.h +63 -0
- data/ext/v8/upstream/2.0.6/src/x64/stub-cache-x64.cc +1884 -0
- data/ext/v8/upstream/2.0.6/src/x64/virtual-frame-x64.cc +1089 -0
- data/ext/v8/upstream/2.0.6/src/x64/virtual-frame-x64.h +560 -0
- data/ext/v8/upstream/2.0.6/src/zone-inl.h +297 -0
- data/ext/v8/upstream/2.0.6/src/zone.cc +193 -0
- data/ext/v8/upstream/2.0.6/src/zone.h +305 -0
- data/ext/v8/upstream/2.0.6/tools/codemap.js +258 -0
- data/ext/v8/upstream/2.0.6/tools/consarray.js +93 -0
- data/ext/v8/upstream/2.0.6/tools/csvparser.js +98 -0
- data/ext/v8/upstream/2.0.6/tools/gyp/v8.gyp +620 -0
- data/ext/v8/upstream/2.0.6/tools/js2c.py +376 -0
- data/ext/v8/upstream/2.0.6/tools/jsmin.py +280 -0
- data/ext/v8/upstream/2.0.6/tools/linux-tick-processor +24 -0
- data/ext/v8/upstream/2.0.6/tools/linux-tick-processor.py +78 -0
- data/ext/v8/upstream/2.0.6/tools/logreader.js +320 -0
- data/ext/v8/upstream/2.0.6/tools/mac-nm +18 -0
- data/ext/v8/upstream/2.0.6/tools/mac-tick-processor +6 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/annotate +7 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/common +19 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/dump +7 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/report +7 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/reset +7 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/run +14 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/shutdown +7 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/start +7 -0
- data/ext/v8/upstream/2.0.6/tools/presubmit.py +299 -0
- data/ext/v8/upstream/2.0.6/tools/process-heap-prof.py +120 -0
- data/ext/v8/upstream/2.0.6/tools/profile.js +621 -0
- data/ext/v8/upstream/2.0.6/tools/profile_view.js +224 -0
- data/ext/v8/upstream/2.0.6/tools/run-valgrind.py +77 -0
- data/ext/v8/upstream/2.0.6/tools/splaytree.js +322 -0
- data/ext/v8/upstream/2.0.6/tools/splaytree.py +226 -0
- data/ext/v8/upstream/2.0.6/tools/stats-viewer.py +456 -0
- data/ext/v8/upstream/2.0.6/tools/test.py +1370 -0
- data/ext/v8/upstream/2.0.6/tools/tickprocessor-driver.js +53 -0
- data/ext/v8/upstream/2.0.6/tools/tickprocessor.js +731 -0
- data/ext/v8/upstream/2.0.6/tools/tickprocessor.py +535 -0
- data/ext/v8/upstream/2.0.6/tools/utils.py +82 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/README.txt +71 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/arm.vsprops +14 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/common.vsprops +35 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/d8.vcproj +199 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/d8_arm.vcproj +199 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/d8_x64.vcproj +201 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/d8js2c.cmd +6 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/debug.vsprops +17 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/ia32.vsprops +13 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/js2c.cmd +6 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/release.vsprops +24 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8.sln +101 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8.vcproj +223 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_arm.sln +74 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_arm.vcproj +223 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base.vcproj +971 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base_arm.vcproj +983 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base_x64.vcproj +959 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest.vcproj +255 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest_arm.vcproj +243 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest_x64.vcproj +257 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_mksnapshot.vcproj +151 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_mksnapshot_x64.vcproj +151 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample.vcproj +151 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample_arm.vcproj +151 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample_x64.vcproj +151 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample.vcproj +151 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample_arm.vcproj +151 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample_x64.vcproj +153 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot.vcproj +142 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_cc.vcproj +92 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_cc_x64.vcproj +92 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_x64.vcproj +142 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_x64.sln +101 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_x64.vcproj +223 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/x64.vsprops +13 -0
- data/ext/v8/upstream/2.0.6/tools/windows-tick-processor.bat +5 -0
- data/ext/v8/upstream/2.0.6/tools/windows-tick-processor.py +137 -0
- data/ext/v8/upstream/Makefile +31 -0
- data/ext/v8/upstream/no-strict-aliasing.patch +13 -0
- data/ext/v8/upstream/scons/CHANGES.txt +5183 -0
- data/ext/v8/upstream/scons/LICENSE.txt +20 -0
- data/ext/v8/upstream/scons/MANIFEST +202 -0
- data/ext/v8/upstream/scons/PKG-INFO +13 -0
- data/ext/v8/upstream/scons/README.txt +273 -0
- data/ext/v8/upstream/scons/RELEASE.txt +1040 -0
- data/ext/v8/upstream/scons/engine/SCons/Action.py +1256 -0
- data/ext/v8/upstream/scons/engine/SCons/Builder.py +868 -0
- data/ext/v8/upstream/scons/engine/SCons/CacheDir.py +217 -0
- data/ext/v8/upstream/scons/engine/SCons/Conftest.py +794 -0
- data/ext/v8/upstream/scons/engine/SCons/Debug.py +237 -0
- data/ext/v8/upstream/scons/engine/SCons/Defaults.py +485 -0
- data/ext/v8/upstream/scons/engine/SCons/Environment.py +2327 -0
- data/ext/v8/upstream/scons/engine/SCons/Errors.py +207 -0
- data/ext/v8/upstream/scons/engine/SCons/Executor.py +636 -0
- data/ext/v8/upstream/scons/engine/SCons/Job.py +435 -0
- data/ext/v8/upstream/scons/engine/SCons/Memoize.py +292 -0
- data/ext/v8/upstream/scons/engine/SCons/Node/Alias.py +153 -0
- data/ext/v8/upstream/scons/engine/SCons/Node/FS.py +3220 -0
- data/ext/v8/upstream/scons/engine/SCons/Node/Python.py +128 -0
- data/ext/v8/upstream/scons/engine/SCons/Node/__init__.py +1341 -0
- data/ext/v8/upstream/scons/engine/SCons/Options/BoolOption.py +50 -0
- data/ext/v8/upstream/scons/engine/SCons/Options/EnumOption.py +50 -0
- data/ext/v8/upstream/scons/engine/SCons/Options/ListOption.py +50 -0
- data/ext/v8/upstream/scons/engine/SCons/Options/PackageOption.py +50 -0
- data/ext/v8/upstream/scons/engine/SCons/Options/PathOption.py +76 -0
- data/ext/v8/upstream/scons/engine/SCons/Options/__init__.py +74 -0
- data/ext/v8/upstream/scons/engine/SCons/PathList.py +232 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/__init__.py +236 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/aix.py +70 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/cygwin.py +55 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/darwin.py +46 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/hpux.py +46 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/irix.py +44 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/os2.py +58 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/posix.py +264 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/sunos.py +50 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/win32.py +386 -0
- data/ext/v8/upstream/scons/engine/SCons/SConf.py +1038 -0
- data/ext/v8/upstream/scons/engine/SCons/SConsign.py +381 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/C.py +132 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/D.py +74 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/Dir.py +111 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/Fortran.py +320 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/IDL.py +48 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/LaTeX.py +378 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/Prog.py +103 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/RC.py +55 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/__init__.py +415 -0
- data/ext/v8/upstream/scons/engine/SCons/Script/Interactive.py +386 -0
- data/ext/v8/upstream/scons/engine/SCons/Script/Main.py +1360 -0
- data/ext/v8/upstream/scons/engine/SCons/Script/SConsOptions.py +944 -0
- data/ext/v8/upstream/scons/engine/SCons/Script/SConscript.py +642 -0
- data/ext/v8/upstream/scons/engine/SCons/Script/__init__.py +414 -0
- data/ext/v8/upstream/scons/engine/SCons/Sig.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Subst.py +911 -0
- data/ext/v8/upstream/scons/engine/SCons/Taskmaster.py +1030 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/386asm.py +61 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/BitKeeper.py +65 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/CVS.py +73 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/FortranCommon.py +247 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/JavaCommon.py +324 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/__init__.py +56 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/arch.py +61 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/common.py +210 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/netframework.py +84 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/sdk.py +321 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/vc.py +367 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/vs.py +497 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/Perforce.py +104 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/PharLapCommon.py +138 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/RCS.py +64 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/SCCS.py +64 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/Subversion.py +71 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/__init__.py +675 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/aixc++.py +82 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/aixcc.py +74 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/aixf77.py +80 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/aixlink.py +76 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/applelink.py +71 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/ar.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/as.py +78 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/bcc32.py +82 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/c++.py +99 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/cc.py +114 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/cvf.py +58 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/default.py +50 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/dmd.py +224 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/dvi.py +64 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/dvipdf.py +125 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/dvips.py +94 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/f77.py +62 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/f90.py +62 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/f95.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/filesystem.py +98 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/fortran.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/g++.py +90 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/g77.py +73 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/gas.py +53 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/gcc.py +80 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/gfortran.py +64 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/gnulink.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/gs.py +81 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/hpc++.py +85 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/hpcc.py +53 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/hplink.py +77 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/icc.py +59 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/icl.py +52 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/ifl.py +72 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/ifort.py +90 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/ilink.py +59 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/ilink32.py +60 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/install.py +229 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/intelc.py +490 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/ipkg.py +71 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/jar.py +110 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/javac.py +234 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/javah.py +138 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/latex.py +79 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/lex.py +99 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/link.py +121 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/linkloc.py +112 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/m4.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/masm.py +77 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/midl.py +90 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/mingw.py +159 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/mslib.py +64 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/mslink.py +266 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/mssdk.py +50 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/msvc.py +269 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/msvs.py +1439 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/mwcc.py +208 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/mwld.py +107 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/nasm.py +72 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/__init__.py +314 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/ipk.py +185 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/msi.py +526 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/rpm.py +367 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_tarbz2.py +43 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_targz.py +43 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_zip.py +43 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/tarbz2.py +44 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/targz.py +44 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/zip.py +44 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/pdf.py +78 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/pdflatex.py +83 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/pdftex.py +108 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/qt.py +336 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/rmic.py +121 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/rpcgen.py +70 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/rpm.py +132 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sgiar.py +68 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sgic++.py +58 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sgicc.py +53 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sgilink.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunar.py +67 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunc++.py +142 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/suncc.py +58 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunf77.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunf90.py +64 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunf95.py +64 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunlink.py +77 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/swig.py +186 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/tar.py +73 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/tex.py +805 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/textfile.py +175 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/tlib.py +53 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/wix.py +100 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/yacc.py +131 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/zip.py +100 -0
- data/ext/v8/upstream/scons/engine/SCons/Util.py +1645 -0
- data/ext/v8/upstream/scons/engine/SCons/Variables/BoolVariable.py +91 -0
- data/ext/v8/upstream/scons/engine/SCons/Variables/EnumVariable.py +107 -0
- data/ext/v8/upstream/scons/engine/SCons/Variables/ListVariable.py +139 -0
- data/ext/v8/upstream/scons/engine/SCons/Variables/PackageVariable.py +109 -0
- data/ext/v8/upstream/scons/engine/SCons/Variables/PathVariable.py +147 -0
- data/ext/v8/upstream/scons/engine/SCons/Variables/__init__.py +317 -0
- data/ext/v8/upstream/scons/engine/SCons/Warnings.py +228 -0
- data/ext/v8/upstream/scons/engine/SCons/__init__.py +49 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/__init__.py +302 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_UserString.py +98 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_hashlib.py +91 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_itertools.py +124 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_optparse.py +1725 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_sets.py +583 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_sets15.py +176 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_shlex.py +325 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_subprocess.py +1296 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_textwrap.py +382 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/builtins.py +187 -0
- data/ext/v8/upstream/scons/engine/SCons/cpp.py +598 -0
- data/ext/v8/upstream/scons/engine/SCons/dblite.py +248 -0
- data/ext/v8/upstream/scons/engine/SCons/exitfuncs.py +77 -0
- data/ext/v8/upstream/scons/os_spawnv_fix.diff +83 -0
- data/ext/v8/upstream/scons/scons-time.1 +1017 -0
- data/ext/v8/upstream/scons/scons.1 +15179 -0
- data/ext/v8/upstream/scons/sconsign.1 +208 -0
- data/ext/v8/upstream/scons/script/scons +184 -0
- data/ext/v8/upstream/scons/script/scons-time +1529 -0
- data/ext/v8/upstream/scons/script/scons.bat +31 -0
- data/ext/v8/upstream/scons/script/sconsign +508 -0
- data/ext/v8/upstream/scons/setup.cfg +6 -0
- data/ext/v8/upstream/scons/setup.py +427 -0
- data/ext/v8/v8.cpp +89 -0
- data/ext/v8/v8_cxt.cpp +92 -0
- data/ext/v8/v8_cxt.h +20 -0
- data/ext/v8/v8_func.cpp +10 -0
- data/ext/v8/v8_func.h +11 -0
- data/ext/v8/v8_msg.cpp +54 -0
- data/ext/v8/v8_msg.h +18 -0
- data/ext/v8/v8_obj.cpp +52 -0
- data/ext/v8/v8_obj.h +13 -0
- data/ext/v8/v8_ref.cpp +26 -0
- data/ext/v8/v8_ref.h +31 -0
- data/ext/v8/v8_script.cpp +20 -0
- data/ext/v8/v8_script.h +8 -0
- data/ext/v8/v8_standalone.cpp +69 -0
- data/ext/v8/v8_standalone.h +31 -0
- data/ext/v8/v8_str.cpp +17 -0
- data/ext/v8/v8_str.h +9 -0
- data/ext/v8/v8_template.cpp +53 -0
- data/ext/v8/v8_template.h +13 -0
- data/lib/v8.rb +10 -0
- data/lib/v8/context.rb +101 -0
- data/lib/v8/object.rb +38 -0
- data/lib/v8/to.rb +33 -0
- data/lib/v8/v8.so +0 -0
- data/script/console +10 -0
- data/script/destroy +14 -0
- data/script/generate +14 -0
- data/spec/ext/cxt_spec.rb +25 -0
- data/spec/ext/obj_spec.rb +13 -0
- data/spec/redjs/jsapi_spec.rb +405 -0
- data/spec/redjs/tap.rb +8 -0
- data/spec/redjs_helper.rb +3 -0
- data/spec/spec.opts +1 -0
- data/spec/spec_helper.rb +14 -0
- data/spec/v8/to_spec.rb +15 -0
- data/tasks/rspec.rake +21 -0
- data/therubyracer.gemspec +680 -0
- metadata +697 -0
@@ -0,0 +1,401 @@
|
|
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_SCOPES_H_
|
29
|
+
#define V8_SCOPES_H_
|
30
|
+
|
31
|
+
#include "ast.h"
|
32
|
+
#include "hashmap.h"
|
33
|
+
|
34
|
+
namespace v8 {
|
35
|
+
namespace internal {
|
36
|
+
|
37
|
+
|
38
|
+
// A hash map to support fast variable declaration and lookup.
|
39
|
+
class VariableMap: public HashMap {
|
40
|
+
public:
|
41
|
+
VariableMap();
|
42
|
+
|
43
|
+
// Dummy constructor. This constructor doesn't set up the map
|
44
|
+
// properly so don't use it unless you have a good reason.
|
45
|
+
explicit VariableMap(bool gotta_love_static_overloading);
|
46
|
+
|
47
|
+
virtual ~VariableMap();
|
48
|
+
|
49
|
+
Variable* Declare(Scope* scope,
|
50
|
+
Handle<String> name,
|
51
|
+
Variable::Mode mode,
|
52
|
+
bool is_valid_lhs,
|
53
|
+
Variable::Kind kind);
|
54
|
+
|
55
|
+
Variable* Lookup(Handle<String> name);
|
56
|
+
};
|
57
|
+
|
58
|
+
|
59
|
+
// The dynamic scope part holds hash maps for the variables that will
|
60
|
+
// be looked up dynamically from within eval and with scopes. The objects
|
61
|
+
// are allocated on-demand from Scope::NonLocal to avoid wasting memory
|
62
|
+
// and setup time for scopes that don't need them.
|
63
|
+
class DynamicScopePart : public ZoneObject {
|
64
|
+
public:
|
65
|
+
VariableMap* GetMap(Variable::Mode mode) {
|
66
|
+
int index = mode - Variable::DYNAMIC;
|
67
|
+
ASSERT(index >= 0 && index < 3);
|
68
|
+
return &maps_[index];
|
69
|
+
}
|
70
|
+
|
71
|
+
private:
|
72
|
+
VariableMap maps_[3];
|
73
|
+
};
|
74
|
+
|
75
|
+
|
76
|
+
// Global invariants after AST construction: Each reference (i.e. identifier)
|
77
|
+
// to a JavaScript variable (including global properties) is represented by a
|
78
|
+
// VariableProxy node. Immediately after AST construction and before variable
|
79
|
+
// allocation, most VariableProxy nodes are "unresolved", i.e. not bound to a
|
80
|
+
// corresponding variable (though some are bound during parse time). Variable
|
81
|
+
// allocation binds each unresolved VariableProxy to one Variable and assigns
|
82
|
+
// a location. Note that many VariableProxy nodes may refer to the same Java-
|
83
|
+
// Script variable.
|
84
|
+
|
85
|
+
class Scope: public ZoneObject {
|
86
|
+
public:
|
87
|
+
// ---------------------------------------------------------------------------
|
88
|
+
// Construction
|
89
|
+
|
90
|
+
enum Type {
|
91
|
+
EVAL_SCOPE, // the top-level scope for an 'eval' source
|
92
|
+
FUNCTION_SCOPE, // the top-level scope for a function
|
93
|
+
GLOBAL_SCOPE // the top-level scope for a program or a top-level eval
|
94
|
+
};
|
95
|
+
|
96
|
+
Scope(Scope* outer_scope, Type type);
|
97
|
+
|
98
|
+
virtual ~Scope() { }
|
99
|
+
|
100
|
+
// The scope name is only used for printing/debugging.
|
101
|
+
void SetScopeName(Handle<String> scope_name) { scope_name_ = scope_name; }
|
102
|
+
|
103
|
+
void Initialize(bool inside_with);
|
104
|
+
|
105
|
+
|
106
|
+
// ---------------------------------------------------------------------------
|
107
|
+
// Declarations
|
108
|
+
|
109
|
+
// Lookup a variable in this scope. Returns the variable or NULL if not found.
|
110
|
+
virtual Variable* LocalLookup(Handle<String> name);
|
111
|
+
|
112
|
+
// Lookup a variable in this scope or outer scopes.
|
113
|
+
// Returns the variable or NULL if not found.
|
114
|
+
virtual Variable* Lookup(Handle<String> name);
|
115
|
+
|
116
|
+
// Declare the function variable for a function literal. This variable
|
117
|
+
// is in an intermediate scope between this function scope and the the
|
118
|
+
// outer scope. Only possible for function scopes; at most one variable.
|
119
|
+
Variable* DeclareFunctionVar(Handle<String> name);
|
120
|
+
|
121
|
+
// Declare a local variable in this scope. If the variable has been
|
122
|
+
// declared before, the previously declared variable is returned.
|
123
|
+
virtual Variable* DeclareLocal(Handle<String> name, Variable::Mode mode);
|
124
|
+
|
125
|
+
// Declare an implicit global variable in this scope which must be a
|
126
|
+
// global scope. The variable was introduced (possibly from an inner
|
127
|
+
// scope) by a reference to an unresolved variable with no intervening
|
128
|
+
// with statements or eval calls.
|
129
|
+
Variable* DeclareGlobal(Handle<String> name);
|
130
|
+
|
131
|
+
// Add a parameter to the parameter list. The parameter must have been
|
132
|
+
// declared via Declare. The same parameter may occur more than once in
|
133
|
+
// the parameter list; they must be added in source order, from left to
|
134
|
+
// right.
|
135
|
+
void AddParameter(Variable* var);
|
136
|
+
|
137
|
+
// Create a new unresolved variable.
|
138
|
+
virtual VariableProxy* NewUnresolved(Handle<String> name, bool inside_with);
|
139
|
+
|
140
|
+
// Remove a unresolved variable. During parsing, an unresolved variable
|
141
|
+
// may have been added optimistically, but then only the variable name
|
142
|
+
// was used (typically for labels). If the variable was not declared, the
|
143
|
+
// addition introduced a new unresolved variable which may end up being
|
144
|
+
// allocated globally as a "ghost" variable. RemoveUnresolved removes
|
145
|
+
// such a variable again if it was added; otherwise this is a no-op.
|
146
|
+
void RemoveUnresolved(VariableProxy* var);
|
147
|
+
|
148
|
+
// Creates a new temporary variable in this scope and binds a proxy to it.
|
149
|
+
// The name is only used for printing and cannot be used to find the variable.
|
150
|
+
// In particular, the only way to get hold of the temporary is by keeping the
|
151
|
+
// VariableProxy* around.
|
152
|
+
virtual VariableProxy* NewTemporary(Handle<String> name);
|
153
|
+
|
154
|
+
// Adds the specific declaration node to the list of declarations in
|
155
|
+
// this scope. The declarations are processed as part of entering
|
156
|
+
// the scope; see codegen.cc:ProcessDeclarations.
|
157
|
+
void AddDeclaration(Declaration* declaration);
|
158
|
+
|
159
|
+
// ---------------------------------------------------------------------------
|
160
|
+
// Illegal redeclaration support.
|
161
|
+
|
162
|
+
// Set an expression node that will be executed when the scope is
|
163
|
+
// entered. We only keep track of one illegal redeclaration node per
|
164
|
+
// scope - the first one - so if you try to set it multiple times
|
165
|
+
// the additional requests will be silently ignored.
|
166
|
+
void SetIllegalRedeclaration(Expression* expression);
|
167
|
+
|
168
|
+
// Visit the illegal redeclaration expression. Do not call if the
|
169
|
+
// scope doesn't have an illegal redeclaration node.
|
170
|
+
void VisitIllegalRedeclaration(AstVisitor* visitor);
|
171
|
+
|
172
|
+
// Check if the scope has (at least) one illegal redeclaration.
|
173
|
+
bool HasIllegalRedeclaration() const { return illegal_redecl_ != NULL; }
|
174
|
+
|
175
|
+
|
176
|
+
// ---------------------------------------------------------------------------
|
177
|
+
// Scope-specific info.
|
178
|
+
|
179
|
+
// Inform the scope that the corresponding code contains a with statement.
|
180
|
+
void RecordWithStatement() { scope_contains_with_ = true; }
|
181
|
+
|
182
|
+
// Inform the scope that the corresponding code contains an eval call.
|
183
|
+
void RecordEvalCall() { scope_calls_eval_ = true; }
|
184
|
+
|
185
|
+
|
186
|
+
// ---------------------------------------------------------------------------
|
187
|
+
// Predicates.
|
188
|
+
|
189
|
+
// Specific scope types.
|
190
|
+
bool is_eval_scope() const { return type_ == EVAL_SCOPE; }
|
191
|
+
bool is_function_scope() const { return type_ == FUNCTION_SCOPE; }
|
192
|
+
bool is_global_scope() const { return type_ == GLOBAL_SCOPE; }
|
193
|
+
|
194
|
+
// Information about which scopes calls eval.
|
195
|
+
bool calls_eval() const { return scope_calls_eval_; }
|
196
|
+
bool outer_scope_calls_eval() const { return outer_scope_calls_eval_; }
|
197
|
+
|
198
|
+
// Is this scope inside a with statement.
|
199
|
+
bool inside_with() const { return scope_inside_with_; }
|
200
|
+
// Does this scope contain a with statement.
|
201
|
+
bool contains_with() const { return scope_contains_with_; }
|
202
|
+
|
203
|
+
// The scope immediately surrounding this scope, or NULL.
|
204
|
+
Scope* outer_scope() const { return outer_scope_; }
|
205
|
+
|
206
|
+
// ---------------------------------------------------------------------------
|
207
|
+
// Accessors.
|
208
|
+
|
209
|
+
// A new variable proxy corresponding to the (function) receiver.
|
210
|
+
VariableProxy* receiver() const {
|
211
|
+
VariableProxy* proxy =
|
212
|
+
new VariableProxy(Factory::this_symbol(), true, false);
|
213
|
+
proxy->BindTo(receiver_);
|
214
|
+
return proxy;
|
215
|
+
}
|
216
|
+
|
217
|
+
// The variable holding the function literal for named function
|
218
|
+
// literals, or NULL.
|
219
|
+
// Only valid for function scopes.
|
220
|
+
Variable* function() const {
|
221
|
+
ASSERT(is_function_scope());
|
222
|
+
return function_;
|
223
|
+
}
|
224
|
+
|
225
|
+
// Parameters. The left-most parameter has index 0.
|
226
|
+
// Only valid for function scopes.
|
227
|
+
Variable* parameter(int index) const {
|
228
|
+
ASSERT(is_function_scope());
|
229
|
+
return params_[index];
|
230
|
+
}
|
231
|
+
|
232
|
+
int num_parameters() const { return params_.length(); }
|
233
|
+
|
234
|
+
// The local variable 'arguments' if we need to allocate it; NULL otherwise.
|
235
|
+
// If arguments() exist, arguments_shadow() exists, too.
|
236
|
+
VariableProxy* arguments() const { return arguments_; }
|
237
|
+
|
238
|
+
// The '.arguments' shadow variable if we need to allocate it; NULL otherwise.
|
239
|
+
// If arguments_shadow() exist, arguments() exists, too.
|
240
|
+
VariableProxy* arguments_shadow() const { return arguments_shadow_; }
|
241
|
+
|
242
|
+
// Declarations list.
|
243
|
+
ZoneList<Declaration*>* declarations() { return &decls_; }
|
244
|
+
|
245
|
+
|
246
|
+
|
247
|
+
// ---------------------------------------------------------------------------
|
248
|
+
// Variable allocation.
|
249
|
+
|
250
|
+
// Collect all used locals in this scope.
|
251
|
+
template<class Allocator>
|
252
|
+
void CollectUsedVariables(List<Variable*, Allocator>* locals);
|
253
|
+
|
254
|
+
// Resolve and fill in the allocation information for all variables
|
255
|
+
// in this scopes. Must be called *after* all scopes have been
|
256
|
+
// processed (parsed) to ensure that unresolved variables can be
|
257
|
+
// resolved properly.
|
258
|
+
//
|
259
|
+
// In the case of code compiled and run using 'eval', the context
|
260
|
+
// parameter is the context in which eval was called. In all other
|
261
|
+
// cases the context parameter is an empty handle.
|
262
|
+
void AllocateVariables(Handle<Context> context);
|
263
|
+
|
264
|
+
// Result of variable allocation.
|
265
|
+
int num_stack_slots() const { return num_stack_slots_; }
|
266
|
+
int num_heap_slots() const { return num_heap_slots_; }
|
267
|
+
|
268
|
+
// Make sure this scope and all outer scopes are eagerly compiled.
|
269
|
+
void ForceEagerCompilation() { force_eager_compilation_ = true; }
|
270
|
+
|
271
|
+
// Determine if we can use lazy compilation for this scope.
|
272
|
+
bool AllowsLazyCompilation() const;
|
273
|
+
|
274
|
+
// True if the outer context of this scope is always the global context.
|
275
|
+
bool HasTrivialOuterContext() const;
|
276
|
+
|
277
|
+
// The number of contexts between this and scope; zero if this == scope.
|
278
|
+
int ContextChainLength(Scope* scope);
|
279
|
+
|
280
|
+
|
281
|
+
// ---------------------------------------------------------------------------
|
282
|
+
// Debugging.
|
283
|
+
|
284
|
+
#ifdef DEBUG
|
285
|
+
void Print(int n = 0); // n = indentation; n < 0 => don't print recursively
|
286
|
+
#endif
|
287
|
+
|
288
|
+
// ---------------------------------------------------------------------------
|
289
|
+
// Implementation.
|
290
|
+
protected:
|
291
|
+
friend class ParserFactory;
|
292
|
+
|
293
|
+
explicit Scope(Type type);
|
294
|
+
|
295
|
+
// Scope tree.
|
296
|
+
Scope* outer_scope_; // the immediately enclosing outer scope, or NULL
|
297
|
+
ZoneList<Scope*> inner_scopes_; // the immediately enclosed inner scopes
|
298
|
+
|
299
|
+
// The scope type.
|
300
|
+
Type type_;
|
301
|
+
|
302
|
+
// Debugging support.
|
303
|
+
Handle<String> scope_name_;
|
304
|
+
|
305
|
+
// The variables declared in this scope:
|
306
|
+
//
|
307
|
+
// All user-declared variables (incl. parameters). For global scopes
|
308
|
+
// variables may be implicitly 'declared' by being used (possibly in
|
309
|
+
// an inner scope) with no intervening with statements or eval calls.
|
310
|
+
VariableMap variables_;
|
311
|
+
// Compiler-allocated (user-invisible) temporaries.
|
312
|
+
ZoneList<Variable*> temps_;
|
313
|
+
// Parameter list in source order.
|
314
|
+
ZoneList<Variable*> params_;
|
315
|
+
// Variables that must be looked up dynamically.
|
316
|
+
DynamicScopePart* dynamics_;
|
317
|
+
// Unresolved variables referred to from this scope.
|
318
|
+
ZoneList<VariableProxy*> unresolved_;
|
319
|
+
// Declarations.
|
320
|
+
ZoneList<Declaration*> decls_;
|
321
|
+
// Convenience variable.
|
322
|
+
Variable* receiver_;
|
323
|
+
// Function variable, if any; function scopes only.
|
324
|
+
Variable* function_;
|
325
|
+
// Convenience variable; function scopes only.
|
326
|
+
VariableProxy* arguments_;
|
327
|
+
// Convenience variable; function scopes only.
|
328
|
+
VariableProxy* arguments_shadow_;
|
329
|
+
|
330
|
+
// Illegal redeclaration.
|
331
|
+
Expression* illegal_redecl_;
|
332
|
+
|
333
|
+
// Scope-specific information.
|
334
|
+
bool scope_inside_with_; // this scope is inside a 'with' of some outer scope
|
335
|
+
bool scope_contains_with_; // this scope contains a 'with' statement
|
336
|
+
bool scope_calls_eval_; // this scope contains an 'eval' call
|
337
|
+
|
338
|
+
// Computed via PropagateScopeInfo.
|
339
|
+
bool outer_scope_calls_eval_;
|
340
|
+
bool inner_scope_calls_eval_;
|
341
|
+
bool outer_scope_is_eval_scope_;
|
342
|
+
bool force_eager_compilation_;
|
343
|
+
|
344
|
+
// Computed via AllocateVariables; function scopes only.
|
345
|
+
int num_stack_slots_;
|
346
|
+
int num_heap_slots_;
|
347
|
+
|
348
|
+
// Create a non-local variable with a given name.
|
349
|
+
// These variables are looked up dynamically at runtime.
|
350
|
+
Variable* NonLocal(Handle<String> name, Variable::Mode mode);
|
351
|
+
|
352
|
+
// Variable resolution.
|
353
|
+
Variable* LookupRecursive(Handle<String> name,
|
354
|
+
bool inner_lookup,
|
355
|
+
Variable** invalidated_local);
|
356
|
+
void ResolveVariable(Scope* global_scope,
|
357
|
+
Handle<Context> context,
|
358
|
+
VariableProxy* proxy);
|
359
|
+
void ResolveVariablesRecursively(Scope* global_scope,
|
360
|
+
Handle<Context> context);
|
361
|
+
|
362
|
+
// Scope analysis.
|
363
|
+
bool PropagateScopeInfo(bool outer_scope_calls_eval,
|
364
|
+
bool outer_scope_is_eval_scope);
|
365
|
+
bool HasTrivialContext() const;
|
366
|
+
|
367
|
+
// Predicates.
|
368
|
+
bool MustAllocate(Variable* var);
|
369
|
+
bool MustAllocateInContext(Variable* var);
|
370
|
+
bool HasArgumentsParameter();
|
371
|
+
|
372
|
+
// Variable allocation.
|
373
|
+
void AllocateStackSlot(Variable* var);
|
374
|
+
void AllocateHeapSlot(Variable* var);
|
375
|
+
void AllocateParameterLocals();
|
376
|
+
void AllocateNonParameterLocal(Variable* var);
|
377
|
+
void AllocateNonParameterLocals();
|
378
|
+
void AllocateVariablesRecursively();
|
379
|
+
};
|
380
|
+
|
381
|
+
|
382
|
+
class DummyScope : public Scope {
|
383
|
+
public:
|
384
|
+
DummyScope() : Scope(GLOBAL_SCOPE) {
|
385
|
+
outer_scope_ = this;
|
386
|
+
}
|
387
|
+
|
388
|
+
virtual Variable* Lookup(Handle<String> name) { return NULL; }
|
389
|
+
virtual Variable* Declare(Handle<String> name, Variable::Mode mode) {
|
390
|
+
return NULL;
|
391
|
+
}
|
392
|
+
virtual VariableProxy* NewUnresolved(Handle<String> name, bool inside_with) {
|
393
|
+
return NULL;
|
394
|
+
}
|
395
|
+
virtual VariableProxy* NewTemporary(Handle<String> name) { return NULL; }
|
396
|
+
};
|
397
|
+
|
398
|
+
|
399
|
+
} } // namespace v8::internal
|
400
|
+
|
401
|
+
#endif // V8_SCOPES_H_
|
@@ -0,0 +1,1260 @@
|
|
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 "accessors.h"
|
31
|
+
#include "api.h"
|
32
|
+
#include "execution.h"
|
33
|
+
#include "global-handles.h"
|
34
|
+
#include "ic-inl.h"
|
35
|
+
#include "natives.h"
|
36
|
+
#include "platform.h"
|
37
|
+
#include "runtime.h"
|
38
|
+
#include "serialize.h"
|
39
|
+
#include "stub-cache.h"
|
40
|
+
#include "v8threads.h"
|
41
|
+
#include "top.h"
|
42
|
+
#include "bootstrapper.h"
|
43
|
+
|
44
|
+
namespace v8 {
|
45
|
+
namespace internal {
|
46
|
+
|
47
|
+
// Mapping objects to their location after deserialization.
|
48
|
+
// This is used during building, but not at runtime by V8.
|
49
|
+
class SerializationAddressMapper {
|
50
|
+
public:
|
51
|
+
static bool IsMapped(HeapObject* obj) {
|
52
|
+
EnsureMapExists();
|
53
|
+
return serialization_map_->Lookup(Key(obj), Hash(obj), false) != NULL;
|
54
|
+
}
|
55
|
+
|
56
|
+
static int MappedTo(HeapObject* obj) {
|
57
|
+
ASSERT(IsMapped(obj));
|
58
|
+
return static_cast<int>(reinterpret_cast<intptr_t>(
|
59
|
+
serialization_map_->Lookup(Key(obj), Hash(obj), false)->value));
|
60
|
+
}
|
61
|
+
|
62
|
+
static void Map(HeapObject* obj, int to) {
|
63
|
+
EnsureMapExists();
|
64
|
+
ASSERT(!IsMapped(obj));
|
65
|
+
HashMap::Entry* entry =
|
66
|
+
serialization_map_->Lookup(Key(obj), Hash(obj), true);
|
67
|
+
entry->value = Value(to);
|
68
|
+
}
|
69
|
+
|
70
|
+
static void Zap() {
|
71
|
+
if (serialization_map_ != NULL) {
|
72
|
+
delete serialization_map_;
|
73
|
+
}
|
74
|
+
serialization_map_ = NULL;
|
75
|
+
}
|
76
|
+
|
77
|
+
private:
|
78
|
+
static bool SerializationMatchFun(void* key1, void* key2) {
|
79
|
+
return key1 == key2;
|
80
|
+
}
|
81
|
+
|
82
|
+
static uint32_t Hash(HeapObject* obj) {
|
83
|
+
return static_cast<int32_t>(reinterpret_cast<intptr_t>(obj->address()));
|
84
|
+
}
|
85
|
+
|
86
|
+
static void* Key(HeapObject* obj) {
|
87
|
+
return reinterpret_cast<void*>(obj->address());
|
88
|
+
}
|
89
|
+
|
90
|
+
static void* Value(int v) {
|
91
|
+
return reinterpret_cast<void*>(v);
|
92
|
+
}
|
93
|
+
|
94
|
+
static void EnsureMapExists() {
|
95
|
+
if (serialization_map_ == NULL) {
|
96
|
+
serialization_map_ = new HashMap(&SerializationMatchFun);
|
97
|
+
}
|
98
|
+
}
|
99
|
+
|
100
|
+
static HashMap* serialization_map_;
|
101
|
+
};
|
102
|
+
|
103
|
+
|
104
|
+
HashMap* SerializationAddressMapper::serialization_map_ = NULL;
|
105
|
+
|
106
|
+
|
107
|
+
|
108
|
+
|
109
|
+
// -----------------------------------------------------------------------------
|
110
|
+
// Coding of external references.
|
111
|
+
|
112
|
+
// The encoding of an external reference. The type is in the high word.
|
113
|
+
// The id is in the low word.
|
114
|
+
static uint32_t EncodeExternal(TypeCode type, uint16_t id) {
|
115
|
+
return static_cast<uint32_t>(type) << 16 | id;
|
116
|
+
}
|
117
|
+
|
118
|
+
|
119
|
+
static int* GetInternalPointer(StatsCounter* counter) {
|
120
|
+
// All counters refer to dummy_counter, if deserializing happens without
|
121
|
+
// setting up counters.
|
122
|
+
static int dummy_counter = 0;
|
123
|
+
return counter->Enabled() ? counter->GetInternalPointer() : &dummy_counter;
|
124
|
+
}
|
125
|
+
|
126
|
+
|
127
|
+
// ExternalReferenceTable is a helper class that defines the relationship
|
128
|
+
// between external references and their encodings. It is used to build
|
129
|
+
// hashmaps in ExternalReferenceEncoder and ExternalReferenceDecoder.
|
130
|
+
class ExternalReferenceTable {
|
131
|
+
public:
|
132
|
+
static ExternalReferenceTable* instance() {
|
133
|
+
if (!instance_) instance_ = new ExternalReferenceTable();
|
134
|
+
return instance_;
|
135
|
+
}
|
136
|
+
|
137
|
+
int size() const { return refs_.length(); }
|
138
|
+
|
139
|
+
Address address(int i) { return refs_[i].address; }
|
140
|
+
|
141
|
+
uint32_t code(int i) { return refs_[i].code; }
|
142
|
+
|
143
|
+
const char* name(int i) { return refs_[i].name; }
|
144
|
+
|
145
|
+
int max_id(int code) { return max_id_[code]; }
|
146
|
+
|
147
|
+
private:
|
148
|
+
static ExternalReferenceTable* instance_;
|
149
|
+
|
150
|
+
ExternalReferenceTable() : refs_(64) { PopulateTable(); }
|
151
|
+
~ExternalReferenceTable() { }
|
152
|
+
|
153
|
+
struct ExternalReferenceEntry {
|
154
|
+
Address address;
|
155
|
+
uint32_t code;
|
156
|
+
const char* name;
|
157
|
+
};
|
158
|
+
|
159
|
+
void PopulateTable();
|
160
|
+
|
161
|
+
// For a few types of references, we can get their address from their id.
|
162
|
+
void AddFromId(TypeCode type, uint16_t id, const char* name);
|
163
|
+
|
164
|
+
// For other types of references, the caller will figure out the address.
|
165
|
+
void Add(Address address, TypeCode type, uint16_t id, const char* name);
|
166
|
+
|
167
|
+
List<ExternalReferenceEntry> refs_;
|
168
|
+
int max_id_[kTypeCodeCount];
|
169
|
+
};
|
170
|
+
|
171
|
+
|
172
|
+
ExternalReferenceTable* ExternalReferenceTable::instance_ = NULL;
|
173
|
+
|
174
|
+
|
175
|
+
void ExternalReferenceTable::AddFromId(TypeCode type,
|
176
|
+
uint16_t id,
|
177
|
+
const char* name) {
|
178
|
+
Address address;
|
179
|
+
switch (type) {
|
180
|
+
case C_BUILTIN: {
|
181
|
+
ExternalReference ref(static_cast<Builtins::CFunctionId>(id));
|
182
|
+
address = ref.address();
|
183
|
+
break;
|
184
|
+
}
|
185
|
+
case BUILTIN: {
|
186
|
+
ExternalReference ref(static_cast<Builtins::Name>(id));
|
187
|
+
address = ref.address();
|
188
|
+
break;
|
189
|
+
}
|
190
|
+
case RUNTIME_FUNCTION: {
|
191
|
+
ExternalReference ref(static_cast<Runtime::FunctionId>(id));
|
192
|
+
address = ref.address();
|
193
|
+
break;
|
194
|
+
}
|
195
|
+
case IC_UTILITY: {
|
196
|
+
ExternalReference ref(IC_Utility(static_cast<IC::UtilityId>(id)));
|
197
|
+
address = ref.address();
|
198
|
+
break;
|
199
|
+
}
|
200
|
+
default:
|
201
|
+
UNREACHABLE();
|
202
|
+
return;
|
203
|
+
}
|
204
|
+
Add(address, type, id, name);
|
205
|
+
}
|
206
|
+
|
207
|
+
|
208
|
+
void ExternalReferenceTable::Add(Address address,
|
209
|
+
TypeCode type,
|
210
|
+
uint16_t id,
|
211
|
+
const char* name) {
|
212
|
+
ASSERT_NE(NULL, address);
|
213
|
+
ExternalReferenceEntry entry;
|
214
|
+
entry.address = address;
|
215
|
+
entry.code = EncodeExternal(type, id);
|
216
|
+
entry.name = name;
|
217
|
+
ASSERT_NE(0, entry.code);
|
218
|
+
refs_.Add(entry);
|
219
|
+
if (id > max_id_[type]) max_id_[type] = id;
|
220
|
+
}
|
221
|
+
|
222
|
+
|
223
|
+
void ExternalReferenceTable::PopulateTable() {
|
224
|
+
for (int type_code = 0; type_code < kTypeCodeCount; type_code++) {
|
225
|
+
max_id_[type_code] = 0;
|
226
|
+
}
|
227
|
+
|
228
|
+
// The following populates all of the different type of external references
|
229
|
+
// into the ExternalReferenceTable.
|
230
|
+
//
|
231
|
+
// NOTE: This function was originally 100k of code. It has since been
|
232
|
+
// rewritten to be mostly table driven, as the callback macro style tends to
|
233
|
+
// very easily cause code bloat. Please be careful in the future when adding
|
234
|
+
// new references.
|
235
|
+
|
236
|
+
struct RefTableEntry {
|
237
|
+
TypeCode type;
|
238
|
+
uint16_t id;
|
239
|
+
const char* name;
|
240
|
+
};
|
241
|
+
|
242
|
+
static const RefTableEntry ref_table[] = {
|
243
|
+
// Builtins
|
244
|
+
#define DEF_ENTRY_C(name) \
|
245
|
+
{ C_BUILTIN, \
|
246
|
+
Builtins::c_##name, \
|
247
|
+
"Builtins::" #name },
|
248
|
+
|
249
|
+
BUILTIN_LIST_C(DEF_ENTRY_C)
|
250
|
+
#undef DEF_ENTRY_C
|
251
|
+
|
252
|
+
#define DEF_ENTRY_C(name) \
|
253
|
+
{ BUILTIN, \
|
254
|
+
Builtins::name, \
|
255
|
+
"Builtins::" #name },
|
256
|
+
#define DEF_ENTRY_A(name, kind, state) DEF_ENTRY_C(name)
|
257
|
+
|
258
|
+
BUILTIN_LIST_C(DEF_ENTRY_C)
|
259
|
+
BUILTIN_LIST_A(DEF_ENTRY_A)
|
260
|
+
BUILTIN_LIST_DEBUG_A(DEF_ENTRY_A)
|
261
|
+
#undef DEF_ENTRY_C
|
262
|
+
#undef DEF_ENTRY_A
|
263
|
+
|
264
|
+
// Runtime functions
|
265
|
+
#define RUNTIME_ENTRY(name, nargs, ressize) \
|
266
|
+
{ RUNTIME_FUNCTION, \
|
267
|
+
Runtime::k##name, \
|
268
|
+
"Runtime::" #name },
|
269
|
+
|
270
|
+
RUNTIME_FUNCTION_LIST(RUNTIME_ENTRY)
|
271
|
+
#undef RUNTIME_ENTRY
|
272
|
+
|
273
|
+
// IC utilities
|
274
|
+
#define IC_ENTRY(name) \
|
275
|
+
{ IC_UTILITY, \
|
276
|
+
IC::k##name, \
|
277
|
+
"IC::" #name },
|
278
|
+
|
279
|
+
IC_UTIL_LIST(IC_ENTRY)
|
280
|
+
#undef IC_ENTRY
|
281
|
+
}; // end of ref_table[].
|
282
|
+
|
283
|
+
for (size_t i = 0; i < ARRAY_SIZE(ref_table); ++i) {
|
284
|
+
AddFromId(ref_table[i].type, ref_table[i].id, ref_table[i].name);
|
285
|
+
}
|
286
|
+
|
287
|
+
#ifdef ENABLE_DEBUGGER_SUPPORT
|
288
|
+
// Debug addresses
|
289
|
+
Add(Debug_Address(Debug::k_after_break_target_address).address(),
|
290
|
+
DEBUG_ADDRESS,
|
291
|
+
Debug::k_after_break_target_address << kDebugIdShift,
|
292
|
+
"Debug::after_break_target_address()");
|
293
|
+
Add(Debug_Address(Debug::k_debug_break_return_address).address(),
|
294
|
+
DEBUG_ADDRESS,
|
295
|
+
Debug::k_debug_break_return_address << kDebugIdShift,
|
296
|
+
"Debug::debug_break_return_address()");
|
297
|
+
const char* debug_register_format = "Debug::register_address(%i)";
|
298
|
+
int dr_format_length = StrLength(debug_register_format);
|
299
|
+
for (int i = 0; i < kNumJSCallerSaved; ++i) {
|
300
|
+
Vector<char> name = Vector<char>::New(dr_format_length + 1);
|
301
|
+
OS::SNPrintF(name, debug_register_format, i);
|
302
|
+
Add(Debug_Address(Debug::k_register_address, i).address(),
|
303
|
+
DEBUG_ADDRESS,
|
304
|
+
Debug::k_register_address << kDebugIdShift | i,
|
305
|
+
name.start());
|
306
|
+
}
|
307
|
+
#endif
|
308
|
+
|
309
|
+
// Stat counters
|
310
|
+
struct StatsRefTableEntry {
|
311
|
+
StatsCounter* counter;
|
312
|
+
uint16_t id;
|
313
|
+
const char* name;
|
314
|
+
};
|
315
|
+
|
316
|
+
static const StatsRefTableEntry stats_ref_table[] = {
|
317
|
+
#define COUNTER_ENTRY(name, caption) \
|
318
|
+
{ &Counters::name, \
|
319
|
+
Counters::k_##name, \
|
320
|
+
"Counters::" #name },
|
321
|
+
|
322
|
+
STATS_COUNTER_LIST_1(COUNTER_ENTRY)
|
323
|
+
STATS_COUNTER_LIST_2(COUNTER_ENTRY)
|
324
|
+
#undef COUNTER_ENTRY
|
325
|
+
}; // end of stats_ref_table[].
|
326
|
+
|
327
|
+
for (size_t i = 0; i < ARRAY_SIZE(stats_ref_table); ++i) {
|
328
|
+
Add(reinterpret_cast<Address>(
|
329
|
+
GetInternalPointer(stats_ref_table[i].counter)),
|
330
|
+
STATS_COUNTER,
|
331
|
+
stats_ref_table[i].id,
|
332
|
+
stats_ref_table[i].name);
|
333
|
+
}
|
334
|
+
|
335
|
+
// Top addresses
|
336
|
+
const char* top_address_format = "Top::%s";
|
337
|
+
|
338
|
+
const char* AddressNames[] = {
|
339
|
+
#define C(name) #name,
|
340
|
+
TOP_ADDRESS_LIST(C)
|
341
|
+
TOP_ADDRESS_LIST_PROF(C)
|
342
|
+
NULL
|
343
|
+
#undef C
|
344
|
+
};
|
345
|
+
|
346
|
+
int top_format_length = StrLength(top_address_format) - 2;
|
347
|
+
for (uint16_t i = 0; i < Top::k_top_address_count; ++i) {
|
348
|
+
const char* address_name = AddressNames[i];
|
349
|
+
Vector<char> name =
|
350
|
+
Vector<char>::New(top_format_length + StrLength(address_name) + 1);
|
351
|
+
const char* chars = name.start();
|
352
|
+
OS::SNPrintF(name, top_address_format, address_name);
|
353
|
+
Add(Top::get_address_from_id((Top::AddressId)i), TOP_ADDRESS, i, chars);
|
354
|
+
}
|
355
|
+
|
356
|
+
// Extensions
|
357
|
+
Add(FUNCTION_ADDR(GCExtension::GC), EXTENSION, 1,
|
358
|
+
"GCExtension::GC");
|
359
|
+
|
360
|
+
// Accessors
|
361
|
+
#define ACCESSOR_DESCRIPTOR_DECLARATION(name) \
|
362
|
+
Add((Address)&Accessors::name, \
|
363
|
+
ACCESSOR, \
|
364
|
+
Accessors::k##name, \
|
365
|
+
"Accessors::" #name);
|
366
|
+
|
367
|
+
ACCESSOR_DESCRIPTOR_LIST(ACCESSOR_DESCRIPTOR_DECLARATION)
|
368
|
+
#undef ACCESSOR_DESCRIPTOR_DECLARATION
|
369
|
+
|
370
|
+
// Stub cache tables
|
371
|
+
Add(SCTableReference::keyReference(StubCache::kPrimary).address(),
|
372
|
+
STUB_CACHE_TABLE,
|
373
|
+
1,
|
374
|
+
"StubCache::primary_->key");
|
375
|
+
Add(SCTableReference::valueReference(StubCache::kPrimary).address(),
|
376
|
+
STUB_CACHE_TABLE,
|
377
|
+
2,
|
378
|
+
"StubCache::primary_->value");
|
379
|
+
Add(SCTableReference::keyReference(StubCache::kSecondary).address(),
|
380
|
+
STUB_CACHE_TABLE,
|
381
|
+
3,
|
382
|
+
"StubCache::secondary_->key");
|
383
|
+
Add(SCTableReference::valueReference(StubCache::kSecondary).address(),
|
384
|
+
STUB_CACHE_TABLE,
|
385
|
+
4,
|
386
|
+
"StubCache::secondary_->value");
|
387
|
+
|
388
|
+
// Runtime entries
|
389
|
+
Add(ExternalReference::perform_gc_function().address(),
|
390
|
+
RUNTIME_ENTRY,
|
391
|
+
1,
|
392
|
+
"Runtime::PerformGC");
|
393
|
+
Add(ExternalReference::random_positive_smi_function().address(),
|
394
|
+
RUNTIME_ENTRY,
|
395
|
+
2,
|
396
|
+
"V8::RandomPositiveSmi");
|
397
|
+
|
398
|
+
// Miscellaneous
|
399
|
+
Add(ExternalReference::builtin_passed_function().address(),
|
400
|
+
UNCLASSIFIED,
|
401
|
+
1,
|
402
|
+
"Builtins::builtin_passed_function");
|
403
|
+
Add(ExternalReference::the_hole_value_location().address(),
|
404
|
+
UNCLASSIFIED,
|
405
|
+
2,
|
406
|
+
"Factory::the_hole_value().location()");
|
407
|
+
Add(ExternalReference::roots_address().address(),
|
408
|
+
UNCLASSIFIED,
|
409
|
+
3,
|
410
|
+
"Heap::roots_address()");
|
411
|
+
Add(ExternalReference::address_of_stack_limit().address(),
|
412
|
+
UNCLASSIFIED,
|
413
|
+
4,
|
414
|
+
"StackGuard::address_of_jslimit()");
|
415
|
+
Add(ExternalReference::address_of_real_stack_limit().address(),
|
416
|
+
UNCLASSIFIED,
|
417
|
+
5,
|
418
|
+
"StackGuard::address_of_real_jslimit()");
|
419
|
+
Add(ExternalReference::address_of_regexp_stack_limit().address(),
|
420
|
+
UNCLASSIFIED,
|
421
|
+
6,
|
422
|
+
"RegExpStack::limit_address()");
|
423
|
+
Add(ExternalReference::new_space_start().address(),
|
424
|
+
UNCLASSIFIED,
|
425
|
+
7,
|
426
|
+
"Heap::NewSpaceStart()");
|
427
|
+
Add(ExternalReference::heap_always_allocate_scope_depth().address(),
|
428
|
+
UNCLASSIFIED,
|
429
|
+
8,
|
430
|
+
"Heap::always_allocate_scope_depth()");
|
431
|
+
Add(ExternalReference::new_space_allocation_limit_address().address(),
|
432
|
+
UNCLASSIFIED,
|
433
|
+
9,
|
434
|
+
"Heap::NewSpaceAllocationLimitAddress()");
|
435
|
+
Add(ExternalReference::new_space_allocation_top_address().address(),
|
436
|
+
UNCLASSIFIED,
|
437
|
+
10,
|
438
|
+
"Heap::NewSpaceAllocationTopAddress()");
|
439
|
+
#ifdef ENABLE_DEBUGGER_SUPPORT
|
440
|
+
Add(ExternalReference::debug_break().address(),
|
441
|
+
UNCLASSIFIED,
|
442
|
+
11,
|
443
|
+
"Debug::Break()");
|
444
|
+
Add(ExternalReference::debug_step_in_fp_address().address(),
|
445
|
+
UNCLASSIFIED,
|
446
|
+
12,
|
447
|
+
"Debug::step_in_fp_addr()");
|
448
|
+
#endif
|
449
|
+
Add(ExternalReference::double_fp_operation(Token::ADD).address(),
|
450
|
+
UNCLASSIFIED,
|
451
|
+
13,
|
452
|
+
"add_two_doubles");
|
453
|
+
Add(ExternalReference::double_fp_operation(Token::SUB).address(),
|
454
|
+
UNCLASSIFIED,
|
455
|
+
14,
|
456
|
+
"sub_two_doubles");
|
457
|
+
Add(ExternalReference::double_fp_operation(Token::MUL).address(),
|
458
|
+
UNCLASSIFIED,
|
459
|
+
15,
|
460
|
+
"mul_two_doubles");
|
461
|
+
Add(ExternalReference::double_fp_operation(Token::DIV).address(),
|
462
|
+
UNCLASSIFIED,
|
463
|
+
16,
|
464
|
+
"div_two_doubles");
|
465
|
+
Add(ExternalReference::double_fp_operation(Token::MOD).address(),
|
466
|
+
UNCLASSIFIED,
|
467
|
+
17,
|
468
|
+
"mod_two_doubles");
|
469
|
+
Add(ExternalReference::compare_doubles().address(),
|
470
|
+
UNCLASSIFIED,
|
471
|
+
18,
|
472
|
+
"compare_doubles");
|
473
|
+
#ifdef V8_NATIVE_REGEXP
|
474
|
+
Add(ExternalReference::re_case_insensitive_compare_uc16().address(),
|
475
|
+
UNCLASSIFIED,
|
476
|
+
19,
|
477
|
+
"NativeRegExpMacroAssembler::CaseInsensitiveCompareUC16()");
|
478
|
+
Add(ExternalReference::re_check_stack_guard_state().address(),
|
479
|
+
UNCLASSIFIED,
|
480
|
+
20,
|
481
|
+
"RegExpMacroAssembler*::CheckStackGuardState()");
|
482
|
+
Add(ExternalReference::re_grow_stack().address(),
|
483
|
+
UNCLASSIFIED,
|
484
|
+
21,
|
485
|
+
"NativeRegExpMacroAssembler::GrowStack()");
|
486
|
+
#endif
|
487
|
+
// Keyed lookup cache.
|
488
|
+
Add(ExternalReference::keyed_lookup_cache_keys().address(),
|
489
|
+
UNCLASSIFIED,
|
490
|
+
22,
|
491
|
+
"KeyedLookupCache::keys()");
|
492
|
+
Add(ExternalReference::keyed_lookup_cache_field_offsets().address(),
|
493
|
+
UNCLASSIFIED,
|
494
|
+
23,
|
495
|
+
"KeyedLookupCache::field_offsets()");
|
496
|
+
}
|
497
|
+
|
498
|
+
|
499
|
+
ExternalReferenceEncoder::ExternalReferenceEncoder()
|
500
|
+
: encodings_(Match) {
|
501
|
+
ExternalReferenceTable* external_references =
|
502
|
+
ExternalReferenceTable::instance();
|
503
|
+
for (int i = 0; i < external_references->size(); ++i) {
|
504
|
+
Put(external_references->address(i), i);
|
505
|
+
}
|
506
|
+
}
|
507
|
+
|
508
|
+
|
509
|
+
uint32_t ExternalReferenceEncoder::Encode(Address key) const {
|
510
|
+
int index = IndexOf(key);
|
511
|
+
return index >=0 ? ExternalReferenceTable::instance()->code(index) : 0;
|
512
|
+
}
|
513
|
+
|
514
|
+
|
515
|
+
const char* ExternalReferenceEncoder::NameOfAddress(Address key) const {
|
516
|
+
int index = IndexOf(key);
|
517
|
+
return index >=0 ? ExternalReferenceTable::instance()->name(index) : NULL;
|
518
|
+
}
|
519
|
+
|
520
|
+
|
521
|
+
int ExternalReferenceEncoder::IndexOf(Address key) const {
|
522
|
+
if (key == NULL) return -1;
|
523
|
+
HashMap::Entry* entry =
|
524
|
+
const_cast<HashMap &>(encodings_).Lookup(key, Hash(key), false);
|
525
|
+
return entry == NULL
|
526
|
+
? -1
|
527
|
+
: static_cast<int>(reinterpret_cast<intptr_t>(entry->value));
|
528
|
+
}
|
529
|
+
|
530
|
+
|
531
|
+
void ExternalReferenceEncoder::Put(Address key, int index) {
|
532
|
+
HashMap::Entry* entry = encodings_.Lookup(key, Hash(key), true);
|
533
|
+
entry->value = reinterpret_cast<void *>(index);
|
534
|
+
}
|
535
|
+
|
536
|
+
|
537
|
+
ExternalReferenceDecoder::ExternalReferenceDecoder()
|
538
|
+
: encodings_(NewArray<Address*>(kTypeCodeCount)) {
|
539
|
+
ExternalReferenceTable* external_references =
|
540
|
+
ExternalReferenceTable::instance();
|
541
|
+
for (int type = kFirstTypeCode; type < kTypeCodeCount; ++type) {
|
542
|
+
int max = external_references->max_id(type) + 1;
|
543
|
+
encodings_[type] = NewArray<Address>(max + 1);
|
544
|
+
}
|
545
|
+
for (int i = 0; i < external_references->size(); ++i) {
|
546
|
+
Put(external_references->code(i), external_references->address(i));
|
547
|
+
}
|
548
|
+
}
|
549
|
+
|
550
|
+
|
551
|
+
ExternalReferenceDecoder::~ExternalReferenceDecoder() {
|
552
|
+
for (int type = kFirstTypeCode; type < kTypeCodeCount; ++type) {
|
553
|
+
DeleteArray(encodings_[type]);
|
554
|
+
}
|
555
|
+
DeleteArray(encodings_);
|
556
|
+
}
|
557
|
+
|
558
|
+
|
559
|
+
bool Serializer::serialization_enabled_ = false;
|
560
|
+
bool Serializer::too_late_to_enable_now_ = false;
|
561
|
+
|
562
|
+
|
563
|
+
Deserializer::Deserializer(SnapshotByteSource* source)
|
564
|
+
: source_(source),
|
565
|
+
external_reference_decoder_(NULL) {
|
566
|
+
}
|
567
|
+
|
568
|
+
|
569
|
+
// This routine both allocates a new object, and also keeps
|
570
|
+
// track of where objects have been allocated so that we can
|
571
|
+
// fix back references when deserializing.
|
572
|
+
Address Deserializer::Allocate(int space_index, Space* space, int size) {
|
573
|
+
Address address;
|
574
|
+
if (!SpaceIsLarge(space_index)) {
|
575
|
+
ASSERT(!SpaceIsPaged(space_index) ||
|
576
|
+
size <= Page::kPageSize - Page::kObjectStartOffset);
|
577
|
+
Object* new_allocation;
|
578
|
+
if (space_index == NEW_SPACE) {
|
579
|
+
new_allocation = reinterpret_cast<NewSpace*>(space)->AllocateRaw(size);
|
580
|
+
} else {
|
581
|
+
new_allocation = reinterpret_cast<PagedSpace*>(space)->AllocateRaw(size);
|
582
|
+
}
|
583
|
+
HeapObject* new_object = HeapObject::cast(new_allocation);
|
584
|
+
ASSERT(!new_object->IsFailure());
|
585
|
+
address = new_object->address();
|
586
|
+
high_water_[space_index] = address + size;
|
587
|
+
} else {
|
588
|
+
ASSERT(SpaceIsLarge(space_index));
|
589
|
+
ASSERT(size > Page::kPageSize - Page::kObjectStartOffset);
|
590
|
+
LargeObjectSpace* lo_space = reinterpret_cast<LargeObjectSpace*>(space);
|
591
|
+
Object* new_allocation;
|
592
|
+
if (space_index == kLargeData) {
|
593
|
+
new_allocation = lo_space->AllocateRaw(size);
|
594
|
+
} else if (space_index == kLargeFixedArray) {
|
595
|
+
new_allocation = lo_space->AllocateRawFixedArray(size);
|
596
|
+
} else {
|
597
|
+
ASSERT_EQ(kLargeCode, space_index);
|
598
|
+
new_allocation = lo_space->AllocateRawCode(size);
|
599
|
+
}
|
600
|
+
ASSERT(!new_allocation->IsFailure());
|
601
|
+
HeapObject* new_object = HeapObject::cast(new_allocation);
|
602
|
+
// Record all large objects in the same space.
|
603
|
+
address = new_object->address();
|
604
|
+
high_water_[LO_SPACE] = address + size;
|
605
|
+
}
|
606
|
+
last_object_address_ = address;
|
607
|
+
return address;
|
608
|
+
}
|
609
|
+
|
610
|
+
|
611
|
+
// This returns the address of an object that has been described in the
|
612
|
+
// snapshot as being offset bytes back in a particular space.
|
613
|
+
HeapObject* Deserializer::GetAddressFromEnd(int space) {
|
614
|
+
int offset = source_->GetInt();
|
615
|
+
ASSERT(!SpaceIsLarge(space));
|
616
|
+
offset <<= kObjectAlignmentBits;
|
617
|
+
return HeapObject::FromAddress(high_water_[space] - offset);
|
618
|
+
}
|
619
|
+
|
620
|
+
|
621
|
+
// This returns the address of an object that has been described in the
|
622
|
+
// snapshot as being offset bytes into a particular space.
|
623
|
+
HeapObject* Deserializer::GetAddressFromStart(int space) {
|
624
|
+
int offset = source_->GetInt();
|
625
|
+
if (SpaceIsLarge(space)) {
|
626
|
+
// Large spaces have one object per 'page'.
|
627
|
+
return HeapObject::FromAddress(pages_[LO_SPACE][offset]);
|
628
|
+
}
|
629
|
+
offset <<= kObjectAlignmentBits;
|
630
|
+
if (space == NEW_SPACE) {
|
631
|
+
// New space has only one space - numbered 0.
|
632
|
+
return HeapObject::FromAddress(pages_[space][0] + offset);
|
633
|
+
}
|
634
|
+
ASSERT(SpaceIsPaged(space));
|
635
|
+
int page_of_pointee = offset >> kPageSizeBits;
|
636
|
+
Address object_address = pages_[space][page_of_pointee] +
|
637
|
+
(offset & Page::kPageAlignmentMask);
|
638
|
+
return HeapObject::FromAddress(object_address);
|
639
|
+
}
|
640
|
+
|
641
|
+
|
642
|
+
void Deserializer::Deserialize() {
|
643
|
+
// Don't GC while deserializing - just expand the heap.
|
644
|
+
AlwaysAllocateScope always_allocate;
|
645
|
+
// Don't use the free lists while deserializing.
|
646
|
+
LinearAllocationScope allocate_linearly;
|
647
|
+
// No active threads.
|
648
|
+
ASSERT_EQ(NULL, ThreadState::FirstInUse());
|
649
|
+
// No active handles.
|
650
|
+
ASSERT(HandleScopeImplementer::instance()->blocks()->is_empty());
|
651
|
+
ASSERT_EQ(NULL, external_reference_decoder_);
|
652
|
+
external_reference_decoder_ = new ExternalReferenceDecoder();
|
653
|
+
Heap::IterateRoots(this, VISIT_ONLY_STRONG);
|
654
|
+
ASSERT(source_->AtEOF());
|
655
|
+
delete external_reference_decoder_;
|
656
|
+
external_reference_decoder_ = NULL;
|
657
|
+
}
|
658
|
+
|
659
|
+
|
660
|
+
// This is called on the roots. It is the driver of the deserialization
|
661
|
+
// process. It is also called on the body of each function.
|
662
|
+
void Deserializer::VisitPointers(Object** start, Object** end) {
|
663
|
+
// The space must be new space. Any other space would cause ReadChunk to try
|
664
|
+
// to update the remembered using NULL as the address.
|
665
|
+
ReadChunk(start, end, NEW_SPACE, NULL);
|
666
|
+
}
|
667
|
+
|
668
|
+
|
669
|
+
// This routine writes the new object into the pointer provided and then
|
670
|
+
// returns true if the new object was in young space and false otherwise.
|
671
|
+
// The reason for this strange interface is that otherwise the object is
|
672
|
+
// written very late, which means the ByteArray map is not set up by the
|
673
|
+
// time we need to use it to mark the space at the end of a page free (by
|
674
|
+
// making it into a byte array).
|
675
|
+
void Deserializer::ReadObject(int space_number,
|
676
|
+
Space* space,
|
677
|
+
Object** write_back) {
|
678
|
+
int size = source_->GetInt() << kObjectAlignmentBits;
|
679
|
+
Address address = Allocate(space_number, space, size);
|
680
|
+
*write_back = HeapObject::FromAddress(address);
|
681
|
+
Object** current = reinterpret_cast<Object**>(address);
|
682
|
+
Object** limit = current + (size >> kPointerSizeLog2);
|
683
|
+
ReadChunk(current, limit, space_number, address);
|
684
|
+
}
|
685
|
+
|
686
|
+
|
687
|
+
#define ONE_CASE_PER_SPACE(base_tag) \
|
688
|
+
case (base_tag) + NEW_SPACE: /* NOLINT */ \
|
689
|
+
case (base_tag) + OLD_POINTER_SPACE: /* NOLINT */ \
|
690
|
+
case (base_tag) + OLD_DATA_SPACE: /* NOLINT */ \
|
691
|
+
case (base_tag) + CODE_SPACE: /* NOLINT */ \
|
692
|
+
case (base_tag) + MAP_SPACE: /* NOLINT */ \
|
693
|
+
case (base_tag) + CELL_SPACE: /* NOLINT */ \
|
694
|
+
case (base_tag) + kLargeData: /* NOLINT */ \
|
695
|
+
case (base_tag) + kLargeCode: /* NOLINT */ \
|
696
|
+
case (base_tag) + kLargeFixedArray: /* NOLINT */
|
697
|
+
|
698
|
+
|
699
|
+
void Deserializer::ReadChunk(Object** current,
|
700
|
+
Object** limit,
|
701
|
+
int space,
|
702
|
+
Address address) {
|
703
|
+
while (current < limit) {
|
704
|
+
int data = source_->Get();
|
705
|
+
switch (data) {
|
706
|
+
#define RAW_CASE(index, size) \
|
707
|
+
case RAW_DATA_SERIALIZATION + index: { \
|
708
|
+
byte* raw_data_out = reinterpret_cast<byte*>(current); \
|
709
|
+
source_->CopyRaw(raw_data_out, size); \
|
710
|
+
current = reinterpret_cast<Object**>(raw_data_out + size); \
|
711
|
+
break; \
|
712
|
+
}
|
713
|
+
COMMON_RAW_LENGTHS(RAW_CASE)
|
714
|
+
#undef RAW_CASE
|
715
|
+
case RAW_DATA_SERIALIZATION: {
|
716
|
+
int size = source_->GetInt();
|
717
|
+
byte* raw_data_out = reinterpret_cast<byte*>(current);
|
718
|
+
source_->CopyRaw(raw_data_out, size);
|
719
|
+
current = reinterpret_cast<Object**>(raw_data_out + size);
|
720
|
+
break;
|
721
|
+
}
|
722
|
+
case OBJECT_SERIALIZATION + NEW_SPACE: {
|
723
|
+
ReadObject(NEW_SPACE, Heap::new_space(), current);
|
724
|
+
if (space != NEW_SPACE) {
|
725
|
+
Heap::RecordWrite(address, static_cast<int>(
|
726
|
+
reinterpret_cast<Address>(current) - address));
|
727
|
+
}
|
728
|
+
current++;
|
729
|
+
break;
|
730
|
+
}
|
731
|
+
case OBJECT_SERIALIZATION + OLD_DATA_SPACE:
|
732
|
+
ReadObject(OLD_DATA_SPACE, Heap::old_data_space(), current++);
|
733
|
+
break;
|
734
|
+
case OBJECT_SERIALIZATION + OLD_POINTER_SPACE:
|
735
|
+
ReadObject(OLD_POINTER_SPACE, Heap::old_pointer_space(), current++);
|
736
|
+
break;
|
737
|
+
case OBJECT_SERIALIZATION + MAP_SPACE:
|
738
|
+
ReadObject(MAP_SPACE, Heap::map_space(), current++);
|
739
|
+
break;
|
740
|
+
case OBJECT_SERIALIZATION + CODE_SPACE:
|
741
|
+
ReadObject(CODE_SPACE, Heap::code_space(), current++);
|
742
|
+
LOG(LogCodeObject(current[-1]));
|
743
|
+
break;
|
744
|
+
case OBJECT_SERIALIZATION + CELL_SPACE:
|
745
|
+
ReadObject(CELL_SPACE, Heap::cell_space(), current++);
|
746
|
+
break;
|
747
|
+
case OBJECT_SERIALIZATION + kLargeData:
|
748
|
+
ReadObject(kLargeData, Heap::lo_space(), current++);
|
749
|
+
break;
|
750
|
+
case OBJECT_SERIALIZATION + kLargeCode:
|
751
|
+
ReadObject(kLargeCode, Heap::lo_space(), current++);
|
752
|
+
LOG(LogCodeObject(current[-1]));
|
753
|
+
break;
|
754
|
+
case OBJECT_SERIALIZATION + kLargeFixedArray:
|
755
|
+
ReadObject(kLargeFixedArray, Heap::lo_space(), current++);
|
756
|
+
break;
|
757
|
+
case CODE_OBJECT_SERIALIZATION + kLargeCode: {
|
758
|
+
Object* new_code_object = NULL;
|
759
|
+
ReadObject(kLargeCode, Heap::lo_space(), &new_code_object);
|
760
|
+
Code* code_object = reinterpret_cast<Code*>(new_code_object);
|
761
|
+
LOG(LogCodeObject(code_object));
|
762
|
+
// Setting a branch/call to another code object from code.
|
763
|
+
Address location_of_branch_data = reinterpret_cast<Address>(current);
|
764
|
+
Assembler::set_target_at(location_of_branch_data,
|
765
|
+
code_object->instruction_start());
|
766
|
+
location_of_branch_data += Assembler::kCallTargetSize;
|
767
|
+
current = reinterpret_cast<Object**>(location_of_branch_data);
|
768
|
+
break;
|
769
|
+
}
|
770
|
+
case CODE_OBJECT_SERIALIZATION + CODE_SPACE: {
|
771
|
+
Object* new_code_object = NULL;
|
772
|
+
ReadObject(CODE_SPACE, Heap::code_space(), &new_code_object);
|
773
|
+
Code* code_object = reinterpret_cast<Code*>(new_code_object);
|
774
|
+
LOG(LogCodeObject(code_object));
|
775
|
+
// Setting a branch/call to another code object from code.
|
776
|
+
Address location_of_branch_data = reinterpret_cast<Address>(current);
|
777
|
+
Assembler::set_target_at(location_of_branch_data,
|
778
|
+
code_object->instruction_start());
|
779
|
+
location_of_branch_data += Assembler::kCallTargetSize;
|
780
|
+
current = reinterpret_cast<Object**>(location_of_branch_data);
|
781
|
+
break;
|
782
|
+
}
|
783
|
+
ONE_CASE_PER_SPACE(BACKREF_SERIALIZATION) {
|
784
|
+
// Write a backreference to an object we unpacked earlier.
|
785
|
+
int backref_space = (data & kSpaceMask);
|
786
|
+
if (backref_space == NEW_SPACE && space != NEW_SPACE) {
|
787
|
+
Heap::RecordWrite(address, static_cast<int>(
|
788
|
+
reinterpret_cast<Address>(current) - address));
|
789
|
+
}
|
790
|
+
*current++ = GetAddressFromEnd(backref_space);
|
791
|
+
break;
|
792
|
+
}
|
793
|
+
ONE_CASE_PER_SPACE(REFERENCE_SERIALIZATION) {
|
794
|
+
// Write a reference to an object we unpacked earlier.
|
795
|
+
int reference_space = (data & kSpaceMask);
|
796
|
+
if (reference_space == NEW_SPACE && space != NEW_SPACE) {
|
797
|
+
Heap::RecordWrite(address, static_cast<int>(
|
798
|
+
reinterpret_cast<Address>(current) - address));
|
799
|
+
}
|
800
|
+
*current++ = GetAddressFromStart(reference_space);
|
801
|
+
break;
|
802
|
+
}
|
803
|
+
#define COMMON_REFS_CASE(index, reference_space, address) \
|
804
|
+
case REFERENCE_SERIALIZATION + index: { \
|
805
|
+
ASSERT(SpaceIsPaged(reference_space)); \
|
806
|
+
Address object_address = \
|
807
|
+
pages_[reference_space][0] + (address << kObjectAlignmentBits); \
|
808
|
+
*current++ = HeapObject::FromAddress(object_address); \
|
809
|
+
break; \
|
810
|
+
}
|
811
|
+
COMMON_REFERENCE_PATTERNS(COMMON_REFS_CASE)
|
812
|
+
#undef COMMON_REFS_CASE
|
813
|
+
ONE_CASE_PER_SPACE(CODE_BACKREF_SERIALIZATION) {
|
814
|
+
int backref_space = (data & kSpaceMask);
|
815
|
+
// Can't use Code::cast because heap is not set up yet and assertions
|
816
|
+
// will fail.
|
817
|
+
Code* code_object =
|
818
|
+
reinterpret_cast<Code*>(GetAddressFromEnd(backref_space));
|
819
|
+
// Setting a branch/call to previously decoded code object from code.
|
820
|
+
Address location_of_branch_data = reinterpret_cast<Address>(current);
|
821
|
+
Assembler::set_target_at(location_of_branch_data,
|
822
|
+
code_object->instruction_start());
|
823
|
+
location_of_branch_data += Assembler::kCallTargetSize;
|
824
|
+
current = reinterpret_cast<Object**>(location_of_branch_data);
|
825
|
+
break;
|
826
|
+
}
|
827
|
+
ONE_CASE_PER_SPACE(CODE_REFERENCE_SERIALIZATION) {
|
828
|
+
int backref_space = (data & kSpaceMask);
|
829
|
+
// Can't use Code::cast because heap is not set up yet and assertions
|
830
|
+
// will fail.
|
831
|
+
Code* code_object =
|
832
|
+
reinterpret_cast<Code*>(GetAddressFromStart(backref_space));
|
833
|
+
// Setting a branch/call to previously decoded code object from code.
|
834
|
+
Address location_of_branch_data = reinterpret_cast<Address>(current);
|
835
|
+
Assembler::set_target_at(location_of_branch_data,
|
836
|
+
code_object->instruction_start());
|
837
|
+
location_of_branch_data += Assembler::kCallTargetSize;
|
838
|
+
current = reinterpret_cast<Object**>(location_of_branch_data);
|
839
|
+
break;
|
840
|
+
}
|
841
|
+
case EXTERNAL_REFERENCE_SERIALIZATION: {
|
842
|
+
int reference_id = source_->GetInt();
|
843
|
+
Address address = external_reference_decoder_->Decode(reference_id);
|
844
|
+
*current++ = reinterpret_cast<Object*>(address);
|
845
|
+
break;
|
846
|
+
}
|
847
|
+
case EXTERNAL_BRANCH_TARGET_SERIALIZATION: {
|
848
|
+
int reference_id = source_->GetInt();
|
849
|
+
Address address = external_reference_decoder_->Decode(reference_id);
|
850
|
+
Address location_of_branch_data = reinterpret_cast<Address>(current);
|
851
|
+
Assembler::set_external_target_at(location_of_branch_data, address);
|
852
|
+
location_of_branch_data += Assembler::kExternalTargetSize;
|
853
|
+
current = reinterpret_cast<Object**>(location_of_branch_data);
|
854
|
+
break;
|
855
|
+
}
|
856
|
+
case START_NEW_PAGE_SERIALIZATION: {
|
857
|
+
int space = source_->Get();
|
858
|
+
pages_[space].Add(last_object_address_);
|
859
|
+
break;
|
860
|
+
}
|
861
|
+
case NATIVES_STRING_RESOURCE: {
|
862
|
+
int index = source_->Get();
|
863
|
+
Vector<const char> source_vector = Natives::GetScriptSource(index);
|
864
|
+
NativesExternalStringResource* resource =
|
865
|
+
new NativesExternalStringResource(source_vector.start());
|
866
|
+
*current++ = reinterpret_cast<Object*>(resource);
|
867
|
+
break;
|
868
|
+
}
|
869
|
+
default:
|
870
|
+
UNREACHABLE();
|
871
|
+
}
|
872
|
+
}
|
873
|
+
ASSERT_EQ(current, limit);
|
874
|
+
}
|
875
|
+
|
876
|
+
|
877
|
+
void SnapshotByteSink::PutInt(uintptr_t integer, const char* description) {
|
878
|
+
const int max_shift = ((kPointerSize * kBitsPerByte) / 7) * 7;
|
879
|
+
for (int shift = max_shift; shift > 0; shift -= 7) {
|
880
|
+
if (integer >= static_cast<uintptr_t>(1u) << shift) {
|
881
|
+
Put(((integer >> shift) & 0x7f) | 0x80, "IntPart");
|
882
|
+
}
|
883
|
+
}
|
884
|
+
PutSection(integer & 0x7f, "IntLastPart");
|
885
|
+
}
|
886
|
+
|
887
|
+
#ifdef DEBUG
|
888
|
+
|
889
|
+
void Deserializer::Synchronize(const char* tag) {
|
890
|
+
int data = source_->Get();
|
891
|
+
// If this assert fails then that indicates that you have a mismatch between
|
892
|
+
// the number of GC roots when serializing and deserializing.
|
893
|
+
ASSERT_EQ(SYNCHRONIZE, data);
|
894
|
+
do {
|
895
|
+
int character = source_->Get();
|
896
|
+
if (character == 0) break;
|
897
|
+
if (FLAG_debug_serialization) {
|
898
|
+
PrintF("%c", character);
|
899
|
+
}
|
900
|
+
} while (true);
|
901
|
+
if (FLAG_debug_serialization) {
|
902
|
+
PrintF("\n");
|
903
|
+
}
|
904
|
+
}
|
905
|
+
|
906
|
+
|
907
|
+
void Serializer::Synchronize(const char* tag) {
|
908
|
+
sink_->Put(SYNCHRONIZE, tag);
|
909
|
+
int character;
|
910
|
+
do {
|
911
|
+
character = *tag++;
|
912
|
+
sink_->PutSection(character, "TagCharacter");
|
913
|
+
} while (character != 0);
|
914
|
+
}
|
915
|
+
|
916
|
+
#endif
|
917
|
+
|
918
|
+
Serializer::Serializer(SnapshotByteSink* sink)
|
919
|
+
: sink_(sink),
|
920
|
+
current_root_index_(0),
|
921
|
+
external_reference_encoder_(NULL),
|
922
|
+
partial_(false) {
|
923
|
+
for (int i = 0; i <= LAST_SPACE; i++) {
|
924
|
+
fullness_[i] = 0;
|
925
|
+
}
|
926
|
+
}
|
927
|
+
|
928
|
+
|
929
|
+
void Serializer::Serialize() {
|
930
|
+
// No active threads.
|
931
|
+
CHECK_EQ(NULL, ThreadState::FirstInUse());
|
932
|
+
// No active or weak handles.
|
933
|
+
CHECK(HandleScopeImplementer::instance()->blocks()->is_empty());
|
934
|
+
CHECK_EQ(0, GlobalHandles::NumberOfWeakHandles());
|
935
|
+
CHECK_EQ(NULL, external_reference_encoder_);
|
936
|
+
// We don't support serializing installed extensions.
|
937
|
+
for (RegisteredExtension* ext = RegisteredExtension::first_extension();
|
938
|
+
ext != NULL;
|
939
|
+
ext = ext->next()) {
|
940
|
+
CHECK_NE(v8::INSTALLED, ext->state());
|
941
|
+
}
|
942
|
+
external_reference_encoder_ = new ExternalReferenceEncoder();
|
943
|
+
Heap::IterateRoots(this, VISIT_ONLY_STRONG);
|
944
|
+
delete external_reference_encoder_;
|
945
|
+
external_reference_encoder_ = NULL;
|
946
|
+
SerializationAddressMapper::Zap();
|
947
|
+
}
|
948
|
+
|
949
|
+
|
950
|
+
void Serializer::SerializePartial(Object** object) {
|
951
|
+
partial_ = true;
|
952
|
+
external_reference_encoder_ = new ExternalReferenceEncoder();
|
953
|
+
this->VisitPointer(object);
|
954
|
+
delete external_reference_encoder_;
|
955
|
+
external_reference_encoder_ = NULL;
|
956
|
+
SerializationAddressMapper::Zap();
|
957
|
+
}
|
958
|
+
|
959
|
+
|
960
|
+
void Serializer::VisitPointers(Object** start, Object** end) {
|
961
|
+
for (Object** current = start; current < end; current++) {
|
962
|
+
if ((*current)->IsSmi()) {
|
963
|
+
sink_->Put(RAW_DATA_SERIALIZATION, "RawData");
|
964
|
+
sink_->PutInt(kPointerSize, "length");
|
965
|
+
for (int i = 0; i < kPointerSize; i++) {
|
966
|
+
sink_->Put(reinterpret_cast<byte*>(current)[i], "Byte");
|
967
|
+
}
|
968
|
+
} else {
|
969
|
+
SerializeObject(*current, TAGGED_REPRESENTATION);
|
970
|
+
}
|
971
|
+
}
|
972
|
+
}
|
973
|
+
|
974
|
+
|
975
|
+
int Serializer::RootIndex(HeapObject* heap_object) {
|
976
|
+
for (int i = 0; i < Heap::kRootListLength; i++) {
|
977
|
+
Object* root = Heap::roots_address()[i];
|
978
|
+
if (root == heap_object) return i;
|
979
|
+
}
|
980
|
+
return kInvalidRootIndex;
|
981
|
+
}
|
982
|
+
|
983
|
+
|
984
|
+
void Serializer::SerializeObject(
|
985
|
+
Object* o,
|
986
|
+
ReferenceRepresentation reference_representation) {
|
987
|
+
CHECK(o->IsHeapObject());
|
988
|
+
HeapObject* heap_object = HeapObject::cast(o);
|
989
|
+
if (partial_) {
|
990
|
+
int root_index = RootIndex(heap_object);
|
991
|
+
if (root_index != kInvalidRootIndex) {
|
992
|
+
sink_->Put(ROOT_SERIALIZATION, "RootSerialization");
|
993
|
+
sink_->PutInt(root_index, "root_index");
|
994
|
+
return;
|
995
|
+
}
|
996
|
+
// All the symbols that the snapshot needs should be in the root table.
|
997
|
+
ASSERT(!heap_object->IsSymbol());
|
998
|
+
}
|
999
|
+
if (SerializationAddressMapper::IsMapped(heap_object)) {
|
1000
|
+
int space = SpaceOfAlreadySerializedObject(heap_object);
|
1001
|
+
int address = SerializationAddressMapper::MappedTo(heap_object);
|
1002
|
+
int offset = CurrentAllocationAddress(space) - address;
|
1003
|
+
bool from_start = true;
|
1004
|
+
if (SpaceIsPaged(space)) {
|
1005
|
+
if ((CurrentAllocationAddress(space) >> kPageSizeBits) ==
|
1006
|
+
(address >> kPageSizeBits)) {
|
1007
|
+
from_start = false;
|
1008
|
+
address = offset;
|
1009
|
+
}
|
1010
|
+
} else if (space == NEW_SPACE) {
|
1011
|
+
if (offset < address) {
|
1012
|
+
from_start = false;
|
1013
|
+
address = offset;
|
1014
|
+
}
|
1015
|
+
}
|
1016
|
+
// If we are actually dealing with real offsets (and not a numbering of
|
1017
|
+
// all objects) then we should shift out the bits that are always 0.
|
1018
|
+
if (!SpaceIsLarge(space)) address >>= kObjectAlignmentBits;
|
1019
|
+
if (reference_representation == CODE_TARGET_REPRESENTATION) {
|
1020
|
+
if (from_start) {
|
1021
|
+
sink_->Put(CODE_REFERENCE_SERIALIZATION + space, "RefCodeSer");
|
1022
|
+
sink_->PutInt(address, "address");
|
1023
|
+
} else {
|
1024
|
+
sink_->Put(CODE_BACKREF_SERIALIZATION + space, "BackRefCodeSer");
|
1025
|
+
sink_->PutInt(address, "address");
|
1026
|
+
}
|
1027
|
+
} else {
|
1028
|
+
CHECK_EQ(TAGGED_REPRESENTATION, reference_representation);
|
1029
|
+
if (from_start) {
|
1030
|
+
#define COMMON_REFS_CASE(tag, common_space, common_offset) \
|
1031
|
+
if (space == common_space && address == common_offset) { \
|
1032
|
+
sink_->PutSection(tag + REFERENCE_SERIALIZATION, "RefSer"); \
|
1033
|
+
} else /* NOLINT */
|
1034
|
+
COMMON_REFERENCE_PATTERNS(COMMON_REFS_CASE)
|
1035
|
+
#undef COMMON_REFS_CASE
|
1036
|
+
{ /* NOLINT */
|
1037
|
+
sink_->Put(REFERENCE_SERIALIZATION + space, "RefSer");
|
1038
|
+
sink_->PutInt(address, "address");
|
1039
|
+
}
|
1040
|
+
} else {
|
1041
|
+
sink_->Put(BACKREF_SERIALIZATION + space, "BackRefSer");
|
1042
|
+
sink_->PutInt(address, "address");
|
1043
|
+
}
|
1044
|
+
}
|
1045
|
+
} else {
|
1046
|
+
// Object has not yet been serialized. Serialize it here.
|
1047
|
+
ObjectSerializer serializer(this,
|
1048
|
+
heap_object,
|
1049
|
+
sink_,
|
1050
|
+
reference_representation);
|
1051
|
+
serializer.Serialize();
|
1052
|
+
}
|
1053
|
+
}
|
1054
|
+
|
1055
|
+
|
1056
|
+
|
1057
|
+
void Serializer::ObjectSerializer::Serialize() {
|
1058
|
+
int space = Serializer::SpaceOfObject(object_);
|
1059
|
+
int size = object_->Size();
|
1060
|
+
|
1061
|
+
if (reference_representation_ == TAGGED_REPRESENTATION) {
|
1062
|
+
sink_->Put(OBJECT_SERIALIZATION + space, "ObjectSerialization");
|
1063
|
+
} else {
|
1064
|
+
CHECK_EQ(CODE_TARGET_REPRESENTATION, reference_representation_);
|
1065
|
+
sink_->Put(CODE_OBJECT_SERIALIZATION + space, "ObjectSerialization");
|
1066
|
+
}
|
1067
|
+
sink_->PutInt(size >> kObjectAlignmentBits, "Size in words");
|
1068
|
+
|
1069
|
+
// Mark this object as already serialized.
|
1070
|
+
bool start_new_page;
|
1071
|
+
SerializationAddressMapper::Map(
|
1072
|
+
object_,
|
1073
|
+
serializer_->Allocate(space, size, &start_new_page));
|
1074
|
+
if (start_new_page) {
|
1075
|
+
sink_->Put(START_NEW_PAGE_SERIALIZATION, "NewPage");
|
1076
|
+
sink_->PutSection(space, "NewPageSpace");
|
1077
|
+
}
|
1078
|
+
|
1079
|
+
// Serialize the map (first word of the object).
|
1080
|
+
serializer_->SerializeObject(object_->map(), TAGGED_REPRESENTATION);
|
1081
|
+
|
1082
|
+
// Serialize the rest of the object.
|
1083
|
+
CHECK_EQ(0, bytes_processed_so_far_);
|
1084
|
+
bytes_processed_so_far_ = kPointerSize;
|
1085
|
+
object_->IterateBody(object_->map()->instance_type(), size, this);
|
1086
|
+
OutputRawData(object_->address() + size);
|
1087
|
+
}
|
1088
|
+
|
1089
|
+
|
1090
|
+
void Serializer::ObjectSerializer::VisitPointers(Object** start,
|
1091
|
+
Object** end) {
|
1092
|
+
Object** current = start;
|
1093
|
+
while (current < end) {
|
1094
|
+
while (current < end && (*current)->IsSmi()) current++;
|
1095
|
+
if (current < end) OutputRawData(reinterpret_cast<Address>(current));
|
1096
|
+
|
1097
|
+
while (current < end && !(*current)->IsSmi()) {
|
1098
|
+
serializer_->SerializeObject(*current, TAGGED_REPRESENTATION);
|
1099
|
+
bytes_processed_so_far_ += kPointerSize;
|
1100
|
+
current++;
|
1101
|
+
}
|
1102
|
+
}
|
1103
|
+
}
|
1104
|
+
|
1105
|
+
|
1106
|
+
void Serializer::ObjectSerializer::VisitExternalReferences(Address* start,
|
1107
|
+
Address* end) {
|
1108
|
+
Address references_start = reinterpret_cast<Address>(start);
|
1109
|
+
OutputRawData(references_start);
|
1110
|
+
|
1111
|
+
for (Address* current = start; current < end; current++) {
|
1112
|
+
sink_->Put(EXTERNAL_REFERENCE_SERIALIZATION, "ExternalReference");
|
1113
|
+
int reference_id = serializer_->EncodeExternalReference(*current);
|
1114
|
+
sink_->PutInt(reference_id, "reference id");
|
1115
|
+
}
|
1116
|
+
bytes_processed_so_far_ += static_cast<int>((end - start) * kPointerSize);
|
1117
|
+
}
|
1118
|
+
|
1119
|
+
|
1120
|
+
void Serializer::ObjectSerializer::VisitRuntimeEntry(RelocInfo* rinfo) {
|
1121
|
+
Address target_start = rinfo->target_address_address();
|
1122
|
+
OutputRawData(target_start);
|
1123
|
+
Address target = rinfo->target_address();
|
1124
|
+
uint32_t encoding = serializer_->EncodeExternalReference(target);
|
1125
|
+
CHECK(target == NULL ? encoding == 0 : encoding != 0);
|
1126
|
+
sink_->Put(EXTERNAL_BRANCH_TARGET_SERIALIZATION, "ExternalReference");
|
1127
|
+
sink_->PutInt(encoding, "reference id");
|
1128
|
+
bytes_processed_so_far_ += Assembler::kExternalTargetSize;
|
1129
|
+
}
|
1130
|
+
|
1131
|
+
|
1132
|
+
void Serializer::ObjectSerializer::VisitCodeTarget(RelocInfo* rinfo) {
|
1133
|
+
CHECK(RelocInfo::IsCodeTarget(rinfo->rmode()));
|
1134
|
+
Address target_start = rinfo->target_address_address();
|
1135
|
+
OutputRawData(target_start);
|
1136
|
+
Code* target = Code::GetCodeFromTargetAddress(rinfo->target_address());
|
1137
|
+
serializer_->SerializeObject(target, CODE_TARGET_REPRESENTATION);
|
1138
|
+
bytes_processed_so_far_ += Assembler::kCallTargetSize;
|
1139
|
+
}
|
1140
|
+
|
1141
|
+
|
1142
|
+
void Serializer::ObjectSerializer::VisitExternalAsciiString(
|
1143
|
+
v8::String::ExternalAsciiStringResource** resource_pointer) {
|
1144
|
+
Address references_start = reinterpret_cast<Address>(resource_pointer);
|
1145
|
+
OutputRawData(references_start);
|
1146
|
+
for (int i = 0; i < Natives::GetBuiltinsCount(); i++) {
|
1147
|
+
Object* source = Heap::natives_source_cache()->get(i);
|
1148
|
+
if (!source->IsUndefined()) {
|
1149
|
+
ExternalAsciiString* string = ExternalAsciiString::cast(source);
|
1150
|
+
typedef v8::String::ExternalAsciiStringResource Resource;
|
1151
|
+
Resource* resource = string->resource();
|
1152
|
+
if (resource == *resource_pointer) {
|
1153
|
+
sink_->Put(NATIVES_STRING_RESOURCE, "NativesStringResource");
|
1154
|
+
sink_->PutSection(i, "NativesStringResourceEnd");
|
1155
|
+
bytes_processed_so_far_ += sizeof(resource);
|
1156
|
+
return;
|
1157
|
+
}
|
1158
|
+
}
|
1159
|
+
}
|
1160
|
+
// One of the strings in the natives cache should match the resource. We
|
1161
|
+
// can't serialize any other kinds of external strings.
|
1162
|
+
UNREACHABLE();
|
1163
|
+
}
|
1164
|
+
|
1165
|
+
|
1166
|
+
void Serializer::ObjectSerializer::OutputRawData(Address up_to) {
|
1167
|
+
Address object_start = object_->address();
|
1168
|
+
int up_to_offset = static_cast<int>(up_to - object_start);
|
1169
|
+
int skipped = up_to_offset - bytes_processed_so_far_;
|
1170
|
+
// This assert will fail if the reloc info gives us the target_address_address
|
1171
|
+
// locations in a non-ascending order. Luckily that doesn't happen.
|
1172
|
+
ASSERT(skipped >= 0);
|
1173
|
+
if (skipped != 0) {
|
1174
|
+
Address base = object_start + bytes_processed_so_far_;
|
1175
|
+
#define RAW_CASE(index, length) \
|
1176
|
+
if (skipped == length) { \
|
1177
|
+
sink_->PutSection(RAW_DATA_SERIALIZATION + index, "RawDataFixed"); \
|
1178
|
+
} else /* NOLINT */
|
1179
|
+
COMMON_RAW_LENGTHS(RAW_CASE)
|
1180
|
+
#undef RAW_CASE
|
1181
|
+
{ /* NOLINT */
|
1182
|
+
sink_->Put(RAW_DATA_SERIALIZATION, "RawData");
|
1183
|
+
sink_->PutInt(skipped, "length");
|
1184
|
+
}
|
1185
|
+
for (int i = 0; i < skipped; i++) {
|
1186
|
+
unsigned int data = base[i];
|
1187
|
+
sink_->PutSection(data, "Byte");
|
1188
|
+
}
|
1189
|
+
bytes_processed_so_far_ += skipped;
|
1190
|
+
}
|
1191
|
+
}
|
1192
|
+
|
1193
|
+
|
1194
|
+
int Serializer::SpaceOfObject(HeapObject* object) {
|
1195
|
+
for (int i = FIRST_SPACE; i <= LAST_SPACE; i++) {
|
1196
|
+
AllocationSpace s = static_cast<AllocationSpace>(i);
|
1197
|
+
if (Heap::InSpace(object, s)) {
|
1198
|
+
if (i == LO_SPACE) {
|
1199
|
+
if (object->IsCode()) {
|
1200
|
+
return kLargeCode;
|
1201
|
+
} else if (object->IsFixedArray()) {
|
1202
|
+
return kLargeFixedArray;
|
1203
|
+
} else {
|
1204
|
+
return kLargeData;
|
1205
|
+
}
|
1206
|
+
}
|
1207
|
+
return i;
|
1208
|
+
}
|
1209
|
+
}
|
1210
|
+
UNREACHABLE();
|
1211
|
+
return 0;
|
1212
|
+
}
|
1213
|
+
|
1214
|
+
|
1215
|
+
int Serializer::SpaceOfAlreadySerializedObject(HeapObject* object) {
|
1216
|
+
for (int i = FIRST_SPACE; i <= LAST_SPACE; i++) {
|
1217
|
+
AllocationSpace s = static_cast<AllocationSpace>(i);
|
1218
|
+
if (Heap::InSpace(object, s)) {
|
1219
|
+
return i;
|
1220
|
+
}
|
1221
|
+
}
|
1222
|
+
UNREACHABLE();
|
1223
|
+
return 0;
|
1224
|
+
}
|
1225
|
+
|
1226
|
+
|
1227
|
+
int Serializer::Allocate(int space, int size, bool* new_page) {
|
1228
|
+
CHECK(space >= 0 && space < kNumberOfSpaces);
|
1229
|
+
if (SpaceIsLarge(space)) {
|
1230
|
+
// In large object space we merely number the objects instead of trying to
|
1231
|
+
// determine some sort of address.
|
1232
|
+
*new_page = true;
|
1233
|
+
return fullness_[LO_SPACE]++;
|
1234
|
+
}
|
1235
|
+
*new_page = false;
|
1236
|
+
if (fullness_[space] == 0) {
|
1237
|
+
*new_page = true;
|
1238
|
+
}
|
1239
|
+
if (SpaceIsPaged(space)) {
|
1240
|
+
// Paged spaces are a little special. We encode their addresses as if the
|
1241
|
+
// pages were all contiguous and each page were filled up in the range
|
1242
|
+
// 0 - Page::kObjectAreaSize. In practice the pages may not be contiguous
|
1243
|
+
// and allocation does not start at offset 0 in the page, but this scheme
|
1244
|
+
// means the deserializer can get the page number quickly by shifting the
|
1245
|
+
// serialized address.
|
1246
|
+
CHECK(IsPowerOf2(Page::kPageSize));
|
1247
|
+
int used_in_this_page = (fullness_[space] & (Page::kPageSize - 1));
|
1248
|
+
CHECK(size <= Page::kObjectAreaSize);
|
1249
|
+
if (used_in_this_page + size > Page::kObjectAreaSize) {
|
1250
|
+
*new_page = true;
|
1251
|
+
fullness_[space] = RoundUp(fullness_[space], Page::kPageSize);
|
1252
|
+
}
|
1253
|
+
}
|
1254
|
+
int allocation_address = fullness_[space];
|
1255
|
+
fullness_[space] = allocation_address + size;
|
1256
|
+
return allocation_address;
|
1257
|
+
}
|
1258
|
+
|
1259
|
+
|
1260
|
+
} } // namespace v8::internal
|