mustang 0.0.1 → 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.rspec +1 -0
- data/Isolate +9 -0
- data/README.md +6 -12
- data/Rakefile +30 -4
- data/TODO.md +9 -0
- data/ext/v8/extconf.rb +56 -0
- data/ext/v8/v8.cpp +37 -0
- data/ext/v8/v8_array.cpp +161 -0
- data/ext/v8/v8_array.h +17 -0
- data/ext/v8/v8_base.cpp +147 -0
- data/ext/v8/v8_base.h +23 -0
- data/ext/v8/v8_cast.cpp +151 -0
- data/ext/v8/v8_cast.h +64 -0
- data/ext/v8/v8_context.cpp +174 -0
- data/ext/v8/v8_context.h +12 -0
- data/ext/v8/v8_date.cpp +61 -0
- data/ext/v8/v8_date.h +16 -0
- data/ext/v8/v8_errors.cpp +147 -0
- data/ext/v8/v8_errors.h +19 -0
- data/ext/v8/v8_external.cpp +66 -0
- data/ext/v8/v8_external.h +16 -0
- data/ext/v8/v8_function.cpp +182 -0
- data/ext/v8/v8_function.h +14 -0
- data/ext/v8/v8_integer.cpp +70 -0
- data/ext/v8/v8_integer.h +16 -0
- data/ext/v8/v8_macros.h +30 -0
- data/ext/v8/v8_main.cpp +53 -0
- data/ext/v8/v8_main.h +13 -0
- data/ext/v8/v8_number.cpp +62 -0
- data/ext/v8/v8_number.h +16 -0
- data/ext/v8/v8_object.cpp +172 -0
- data/ext/v8/v8_object.h +17 -0
- data/ext/v8/v8_ref.cpp +72 -0
- data/ext/v8/v8_ref.h +43 -0
- data/ext/v8/v8_regexp.cpp +148 -0
- data/ext/v8/v8_regexp.h +16 -0
- data/ext/v8/v8_string.cpp +78 -0
- data/ext/v8/v8_string.h +16 -0
- data/ext/v8/v8_value.cpp +370 -0
- data/ext/v8/v8_value.h +19 -0
- data/gemspec.yml +2 -1
- data/lib/core_ext/class.rb +14 -0
- data/lib/core_ext/object.rb +12 -0
- data/lib/core_ext/symbol.rb +23 -0
- data/lib/mustang.rb +44 -0
- data/lib/mustang/context.rb +69 -0
- data/lib/mustang/errors.rb +36 -0
- data/lib/support/delegated.rb +25 -0
- data/lib/v8/array.rb +21 -0
- data/lib/v8/context.rb +13 -0
- data/lib/v8/date.rb +20 -0
- data/lib/v8/error.rb +15 -0
- data/lib/v8/external.rb +16 -0
- data/lib/v8/function.rb +11 -0
- data/lib/v8/integer.rb +16 -0
- data/lib/v8/number.rb +16 -0
- data/lib/v8/object.rb +66 -0
- data/lib/v8/regexp.rb +23 -0
- data/lib/v8/string.rb +27 -0
- data/mustang.gemspec +3 -0
- data/spec/core_ext/class_spec.rb +19 -0
- data/spec/core_ext/object_spec.rb +19 -0
- data/spec/core_ext/symbol_spec.rb +27 -0
- data/spec/fixtures/test1.js +2 -0
- data/spec/fixtures/test2.js +2 -0
- data/spec/spec_helper.rb +20 -0
- data/spec/v8/array_spec.rb +88 -0
- data/spec/v8/cast_spec.rb +151 -0
- data/spec/v8/context_spec.rb +78 -0
- data/spec/v8/data_spec.rb +39 -0
- data/spec/v8/date_spec.rb +45 -0
- data/spec/v8/empty_spec.rb +27 -0
- data/spec/v8/errors_spec.rb +142 -0
- data/spec/v8/external_spec.rb +44 -0
- data/spec/v8/function_spec.rb +170 -0
- data/spec/v8/integer_spec.rb +41 -0
- data/spec/v8/main_spec.rb +18 -0
- data/spec/v8/null_spec.rb +27 -0
- data/spec/v8/number_spec.rb +40 -0
- data/spec/v8/object_spec.rb +79 -0
- data/spec/v8/primitive_spec.rb +9 -0
- data/spec/v8/regexp_spec.rb +65 -0
- data/spec/v8/string_spec.rb +48 -0
- data/spec/v8/undefined_spec.rb +27 -0
- data/spec/v8/value_spec.rb +215 -0
- data/vendor/v8/.gitignore +2 -0
- data/vendor/v8/AUTHORS +3 -1
- data/vendor/v8/ChangeLog +117 -0
- data/vendor/v8/SConstruct +334 -53
- data/vendor/v8/include/v8-debug.h +21 -11
- data/vendor/v8/include/v8-preparser.h +1 -1
- data/vendor/v8/include/v8-profiler.h +122 -43
- data/vendor/v8/include/v8-testing.h +5 -0
- data/vendor/v8/include/v8.h +171 -17
- data/vendor/v8/preparser/SConscript +38 -0
- data/vendor/v8/preparser/preparser-process.cc +77 -114
- data/vendor/v8/samples/shell.cc +232 -46
- data/vendor/v8/src/SConscript +29 -5
- data/vendor/v8/src/accessors.cc +70 -211
- data/vendor/v8/{test/cctest/test-mips.cc → src/allocation-inl.h} +15 -18
- data/vendor/v8/src/allocation.cc +0 -82
- data/vendor/v8/src/allocation.h +9 -42
- data/vendor/v8/src/api.cc +1645 -1156
- data/vendor/v8/src/api.h +76 -12
- data/vendor/v8/src/apiutils.h +0 -7
- data/vendor/v8/src/arguments.h +15 -4
- data/vendor/v8/src/arm/assembler-arm-inl.h +10 -9
- data/vendor/v8/src/arm/assembler-arm.cc +62 -23
- data/vendor/v8/src/arm/assembler-arm.h +76 -11
- data/vendor/v8/src/arm/builtins-arm.cc +39 -33
- data/vendor/v8/src/arm/code-stubs-arm.cc +1182 -402
- data/vendor/v8/src/arm/code-stubs-arm.h +20 -54
- data/vendor/v8/src/arm/codegen-arm.cc +159 -106
- data/vendor/v8/src/arm/codegen-arm.h +6 -6
- data/vendor/v8/src/arm/constants-arm.h +16 -1
- data/vendor/v8/src/arm/cpu-arm.cc +7 -5
- data/vendor/v8/src/arm/debug-arm.cc +6 -4
- data/vendor/v8/src/arm/deoptimizer-arm.cc +51 -14
- data/vendor/v8/src/arm/disasm-arm.cc +47 -15
- data/vendor/v8/src/arm/frames-arm.h +1 -1
- data/vendor/v8/src/arm/full-codegen-arm.cc +724 -408
- data/vendor/v8/src/arm/ic-arm.cc +90 -85
- data/vendor/v8/src/arm/lithium-arm.cc +140 -69
- data/vendor/v8/src/arm/lithium-arm.h +161 -46
- data/vendor/v8/src/arm/lithium-codegen-arm.cc +567 -297
- data/vendor/v8/src/arm/lithium-codegen-arm.h +21 -9
- data/vendor/v8/src/arm/lithium-gap-resolver-arm.cc +2 -0
- data/vendor/v8/src/arm/macro-assembler-arm.cc +457 -96
- data/vendor/v8/src/arm/macro-assembler-arm.h +115 -18
- data/vendor/v8/src/arm/regexp-macro-assembler-arm.cc +20 -13
- data/vendor/v8/src/arm/regexp-macro-assembler-arm.h +1 -0
- data/vendor/v8/src/arm/simulator-arm.cc +184 -101
- data/vendor/v8/src/arm/simulator-arm.h +26 -21
- data/vendor/v8/src/arm/stub-cache-arm.cc +450 -467
- data/vendor/v8/src/arm/virtual-frame-arm.cc +14 -12
- data/vendor/v8/src/arm/virtual-frame-arm.h +11 -8
- data/vendor/v8/src/array.js +35 -18
- data/vendor/v8/src/assembler.cc +186 -92
- data/vendor/v8/src/assembler.h +106 -69
- data/vendor/v8/src/ast-inl.h +5 -0
- data/vendor/v8/src/ast.cc +46 -35
- data/vendor/v8/src/ast.h +107 -50
- data/vendor/v8/src/atomicops.h +2 -0
- data/vendor/v8/src/atomicops_internals_mips_gcc.h +169 -0
- data/vendor/v8/src/bootstrapper.cc +649 -399
- data/vendor/v8/src/bootstrapper.h +94 -27
- data/vendor/v8/src/builtins.cc +359 -227
- data/vendor/v8/src/builtins.h +157 -123
- data/vendor/v8/src/checks.cc +2 -2
- data/vendor/v8/src/checks.h +4 -0
- data/vendor/v8/src/code-stubs.cc +27 -17
- data/vendor/v8/src/code-stubs.h +38 -17
- data/vendor/v8/src/codegen-inl.h +5 -1
- data/vendor/v8/src/codegen.cc +27 -17
- data/vendor/v8/src/codegen.h +9 -9
- data/vendor/v8/src/compilation-cache.cc +92 -206
- data/vendor/v8/src/compilation-cache.h +205 -30
- data/vendor/v8/src/compiler.cc +107 -120
- data/vendor/v8/src/compiler.h +17 -2
- data/vendor/v8/src/contexts.cc +22 -15
- data/vendor/v8/src/contexts.h +14 -8
- data/vendor/v8/src/conversions.cc +86 -30
- data/vendor/v8/src/counters.cc +19 -4
- data/vendor/v8/src/counters.h +28 -16
- data/vendor/v8/src/cpu-profiler-inl.h +4 -3
- data/vendor/v8/src/cpu-profiler.cc +123 -72
- data/vendor/v8/src/cpu-profiler.h +33 -19
- data/vendor/v8/src/cpu.h +2 -0
- data/vendor/v8/src/d8-debug.cc +3 -3
- data/vendor/v8/src/d8-debug.h +7 -6
- data/vendor/v8/src/d8-posix.cc +2 -0
- data/vendor/v8/src/d8.cc +22 -12
- data/vendor/v8/src/d8.gyp +3 -0
- data/vendor/v8/src/d8.js +618 -0
- data/vendor/v8/src/data-flow.h +3 -3
- data/vendor/v8/src/dateparser.h +4 -2
- data/vendor/v8/src/debug-agent.cc +10 -9
- data/vendor/v8/src/debug-agent.h +9 -11
- data/vendor/v8/src/debug-debugger.js +121 -0
- data/vendor/v8/src/debug.cc +331 -227
- data/vendor/v8/src/debug.h +248 -219
- data/vendor/v8/src/deoptimizer.cc +173 -62
- data/vendor/v8/src/deoptimizer.h +119 -19
- data/vendor/v8/src/disasm.h +3 -0
- data/vendor/v8/src/disassembler.cc +10 -9
- data/vendor/v8/src/execution.cc +185 -129
- data/vendor/v8/src/execution.h +47 -78
- data/vendor/v8/src/extensions/experimental/break-iterator.cc +250 -0
- data/vendor/v8/src/extensions/experimental/break-iterator.h +89 -0
- data/vendor/v8/src/extensions/experimental/experimental.gyp +2 -0
- data/vendor/v8/src/extensions/experimental/i18n-extension.cc +22 -2
- data/vendor/v8/src/extensions/externalize-string-extension.cc +2 -2
- data/vendor/v8/src/extensions/gc-extension.cc +1 -1
- data/vendor/v8/src/factory.cc +261 -154
- data/vendor/v8/src/factory.h +162 -158
- data/vendor/v8/src/flag-definitions.h +17 -11
- data/vendor/v8/src/frame-element.cc +0 -5
- data/vendor/v8/src/frame-element.h +9 -13
- data/vendor/v8/src/frames-inl.h +7 -0
- data/vendor/v8/src/frames.cc +56 -46
- data/vendor/v8/src/frames.h +36 -25
- data/vendor/v8/src/full-codegen.cc +15 -24
- data/vendor/v8/src/full-codegen.h +13 -41
- data/vendor/v8/src/func-name-inferrer.cc +7 -6
- data/vendor/v8/src/func-name-inferrer.h +1 -1
- data/vendor/v8/src/gdb-jit.cc +1 -0
- data/vendor/v8/src/global-handles.cc +118 -56
- data/vendor/v8/src/global-handles.h +98 -40
- data/vendor/v8/src/globals.h +2 -2
- data/vendor/v8/src/handles-inl.h +106 -9
- data/vendor/v8/src/handles.cc +220 -157
- data/vendor/v8/src/handles.h +38 -59
- data/vendor/v8/src/hashmap.h +3 -3
- data/vendor/v8/src/heap-inl.h +141 -25
- data/vendor/v8/src/heap-profiler.cc +117 -63
- data/vendor/v8/src/heap-profiler.h +38 -21
- data/vendor/v8/src/heap.cc +805 -564
- data/vendor/v8/src/heap.h +640 -594
- data/vendor/v8/src/hydrogen-instructions.cc +216 -73
- data/vendor/v8/src/hydrogen-instructions.h +259 -124
- data/vendor/v8/src/hydrogen.cc +996 -1171
- data/vendor/v8/src/hydrogen.h +163 -144
- data/vendor/v8/src/ia32/assembler-ia32-inl.h +12 -11
- data/vendor/v8/src/ia32/assembler-ia32.cc +85 -39
- data/vendor/v8/src/ia32/assembler-ia32.h +82 -16
- data/vendor/v8/src/ia32/builtins-ia32.cc +64 -58
- data/vendor/v8/src/ia32/code-stubs-ia32.cc +248 -324
- data/vendor/v8/src/ia32/code-stubs-ia32.h +3 -44
- data/vendor/v8/src/ia32/codegen-ia32.cc +217 -165
- data/vendor/v8/src/ia32/codegen-ia32.h +3 -0
- data/vendor/v8/src/ia32/cpu-ia32.cc +6 -5
- data/vendor/v8/src/ia32/debug-ia32.cc +8 -5
- data/vendor/v8/src/ia32/deoptimizer-ia32.cc +124 -14
- data/vendor/v8/src/ia32/disasm-ia32.cc +85 -62
- data/vendor/v8/src/ia32/frames-ia32.h +1 -1
- data/vendor/v8/src/ia32/full-codegen-ia32.cc +348 -435
- data/vendor/v8/src/ia32/ic-ia32.cc +91 -91
- data/vendor/v8/src/ia32/lithium-codegen-ia32.cc +500 -255
- data/vendor/v8/src/ia32/lithium-codegen-ia32.h +13 -4
- data/vendor/v8/src/ia32/lithium-gap-resolver-ia32.cc +6 -0
- data/vendor/v8/src/ia32/lithium-ia32.cc +122 -45
- data/vendor/v8/src/ia32/lithium-ia32.h +128 -41
- data/vendor/v8/src/ia32/macro-assembler-ia32.cc +109 -84
- data/vendor/v8/src/ia32/macro-assembler-ia32.h +18 -9
- data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.cc +26 -15
- data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.h +1 -0
- data/vendor/v8/src/ia32/register-allocator-ia32.cc +30 -30
- data/vendor/v8/src/ia32/simulator-ia32.h +4 -4
- data/vendor/v8/src/ia32/stub-cache-ia32.cc +383 -400
- data/vendor/v8/src/ia32/virtual-frame-ia32.cc +36 -13
- data/vendor/v8/src/ia32/virtual-frame-ia32.h +11 -5
- data/vendor/v8/src/ic-inl.h +12 -2
- data/vendor/v8/src/ic.cc +304 -221
- data/vendor/v8/src/ic.h +115 -58
- data/vendor/v8/src/interpreter-irregexp.cc +25 -21
- data/vendor/v8/src/interpreter-irregexp.h +2 -1
- data/vendor/v8/src/isolate.cc +883 -0
- data/vendor/v8/src/isolate.h +1304 -0
- data/vendor/v8/src/json.js +10 -10
- data/vendor/v8/src/jsregexp.cc +111 -80
- data/vendor/v8/src/jsregexp.h +6 -7
- data/vendor/v8/src/jump-target-heavy.cc +5 -8
- data/vendor/v8/src/jump-target-heavy.h +0 -6
- data/vendor/v8/src/jump-target-inl.h +1 -1
- data/vendor/v8/src/jump-target-light.cc +3 -3
- data/vendor/v8/src/lithium-allocator-inl.h +2 -0
- data/vendor/v8/src/lithium-allocator.cc +42 -30
- data/vendor/v8/src/lithium-allocator.h +8 -22
- data/vendor/v8/src/lithium.cc +1 -0
- data/vendor/v8/src/liveedit.cc +141 -99
- data/vendor/v8/src/liveedit.h +7 -2
- data/vendor/v8/src/liveobjectlist-inl.h +90 -0
- data/vendor/v8/src/liveobjectlist.cc +2537 -1
- data/vendor/v8/src/liveobjectlist.h +245 -35
- data/vendor/v8/src/log-utils.cc +122 -35
- data/vendor/v8/src/log-utils.h +33 -36
- data/vendor/v8/src/log.cc +299 -241
- data/vendor/v8/src/log.h +177 -110
- data/vendor/v8/src/mark-compact.cc +612 -470
- data/vendor/v8/src/mark-compact.h +153 -80
- data/vendor/v8/src/messages.cc +16 -14
- data/vendor/v8/src/messages.js +30 -7
- data/vendor/v8/src/mips/assembler-mips-inl.h +155 -35
- data/vendor/v8/src/mips/assembler-mips.cc +1093 -219
- data/vendor/v8/src/mips/assembler-mips.h +552 -153
- data/vendor/v8/src/mips/builtins-mips.cc +43 -100
- data/vendor/v8/src/mips/code-stubs-mips.cc +752 -0
- data/vendor/v8/src/mips/code-stubs-mips.h +511 -0
- data/vendor/v8/src/mips/codegen-mips-inl.h +8 -14
- data/vendor/v8/src/mips/codegen-mips.cc +672 -896
- data/vendor/v8/src/mips/codegen-mips.h +271 -69
- data/vendor/v8/src/mips/constants-mips.cc +44 -20
- data/vendor/v8/src/mips/constants-mips.h +238 -40
- data/vendor/v8/src/mips/cpu-mips.cc +20 -3
- data/vendor/v8/src/mips/debug-mips.cc +35 -7
- data/vendor/v8/src/mips/deoptimizer-mips.cc +91 -0
- data/vendor/v8/src/mips/disasm-mips.cc +329 -93
- data/vendor/v8/src/mips/frames-mips.cc +2 -50
- data/vendor/v8/src/mips/frames-mips.h +24 -9
- data/vendor/v8/src/mips/full-codegen-mips.cc +473 -23
- data/vendor/v8/src/mips/ic-mips.cc +81 -45
- data/vendor/v8/src/mips/jump-target-mips.cc +11 -106
- data/vendor/v8/src/mips/lithium-codegen-mips.h +65 -0
- data/vendor/v8/src/mips/lithium-mips.h +304 -0
- data/vendor/v8/src/mips/macro-assembler-mips.cc +2391 -390
- data/vendor/v8/src/mips/macro-assembler-mips.h +718 -121
- data/vendor/v8/src/mips/regexp-macro-assembler-mips.cc +478 -0
- data/vendor/v8/src/mips/regexp-macro-assembler-mips.h +250 -0
- data/vendor/v8/src/mips/register-allocator-mips-inl.h +0 -3
- data/vendor/v8/src/mips/register-allocator-mips.h +3 -2
- data/vendor/v8/src/mips/simulator-mips.cc +1009 -221
- data/vendor/v8/src/mips/simulator-mips.h +119 -36
- data/vendor/v8/src/mips/stub-cache-mips.cc +331 -148
- data/vendor/v8/src/mips/{fast-codegen-mips.cc → virtual-frame-mips-inl.h} +11 -30
- data/vendor/v8/src/mips/virtual-frame-mips.cc +137 -149
- data/vendor/v8/src/mips/virtual-frame-mips.h +294 -312
- data/vendor/v8/src/mirror-debugger.js +9 -8
- data/vendor/v8/src/mksnapshot.cc +2 -2
- data/vendor/v8/src/objects-debug.cc +16 -16
- data/vendor/v8/src/objects-inl.h +421 -195
- data/vendor/v8/src/objects-printer.cc +7 -7
- data/vendor/v8/src/objects-visiting.cc +1 -1
- data/vendor/v8/src/objects-visiting.h +33 -12
- data/vendor/v8/src/objects.cc +935 -658
- data/vendor/v8/src/objects.h +234 -139
- data/vendor/v8/src/parser.cc +484 -439
- data/vendor/v8/src/parser.h +35 -14
- data/vendor/v8/src/platform-cygwin.cc +173 -107
- data/vendor/v8/src/platform-freebsd.cc +224 -72
- data/vendor/v8/src/platform-linux.cc +234 -95
- data/vendor/v8/src/platform-macos.cc +215 -82
- data/vendor/v8/src/platform-nullos.cc +9 -3
- data/vendor/v8/src/platform-openbsd.cc +22 -7
- data/vendor/v8/src/platform-posix.cc +30 -5
- data/vendor/v8/src/platform-solaris.cc +120 -38
- data/vendor/v8/src/platform-tls-mac.h +62 -0
- data/vendor/v8/src/platform-tls-win32.h +62 -0
- data/vendor/v8/src/platform-tls.h +50 -0
- data/vendor/v8/src/platform-win32.cc +195 -97
- data/vendor/v8/src/platform.h +72 -15
- data/vendor/v8/src/preparse-data.cc +2 -0
- data/vendor/v8/src/preparser-api.cc +8 -2
- data/vendor/v8/src/preparser.cc +1 -1
- data/vendor/v8/src/prettyprinter.cc +43 -52
- data/vendor/v8/src/prettyprinter.h +1 -1
- data/vendor/v8/src/profile-generator-inl.h +0 -28
- data/vendor/v8/src/profile-generator.cc +942 -685
- data/vendor/v8/src/profile-generator.h +210 -176
- data/vendor/v8/src/property.cc +6 -0
- data/vendor/v8/src/property.h +14 -3
- data/vendor/v8/src/regexp-macro-assembler-irregexp.cc +1 -1
- data/vendor/v8/src/regexp-macro-assembler.cc +28 -19
- data/vendor/v8/src/regexp-macro-assembler.h +11 -6
- data/vendor/v8/src/regexp-stack.cc +18 -10
- data/vendor/v8/src/regexp-stack.h +45 -21
- data/vendor/v8/src/regexp.js +3 -3
- data/vendor/v8/src/register-allocator-inl.h +3 -3
- data/vendor/v8/src/register-allocator.cc +1 -7
- data/vendor/v8/src/register-allocator.h +5 -15
- data/vendor/v8/src/rewriter.cc +2 -1
- data/vendor/v8/src/runtime-profiler.cc +158 -128
- data/vendor/v8/src/runtime-profiler.h +131 -15
- data/vendor/v8/src/runtime.cc +2409 -1692
- data/vendor/v8/src/runtime.h +93 -17
- data/vendor/v8/src/safepoint-table.cc +3 -0
- data/vendor/v8/src/safepoint-table.h +9 -3
- data/vendor/v8/src/scanner-base.cc +21 -28
- data/vendor/v8/src/scanner-base.h +22 -11
- data/vendor/v8/src/scanner.cc +3 -5
- data/vendor/v8/src/scanner.h +4 -2
- data/vendor/v8/src/scopeinfo.cc +11 -16
- data/vendor/v8/src/scopeinfo.h +26 -15
- data/vendor/v8/src/scopes.cc +67 -37
- data/vendor/v8/src/scopes.h +26 -12
- data/vendor/v8/src/serialize.cc +193 -154
- data/vendor/v8/src/serialize.h +41 -36
- data/vendor/v8/src/small-pointer-list.h +163 -0
- data/vendor/v8/src/snapshot-common.cc +1 -1
- data/vendor/v8/src/snapshot.h +3 -1
- data/vendor/v8/src/spaces-inl.h +30 -25
- data/vendor/v8/src/spaces.cc +263 -370
- data/vendor/v8/src/spaces.h +178 -166
- data/vendor/v8/src/string-search.cc +4 -3
- data/vendor/v8/src/string-search.h +21 -20
- data/vendor/v8/src/string-stream.cc +32 -24
- data/vendor/v8/src/string.js +7 -7
- data/vendor/v8/src/stub-cache.cc +324 -248
- data/vendor/v8/src/stub-cache.h +181 -155
- data/vendor/v8/src/token.cc +3 -3
- data/vendor/v8/src/token.h +3 -3
- data/vendor/v8/src/top.cc +218 -390
- data/vendor/v8/src/type-info.cc +98 -32
- data/vendor/v8/src/type-info.h +10 -3
- data/vendor/v8/src/unicode.cc +1 -1
- data/vendor/v8/src/unicode.h +1 -1
- data/vendor/v8/src/utils.h +3 -0
- data/vendor/v8/src/v8-counters.cc +18 -11
- data/vendor/v8/src/v8-counters.h +34 -13
- data/vendor/v8/src/v8.cc +66 -121
- data/vendor/v8/src/v8.h +7 -4
- data/vendor/v8/src/v8globals.h +18 -12
- data/vendor/v8/src/{memory.h → v8memory.h} +0 -0
- data/vendor/v8/src/v8natives.js +59 -18
- data/vendor/v8/src/v8threads.cc +127 -114
- data/vendor/v8/src/v8threads.h +42 -35
- data/vendor/v8/src/v8utils.h +2 -39
- data/vendor/v8/src/variables.h +1 -1
- data/vendor/v8/src/version.cc +26 -5
- data/vendor/v8/src/version.h +4 -0
- data/vendor/v8/src/virtual-frame-heavy-inl.h +2 -4
- data/vendor/v8/src/virtual-frame-light-inl.h +5 -4
- data/vendor/v8/src/vm-state-inl.h +21 -17
- data/vendor/v8/src/vm-state.h +7 -5
- data/vendor/v8/src/win32-headers.h +1 -0
- data/vendor/v8/src/x64/assembler-x64-inl.h +12 -11
- data/vendor/v8/src/x64/assembler-x64.cc +80 -40
- data/vendor/v8/src/x64/assembler-x64.h +67 -17
- data/vendor/v8/src/x64/builtins-x64.cc +34 -33
- data/vendor/v8/src/x64/code-stubs-x64.cc +636 -377
- data/vendor/v8/src/x64/code-stubs-x64.h +14 -48
- data/vendor/v8/src/x64/codegen-x64-inl.h +1 -1
- data/vendor/v8/src/x64/codegen-x64.cc +158 -136
- data/vendor/v8/src/x64/codegen-x64.h +4 -1
- data/vendor/v8/src/x64/cpu-x64.cc +7 -5
- data/vendor/v8/src/x64/debug-x64.cc +8 -6
- data/vendor/v8/src/x64/deoptimizer-x64.cc +195 -20
- data/vendor/v8/src/x64/disasm-x64.cc +42 -23
- data/vendor/v8/src/x64/frames-x64.cc +1 -1
- data/vendor/v8/src/x64/frames-x64.h +2 -2
- data/vendor/v8/src/x64/full-codegen-x64.cc +780 -218
- data/vendor/v8/src/x64/ic-x64.cc +77 -79
- data/vendor/v8/src/x64/jump-target-x64.cc +1 -1
- data/vendor/v8/src/x64/lithium-codegen-x64.cc +698 -181
- data/vendor/v8/src/x64/lithium-codegen-x64.h +31 -6
- data/vendor/v8/src/x64/lithium-x64.cc +136 -54
- data/vendor/v8/src/x64/lithium-x64.h +142 -51
- data/vendor/v8/src/x64/macro-assembler-x64.cc +456 -187
- data/vendor/v8/src/x64/macro-assembler-x64.h +166 -34
- data/vendor/v8/src/x64/regexp-macro-assembler-x64.cc +44 -28
- data/vendor/v8/src/x64/regexp-macro-assembler-x64.h +8 -4
- data/vendor/v8/src/x64/register-allocator-x64-inl.h +3 -3
- data/vendor/v8/src/x64/register-allocator-x64.cc +12 -8
- data/vendor/v8/src/x64/simulator-x64.h +5 -5
- data/vendor/v8/src/x64/stub-cache-x64.cc +299 -344
- data/vendor/v8/src/x64/virtual-frame-x64.cc +37 -13
- data/vendor/v8/src/x64/virtual-frame-x64.h +13 -7
- data/vendor/v8/src/zone-inl.h +49 -3
- data/vendor/v8/src/zone.cc +42 -41
- data/vendor/v8/src/zone.h +37 -34
- data/vendor/v8/test/benchmarks/testcfg.py +100 -0
- data/vendor/v8/test/cctest/SConscript +5 -4
- data/vendor/v8/test/cctest/cctest.h +3 -2
- data/vendor/v8/test/cctest/cctest.status +6 -11
- data/vendor/v8/test/cctest/test-accessors.cc +3 -3
- data/vendor/v8/test/cctest/test-alloc.cc +39 -33
- data/vendor/v8/test/cctest/test-api.cc +1092 -205
- data/vendor/v8/test/cctest/test-assembler-arm.cc +39 -25
- data/vendor/v8/test/cctest/test-assembler-ia32.cc +36 -37
- data/vendor/v8/test/cctest/test-assembler-mips.cc +1098 -40
- data/vendor/v8/test/cctest/test-assembler-x64.cc +32 -25
- data/vendor/v8/test/cctest/test-ast.cc +1 -0
- data/vendor/v8/test/cctest/test-circular-queue.cc +8 -5
- data/vendor/v8/test/cctest/test-compiler.cc +24 -24
- data/vendor/v8/test/cctest/test-cpu-profiler.cc +140 -5
- data/vendor/v8/test/cctest/test-dataflow.cc +1 -0
- data/vendor/v8/test/cctest/test-debug.cc +136 -77
- data/vendor/v8/test/cctest/test-decls.cc +1 -1
- data/vendor/v8/test/cctest/test-deoptimization.cc +25 -24
- data/vendor/v8/test/cctest/test-disasm-arm.cc +9 -4
- data/vendor/v8/test/cctest/test-disasm-ia32.cc +10 -8
- data/vendor/v8/test/cctest/test-func-name-inference.cc +10 -4
- data/vendor/v8/test/cctest/test-heap-profiler.cc +226 -164
- data/vendor/v8/test/cctest/test-heap.cc +240 -217
- data/vendor/v8/test/cctest/test-liveedit.cc +1 -0
- data/vendor/v8/test/cctest/test-log-stack-tracer.cc +18 -20
- data/vendor/v8/test/cctest/test-log.cc +114 -108
- data/vendor/v8/test/cctest/test-macro-assembler-x64.cc +247 -177
- data/vendor/v8/test/cctest/test-mark-compact.cc +129 -90
- data/vendor/v8/test/cctest/test-parsing.cc +15 -14
- data/vendor/v8/test/cctest/test-platform-linux.cc +1 -0
- data/vendor/v8/test/cctest/test-platform-tls.cc +66 -0
- data/vendor/v8/test/cctest/test-platform-win32.cc +1 -0
- data/vendor/v8/test/cctest/test-profile-generator.cc +1 -1
- data/vendor/v8/test/cctest/test-regexp.cc +53 -41
- data/vendor/v8/test/cctest/test-reloc-info.cc +18 -11
- data/vendor/v8/test/cctest/test-serialize.cc +44 -43
- data/vendor/v8/test/cctest/test-sockets.cc +8 -3
- data/vendor/v8/test/cctest/test-spaces.cc +47 -29
- data/vendor/v8/test/cctest/test-strings.cc +20 -20
- data/vendor/v8/test/cctest/test-thread-termination.cc +8 -3
- data/vendor/v8/test/cctest/test-threads.cc +5 -3
- data/vendor/v8/test/cctest/test-utils.cc +5 -4
- data/vendor/v8/test/cctest/testcfg.py +7 -3
- data/vendor/v8/test/es5conform/es5conform.status +2 -77
- data/vendor/v8/test/es5conform/testcfg.py +1 -1
- data/vendor/v8/test/message/testcfg.py +1 -1
- data/vendor/v8/test/mjsunit/accessors-on-global-object.js +3 -3
- data/vendor/v8/test/mjsunit/array-concat.js +43 -1
- data/vendor/v8/test/mjsunit/array-join.js +25 -0
- data/vendor/v8/test/mjsunit/bitops-info.js +7 -1
- data/vendor/v8/test/mjsunit/compiler/array-length.js +2 -2
- data/vendor/v8/test/mjsunit/compiler/global-accessors.js +47 -0
- data/vendor/v8/test/mjsunit/compiler/pic.js +1 -1
- data/vendor/v8/test/mjsunit/compiler/regress-loadfield.js +65 -0
- data/vendor/v8/test/mjsunit/math-sqrt.js +5 -1
- data/vendor/v8/test/mjsunit/mjsunit.js +59 -8
- data/vendor/v8/test/mjsunit/mjsunit.status +0 -12
- data/vendor/v8/test/mjsunit/mul-exhaustive.js +129 -11
- data/vendor/v8/test/mjsunit/negate-zero.js +1 -1
- data/vendor/v8/test/mjsunit/object-freeze.js +5 -13
- data/vendor/v8/test/mjsunit/object-prevent-extensions.js +9 -50
- data/vendor/v8/test/mjsunit/object-seal.js +4 -13
- data/vendor/v8/test/mjsunit/override-eval-with-non-function.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-1145.js +54 -0
- data/vendor/v8/test/mjsunit/regress/regress-1172-bis.js +37 -0
- data/vendor/v8/test/mjsunit/regress/regress-1181.js +54 -0
- data/vendor/v8/test/mjsunit/regress/regress-1207.js +35 -0
- data/vendor/v8/test/mjsunit/regress/regress-1209.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-1210.js +48 -0
- data/vendor/v8/test/mjsunit/regress/regress-1213.js +43 -0
- data/vendor/v8/test/mjsunit/regress/regress-1218.js +29 -0
- data/vendor/v8/test/mjsunit/regress/regress-1229.js +79 -0
- data/vendor/v8/test/mjsunit/regress/regress-1233.js +47 -0
- data/vendor/v8/test/mjsunit/regress/regress-1236.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-1237.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-1240.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-1257.js +58 -0
- data/vendor/v8/test/mjsunit/regress/regress-1278.js +69 -0
- data/vendor/v8/test/mjsunit/regress/regress-create-exception.js +1 -0
- data/vendor/v8/test/mjsunit/regress/regress-lazy-deopt-reloc.js +52 -0
- data/vendor/v8/test/mjsunit/sin-cos.js +15 -10
- data/vendor/v8/test/mjsunit/smi-negative-zero.js +2 -2
- data/vendor/v8/test/mjsunit/str-to-num.js +1 -1
- data/vendor/v8/test/mjsunit/strict-mode.js +435 -0
- data/vendor/v8/test/mjsunit/testcfg.py +23 -6
- data/vendor/v8/test/mozilla/mozilla.status +0 -2
- data/vendor/v8/test/mozilla/testcfg.py +1 -1
- data/vendor/v8/test/preparser/empty.js +28 -0
- data/vendor/v8/test/preparser/functions-only.js +38 -0
- data/vendor/v8/test/preparser/non-alphanum.js +34 -0
- data/vendor/v8/test/preparser/symbols-only.js +49 -0
- data/vendor/v8/test/preparser/testcfg.py +90 -0
- data/vendor/v8/test/sputnik/testcfg.py +1 -1
- data/vendor/v8/test/test262/README +16 -0
- data/vendor/v8/test/test262/harness-adapt.js +80 -0
- data/vendor/v8/test/test262/test262.status +1506 -0
- data/vendor/v8/test/test262/testcfg.py +123 -0
- data/vendor/v8/tools/freebsd-tick-processor +10 -0
- data/vendor/v8/tools/gyp/v8.gyp +8 -33
- data/vendor/v8/tools/linux-tick-processor +5 -3
- data/vendor/v8/tools/test.py +37 -14
- data/vendor/v8/tools/tickprocessor.js +22 -8
- data/vendor/v8/tools/visual_studio/v8_base.vcproj +13 -1
- data/vendor/v8/tools/visual_studio/v8_base_arm.vcproj +5 -1
- data/vendor/v8/tools/visual_studio/v8_base_x64.vcproj +5 -1
- data/vendor/v8/tools/visual_studio/x64.vsprops +1 -0
- metadata +1495 -1341
- data/ext/extconf.rb +0 -22
- data/ext/mustang.cpp +0 -58
- data/vendor/v8/src/top.h +0 -608
data/vendor/v8/src/scanner.cc
CHANGED
@@ -328,8 +328,6 @@ void Scanner::LiteralScope::Complete() {
|
|
328
328
|
// ----------------------------------------------------------------------------
|
329
329
|
// V8JavaScriptScanner
|
330
330
|
|
331
|
-
V8JavaScriptScanner::V8JavaScriptScanner() : JavaScriptScanner() { }
|
332
|
-
|
333
331
|
|
334
332
|
void V8JavaScriptScanner::Initialize(UC16CharacterStream* source) {
|
335
333
|
source_ = source;
|
@@ -347,7 +345,8 @@ void V8JavaScriptScanner::Initialize(UC16CharacterStream* source) {
|
|
347
345
|
// ----------------------------------------------------------------------------
|
348
346
|
// JsonScanner
|
349
347
|
|
350
|
-
JsonScanner::JsonScanner(
|
348
|
+
JsonScanner::JsonScanner(ScannerConstants* scanner_constants)
|
349
|
+
: Scanner(scanner_constants) { }
|
351
350
|
|
352
351
|
|
353
352
|
void JsonScanner::Initialize(UC16CharacterStream* source) {
|
@@ -576,11 +575,10 @@ Token::Value JsonScanner::ScanJsonIdentifier(const char* text,
|
|
576
575
|
Advance();
|
577
576
|
text++;
|
578
577
|
}
|
579
|
-
if (
|
578
|
+
if (scanner_constants_->IsIdentifierPart(c0_)) return Token::ILLEGAL;
|
580
579
|
literal.Complete();
|
581
580
|
return token;
|
582
581
|
}
|
583
582
|
|
584
583
|
|
585
|
-
|
586
584
|
} } // namespace v8::internal
|
data/vendor/v8/src/scanner.h
CHANGED
@@ -134,14 +134,16 @@ class ExternalTwoByteStringUC16CharacterStream: public UC16CharacterStream {
|
|
134
134
|
|
135
135
|
class V8JavaScriptScanner : public JavaScriptScanner {
|
136
136
|
public:
|
137
|
-
V8JavaScriptScanner()
|
137
|
+
explicit V8JavaScriptScanner(ScannerConstants* scanner_constants)
|
138
|
+
: JavaScriptScanner(scanner_constants) {}
|
139
|
+
|
138
140
|
void Initialize(UC16CharacterStream* source);
|
139
141
|
};
|
140
142
|
|
141
143
|
|
142
144
|
class JsonScanner : public Scanner {
|
143
145
|
public:
|
144
|
-
JsonScanner();
|
146
|
+
explicit JsonScanner(ScannerConstants* scanner_constants);
|
145
147
|
|
146
148
|
void Initialize(UC16CharacterStream* source);
|
147
149
|
|
data/vendor/v8/src/scopeinfo.cc
CHANGED
@@ -50,7 +50,7 @@ static int CompareLocal(Variable* const* v, Variable* const* w) {
|
|
50
50
|
|
51
51
|
template<class Allocator>
|
52
52
|
ScopeInfo<Allocator>::ScopeInfo(Scope* scope)
|
53
|
-
: function_name_(
|
53
|
+
: function_name_(FACTORY->empty_symbol()),
|
54
54
|
calls_eval_(scope->calls_eval()),
|
55
55
|
parameters_(scope->num_parameters()),
|
56
56
|
stack_slots_(scope->num_stack_slots()),
|
@@ -141,7 +141,7 @@ ScopeInfo<Allocator>::ScopeInfo(Scope* scope)
|
|
141
141
|
context_slots_.length());
|
142
142
|
ASSERT(var->AsSlot()->index() - Context::MIN_CONTEXT_SLOTS ==
|
143
143
|
context_modes_.length());
|
144
|
-
context_slots_.Add(
|
144
|
+
context_slots_.Add(FACTORY->empty_symbol());
|
145
145
|
context_modes_.Add(Variable::INTERNAL);
|
146
146
|
}
|
147
147
|
}
|
@@ -238,7 +238,7 @@ static Object** ReadList(Object** p,
|
|
238
238
|
|
239
239
|
template<class Allocator>
|
240
240
|
ScopeInfo<Allocator>::ScopeInfo(SerializedScopeInfo* data)
|
241
|
-
: function_name_(
|
241
|
+
: function_name_(FACTORY->empty_symbol()),
|
242
242
|
parameters_(4),
|
243
243
|
stack_slots_(8),
|
244
244
|
context_slots_(8),
|
@@ -309,7 +309,7 @@ Handle<SerializedScopeInfo> ScopeInfo<Allocator>::Serialize() {
|
|
309
309
|
stack_slots_.length();
|
310
310
|
|
311
311
|
Handle<SerializedScopeInfo> data(
|
312
|
-
SerializedScopeInfo::cast(*
|
312
|
+
SerializedScopeInfo::cast(*FACTORY->NewFixedArray(length, TENURED)));
|
313
313
|
AssertNoAllocation nogc;
|
314
314
|
|
315
315
|
Object** p0 = data->data_start();
|
@@ -357,7 +357,7 @@ Handle<SerializedScopeInfo> SerializedScopeInfo::Create(Scope* scope) {
|
|
357
357
|
|
358
358
|
|
359
359
|
SerializedScopeInfo* SerializedScopeInfo::Empty() {
|
360
|
-
return reinterpret_cast<SerializedScopeInfo*>(
|
360
|
+
return reinterpret_cast<SerializedScopeInfo*>(HEAP->empty_fixed_array());
|
361
361
|
}
|
362
362
|
|
363
363
|
|
@@ -448,7 +448,8 @@ int SerializedScopeInfo::StackSlotIndex(String* name) {
|
|
448
448
|
|
449
449
|
int SerializedScopeInfo::ContextSlotIndex(String* name, Variable::Mode* mode) {
|
450
450
|
ASSERT(name->IsSymbol());
|
451
|
-
|
451
|
+
Isolate* isolate = GetIsolate();
|
452
|
+
int result = isolate->context_slot_cache()->Lookup(this, name, mode);
|
452
453
|
if (result != ContextSlotCache::kNotFound) return result;
|
453
454
|
if (length() > 0) {
|
454
455
|
// Slots start after length entry.
|
@@ -465,13 +466,13 @@ int SerializedScopeInfo::ContextSlotIndex(String* name, Variable::Mode* mode) {
|
|
465
466
|
Variable::Mode mode_value = static_cast<Variable::Mode>(v);
|
466
467
|
if (mode != NULL) *mode = mode_value;
|
467
468
|
result = static_cast<int>((p - p0) >> 1) + Context::MIN_CONTEXT_SLOTS;
|
468
|
-
|
469
|
+
isolate->context_slot_cache()->Update(this, name, mode_value, result);
|
469
470
|
return result;
|
470
471
|
}
|
471
472
|
p += 2;
|
472
473
|
}
|
473
474
|
}
|
474
|
-
|
475
|
+
isolate->context_slot_cache()->Update(this, name, Variable::INTERNAL, -1);
|
475
476
|
return -1;
|
476
477
|
}
|
477
478
|
|
@@ -547,7 +548,7 @@ void ContextSlotCache::Update(Object* data,
|
|
547
548
|
int slot_index) {
|
548
549
|
String* symbol;
|
549
550
|
ASSERT(slot_index > kNotFound);
|
550
|
-
if (
|
551
|
+
if (HEAP->LookupSymbolIfExists(name, &symbol)) {
|
551
552
|
int index = Hash(data, symbol);
|
552
553
|
Key& key = keys_[index];
|
553
554
|
key.data = data;
|
@@ -566,12 +567,6 @@ void ContextSlotCache::Clear() {
|
|
566
567
|
}
|
567
568
|
|
568
569
|
|
569
|
-
ContextSlotCache::Key ContextSlotCache::keys_[ContextSlotCache::kLength];
|
570
|
-
|
571
|
-
|
572
|
-
uint32_t ContextSlotCache::values_[ContextSlotCache::kLength];
|
573
|
-
|
574
|
-
|
575
570
|
#ifdef DEBUG
|
576
571
|
|
577
572
|
void ContextSlotCache::ValidateEntry(Object* data,
|
@@ -579,7 +574,7 @@ void ContextSlotCache::ValidateEntry(Object* data,
|
|
579
574
|
Variable::Mode mode,
|
580
575
|
int slot_index) {
|
581
576
|
String* symbol;
|
582
|
-
if (
|
577
|
+
if (HEAP->LookupSymbolIfExists(name, &symbol)) {
|
583
578
|
int index = Hash(data, name);
|
584
579
|
Key& key = keys_[index];
|
585
580
|
ASSERT(key.data == data);
|
data/vendor/v8/src/scopeinfo.h
CHANGED
@@ -114,7 +114,7 @@ class SerializedScopeInfo : public FixedArray {
|
|
114
114
|
|
115
115
|
// Does this scope have an arguments shadow?
|
116
116
|
bool HasArgumentsShadow() {
|
117
|
-
return StackSlotIndex(
|
117
|
+
return StackSlotIndex(GetHeap()->arguments_shadow_symbol()) >= 0;
|
118
118
|
}
|
119
119
|
|
120
120
|
// Return the number of stack slots for code.
|
@@ -173,28 +173,36 @@ class ContextSlotCache {
|
|
173
173
|
public:
|
174
174
|
// Lookup context slot index for (data, name).
|
175
175
|
// If absent, kNotFound is returned.
|
176
|
-
|
177
|
-
|
178
|
-
|
176
|
+
int Lookup(Object* data,
|
177
|
+
String* name,
|
178
|
+
Variable::Mode* mode);
|
179
179
|
|
180
180
|
// Update an element in the cache.
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
|
181
|
+
void Update(Object* data,
|
182
|
+
String* name,
|
183
|
+
Variable::Mode mode,
|
184
|
+
int slot_index);
|
185
185
|
|
186
186
|
// Clear the cache.
|
187
|
-
|
187
|
+
void Clear();
|
188
188
|
|
189
189
|
static const int kNotFound = -2;
|
190
190
|
private:
|
191
|
+
ContextSlotCache() {
|
192
|
+
for (int i = 0; i < kLength; ++i) {
|
193
|
+
keys_[i].data = NULL;
|
194
|
+
keys_[i].name = NULL;
|
195
|
+
values_[i] = kNotFound;
|
196
|
+
}
|
197
|
+
}
|
198
|
+
|
191
199
|
inline static int Hash(Object* data, String* name);
|
192
200
|
|
193
201
|
#ifdef DEBUG
|
194
|
-
|
195
|
-
|
196
|
-
|
197
|
-
|
202
|
+
void ValidateEntry(Object* data,
|
203
|
+
String* name,
|
204
|
+
Variable::Mode mode,
|
205
|
+
int slot_index);
|
198
206
|
#endif
|
199
207
|
|
200
208
|
static const int kLength = 256;
|
@@ -228,8 +236,11 @@ class ContextSlotCache {
|
|
228
236
|
uint32_t value_;
|
229
237
|
};
|
230
238
|
|
231
|
-
|
232
|
-
|
239
|
+
Key keys_[kLength];
|
240
|
+
uint32_t values_[kLength];
|
241
|
+
|
242
|
+
friend class Isolate;
|
243
|
+
DISALLOW_COPY_AND_ASSIGN(ContextSlotCache);
|
233
244
|
};
|
234
245
|
|
235
246
|
|
data/vendor/v8/src/scopes.cc
CHANGED
@@ -40,12 +40,14 @@ namespace internal {
|
|
40
40
|
// ----------------------------------------------------------------------------
|
41
41
|
// A Zone allocator for use with LocalsMap.
|
42
42
|
|
43
|
+
// TODO(isolates): It is probably worth it to change the Allocator class to
|
44
|
+
// take a pointer to an isolate.
|
43
45
|
class ZoneAllocator: public Allocator {
|
44
46
|
public:
|
45
47
|
/* nothing to do */
|
46
48
|
virtual ~ZoneAllocator() {}
|
47
49
|
|
48
|
-
virtual void* New(size_t size) { return
|
50
|
+
virtual void* New(size_t size) { return ZONE->New(static_cast<int>(size)); }
|
49
51
|
|
50
52
|
/* ignored - Zone is freed in one fell swoop */
|
51
53
|
virtual void Delete(void* p) {}
|
@@ -148,26 +150,30 @@ Scope::Scope(Scope* inner_scope, SerializedScopeInfo* scope_info)
|
|
148
150
|
unresolved_(16),
|
149
151
|
decls_(4) {
|
150
152
|
ASSERT(scope_info != NULL);
|
151
|
-
SetDefaults(FUNCTION_SCOPE,
|
153
|
+
SetDefaults(FUNCTION_SCOPE, NULL, scope_info);
|
152
154
|
ASSERT(resolved());
|
153
|
-
InsertAfterScope(inner_scope);
|
154
155
|
if (scope_info->HasHeapAllocatedLocals()) {
|
155
156
|
num_heap_slots_ = scope_info_->NumberOfContextSlots();
|
156
157
|
}
|
157
158
|
|
159
|
+
AddInnerScope(inner_scope);
|
160
|
+
|
158
161
|
// This scope's arguments shadow (if present) is context-allocated if an inner
|
159
162
|
// scope accesses this one's parameters. Allocate the arguments_shadow_
|
160
163
|
// variable if necessary.
|
164
|
+
Isolate* isolate = Isolate::Current();
|
161
165
|
Variable::Mode mode;
|
162
166
|
int arguments_shadow_index =
|
163
|
-
scope_info_->ContextSlotIndex(
|
167
|
+
scope_info_->ContextSlotIndex(
|
168
|
+
isolate->heap()->arguments_shadow_symbol(), &mode);
|
164
169
|
if (arguments_shadow_index >= 0) {
|
165
170
|
ASSERT(mode == Variable::INTERNAL);
|
166
|
-
arguments_shadow_ = new Variable(
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
+
arguments_shadow_ = new Variable(
|
172
|
+
this,
|
173
|
+
isolate->factory()->arguments_shadow_symbol(),
|
174
|
+
Variable::INTERNAL,
|
175
|
+
true,
|
176
|
+
Variable::ARGUMENTS);
|
171
177
|
arguments_shadow_->set_rewrite(
|
172
178
|
new Slot(arguments_shadow_, Slot::CONTEXT, arguments_shadow_index));
|
173
179
|
arguments_shadow_->set_is_used(true);
|
@@ -175,34 +181,44 @@ Scope::Scope(Scope* inner_scope, SerializedScopeInfo* scope_info)
|
|
175
181
|
}
|
176
182
|
|
177
183
|
|
184
|
+
Scope* Scope::DeserializeScopeChain(CompilationInfo* info,
|
185
|
+
Scope* global_scope) {
|
186
|
+
ASSERT(!info->closure().is_null());
|
187
|
+
// If we have a serialized scope info, reuse it.
|
188
|
+
Scope* innermost_scope = NULL;
|
189
|
+
Scope* scope = NULL;
|
190
|
+
|
191
|
+
SerializedScopeInfo* scope_info = info->closure()->shared()->scope_info();
|
192
|
+
if (scope_info != SerializedScopeInfo::Empty()) {
|
193
|
+
JSFunction* current = *info->closure();
|
194
|
+
do {
|
195
|
+
current = current->context()->closure();
|
196
|
+
SerializedScopeInfo* scope_info = current->shared()->scope_info();
|
197
|
+
if (scope_info != SerializedScopeInfo::Empty()) {
|
198
|
+
scope = new Scope(scope, scope_info);
|
199
|
+
if (innermost_scope == NULL) innermost_scope = scope;
|
200
|
+
} else {
|
201
|
+
ASSERT(current->context()->IsGlobalContext());
|
202
|
+
}
|
203
|
+
} while (!current->context()->IsGlobalContext());
|
204
|
+
}
|
205
|
+
|
206
|
+
global_scope->AddInnerScope(scope);
|
207
|
+
if (innermost_scope == NULL) innermost_scope = global_scope;
|
208
|
+
|
209
|
+
return innermost_scope;
|
210
|
+
}
|
211
|
+
|
178
212
|
|
179
213
|
bool Scope::Analyze(CompilationInfo* info) {
|
180
214
|
ASSERT(info->function() != NULL);
|
181
215
|
Scope* top = info->function()->scope();
|
182
216
|
|
183
|
-
// If we have a serialized scope info, reuse it.
|
184
|
-
if (!info->closure().is_null()) {
|
185
|
-
SerializedScopeInfo* scope_info = info->closure()->shared()->scope_info();
|
186
|
-
if (scope_info != SerializedScopeInfo::Empty()) {
|
187
|
-
Scope* scope = top;
|
188
|
-
JSFunction* current = *info->closure();
|
189
|
-
do {
|
190
|
-
current = current->context()->closure();
|
191
|
-
SerializedScopeInfo* scope_info = current->shared()->scope_info();
|
192
|
-
if (scope_info != SerializedScopeInfo::Empty()) {
|
193
|
-
scope = new Scope(scope, scope_info);
|
194
|
-
} else {
|
195
|
-
ASSERT(current->context()->IsGlobalContext());
|
196
|
-
}
|
197
|
-
} while (!current->context()->IsGlobalContext());
|
198
|
-
}
|
199
|
-
}
|
200
|
-
|
201
217
|
while (top->outer_scope() != NULL) top = top->outer_scope();
|
202
218
|
top->AllocateVariables(info->calling_context());
|
203
219
|
|
204
220
|
#ifdef DEBUG
|
205
|
-
if (
|
221
|
+
if (info->isolate()->bootstrapper()->IsActive()
|
206
222
|
? FLAG_print_builtin_scopes
|
207
223
|
: FLAG_print_scopes) {
|
208
224
|
info->function()->scope()->Print();
|
@@ -234,7 +250,7 @@ void Scope::Initialize(bool inside_with) {
|
|
234
250
|
// such parameter is 'this' which is passed on the stack when
|
235
251
|
// invoking scripts
|
236
252
|
Variable* var =
|
237
|
-
variables_.Declare(this,
|
253
|
+
variables_.Declare(this, FACTORY->this_symbol(), Variable::VAR,
|
238
254
|
false, Variable::THIS);
|
239
255
|
var->set_rewrite(new Slot(var, Slot::PARAMETER, -1));
|
240
256
|
receiver_ = var;
|
@@ -243,7 +259,7 @@ void Scope::Initialize(bool inside_with) {
|
|
243
259
|
// Declare 'arguments' variable which exists in all functions.
|
244
260
|
// Note that it might never be accessed, in which case it won't be
|
245
261
|
// allocated during variable allocation.
|
246
|
-
variables_.Declare(this,
|
262
|
+
variables_.Declare(this, FACTORY->arguments_symbol(), Variable::VAR,
|
247
263
|
true, Variable::ARGUMENTS);
|
248
264
|
}
|
249
265
|
}
|
@@ -258,7 +274,7 @@ Variable* Scope::LocalLookup(Handle<String> name) {
|
|
258
274
|
|
259
275
|
// We should never lookup 'arguments' in this scope
|
260
276
|
// as it is implicitly present in any scope.
|
261
|
-
ASSERT(*name != *
|
277
|
+
ASSERT(*name != *FACTORY->arguments_symbol());
|
262
278
|
|
263
279
|
// Assert that there is no local slot with the given name.
|
264
280
|
ASSERT(scope_info_->StackSlotIndex(*name) < 0);
|
@@ -345,12 +361,14 @@ void Scope::AddParameter(Variable* var) {
|
|
345
361
|
}
|
346
362
|
|
347
363
|
|
348
|
-
VariableProxy* Scope::NewUnresolved(Handle<String> name,
|
364
|
+
VariableProxy* Scope::NewUnresolved(Handle<String> name,
|
365
|
+
bool inside_with,
|
366
|
+
int position) {
|
349
367
|
// Note that we must not share the unresolved variables with
|
350
368
|
// the same name because they may be removed selectively via
|
351
369
|
// RemoveUnresolved().
|
352
370
|
ASSERT(!resolved());
|
353
|
-
VariableProxy* proxy = new VariableProxy(name, false, inside_with);
|
371
|
+
VariableProxy* proxy = new VariableProxy(name, false, inside_with, position);
|
354
372
|
unresolved_.Add(proxy);
|
355
373
|
return proxy;
|
356
374
|
}
|
@@ -857,7 +875,7 @@ bool Scope::MustAllocateInContext(Variable* var) {
|
|
857
875
|
|
858
876
|
bool Scope::HasArgumentsParameter() {
|
859
877
|
for (int i = 0; i < params_.length(); i++) {
|
860
|
-
if (params_[i]->name().is_identical_to(
|
878
|
+
if (params_[i]->name().is_identical_to(FACTORY->arguments_symbol()))
|
861
879
|
return true;
|
862
880
|
}
|
863
881
|
return false;
|
@@ -876,8 +894,13 @@ void Scope::AllocateHeapSlot(Variable* var) {
|
|
876
894
|
|
877
895
|
void Scope::AllocateParameterLocals() {
|
878
896
|
ASSERT(is_function_scope());
|
879
|
-
Variable* arguments = LocalLookup(
|
897
|
+
Variable* arguments = LocalLookup(FACTORY->arguments_symbol());
|
880
898
|
ASSERT(arguments != NULL); // functions have 'arguments' declared implicitly
|
899
|
+
|
900
|
+
// Parameters are rewritten to arguments[i] if 'arguments' is used in
|
901
|
+
// a non-strict mode function. Strict mode code doesn't alias arguments.
|
902
|
+
bool rewrite_parameters = false;
|
903
|
+
|
881
904
|
if (MustAllocate(arguments) && !HasArgumentsParameter()) {
|
882
905
|
// 'arguments' is used. Unless there is also a parameter called
|
883
906
|
// 'arguments', we must be conservative and access all parameters via
|
@@ -909,6 +932,13 @@ void Scope::AllocateParameterLocals() {
|
|
909
932
|
// allocate the arguments object by setting 'arguments_'.
|
910
933
|
arguments_ = arguments;
|
911
934
|
|
935
|
+
// In strict mode 'arguments' does not alias formal parameters.
|
936
|
+
// Therefore in strict mode we allocate parameters as if 'arguments'
|
937
|
+
// were not used.
|
938
|
+
rewrite_parameters = !is_strict_mode();
|
939
|
+
}
|
940
|
+
|
941
|
+
if (rewrite_parameters) {
|
912
942
|
// We also need the '.arguments' shadow variable. Declare it and create
|
913
943
|
// and bind the corresponding proxy. It's ok to declare it only now
|
914
944
|
// because it's a local variable that is allocated after the parameters
|
@@ -919,7 +949,7 @@ void Scope::AllocateParameterLocals() {
|
|
919
949
|
// variable may be allocated in the heap-allocated context (temporaries
|
920
950
|
// are never allocated in the context).
|
921
951
|
arguments_shadow_ = new Variable(this,
|
922
|
-
|
952
|
+
FACTORY->arguments_shadow_symbol(),
|
923
953
|
Variable::INTERNAL,
|
924
954
|
true,
|
925
955
|
Variable::ARGUMENTS);
|
@@ -985,7 +1015,7 @@ void Scope::AllocateParameterLocals() {
|
|
985
1015
|
void Scope::AllocateNonParameterLocal(Variable* var) {
|
986
1016
|
ASSERT(var->scope() == this);
|
987
1017
|
ASSERT(var->rewrite() == NULL ||
|
988
|
-
(!var->IsVariable(
|
1018
|
+
(!var->IsVariable(FACTORY->result_symbol())) ||
|
989
1019
|
(var->AsSlot() == NULL || var->AsSlot()->type() != Slot::LOCAL));
|
990
1020
|
if (var->rewrite() == NULL && MustAllocate(var)) {
|
991
1021
|
if (MustAllocateInContext(var)) {
|
data/vendor/v8/src/scopes.h
CHANGED
@@ -104,6 +104,9 @@ class Scope: public ZoneObject {
|
|
104
104
|
// doesn't re-allocate variables repeatedly.
|
105
105
|
static bool Analyze(CompilationInfo* info);
|
106
106
|
|
107
|
+
static Scope* DeserializeScopeChain(CompilationInfo* info,
|
108
|
+
Scope* innermost_scope);
|
109
|
+
|
107
110
|
// The scope name is only used for printing/debugging.
|
108
111
|
void SetScopeName(Handle<String> scope_name) { scope_name_ = scope_name; }
|
109
112
|
|
@@ -146,7 +149,9 @@ class Scope: public ZoneObject {
|
|
146
149
|
void AddParameter(Variable* var);
|
147
150
|
|
148
151
|
// Create a new unresolved variable.
|
149
|
-
virtual VariableProxy* NewUnresolved(Handle<String> name,
|
152
|
+
virtual VariableProxy* NewUnresolved(Handle<String> name,
|
153
|
+
bool inside_with,
|
154
|
+
int position = RelocInfo::kNoPosition);
|
150
155
|
|
151
156
|
// Remove a unresolved variable. During parsing, an unresolved variable
|
152
157
|
// may have been added optimistically, but then only the variable name
|
@@ -193,6 +198,10 @@ class Scope: public ZoneObject {
|
|
193
198
|
// Inform the scope that the corresponding code contains an eval call.
|
194
199
|
void RecordEvalCall() { scope_calls_eval_ = true; }
|
195
200
|
|
201
|
+
// Enable strict mode for the scope (unless disabled by a global flag).
|
202
|
+
void EnableStrictMode() {
|
203
|
+
strict_mode_ = FLAG_strict_mode;
|
204
|
+
}
|
196
205
|
|
197
206
|
// ---------------------------------------------------------------------------
|
198
207
|
// Predicates.
|
@@ -201,6 +210,7 @@ class Scope: public ZoneObject {
|
|
201
210
|
bool is_eval_scope() const { return type_ == EVAL_SCOPE; }
|
202
211
|
bool is_function_scope() const { return type_ == FUNCTION_SCOPE; }
|
203
212
|
bool is_global_scope() const { return type_ == GLOBAL_SCOPE; }
|
213
|
+
bool is_strict_mode() const { return strict_mode_; }
|
204
214
|
|
205
215
|
// Information about which scopes calls eval.
|
206
216
|
bool calls_eval() const { return scope_calls_eval_; }
|
@@ -220,7 +230,7 @@ class Scope: public ZoneObject {
|
|
220
230
|
// A new variable proxy corresponding to the (function) receiver.
|
221
231
|
VariableProxy* receiver() const {
|
222
232
|
VariableProxy* proxy =
|
223
|
-
new VariableProxy(
|
233
|
+
new VariableProxy(FACTORY->this_symbol(), true, false);
|
224
234
|
proxy->BindTo(receiver_);
|
225
235
|
return proxy;
|
226
236
|
}
|
@@ -313,14 +323,6 @@ class Scope: public ZoneObject {
|
|
313
323
|
|
314
324
|
explicit Scope(Type type);
|
315
325
|
|
316
|
-
void InsertAfterScope(Scope* scope) {
|
317
|
-
inner_scopes_.Add(scope);
|
318
|
-
outer_scope_ = scope->outer_scope_;
|
319
|
-
outer_scope_->inner_scopes_.RemoveElement(scope);
|
320
|
-
outer_scope_->inner_scopes_.Add(this);
|
321
|
-
scope->outer_scope_ = this;
|
322
|
-
}
|
323
|
-
|
324
326
|
// Scope tree.
|
325
327
|
Scope* outer_scope_; // the immediately enclosing outer scope, or NULL
|
326
328
|
ZoneList<Scope*> inner_scopes_; // the immediately enclosed inner scopes
|
@@ -363,6 +365,7 @@ class Scope: public ZoneObject {
|
|
363
365
|
bool scope_inside_with_; // this scope is inside a 'with' of some outer scope
|
364
366
|
bool scope_contains_with_; // this scope contains a 'with' statement
|
365
367
|
bool scope_calls_eval_; // this scope contains an 'eval' call
|
368
|
+
bool strict_mode_; // this scope is a strict mode scope
|
366
369
|
|
367
370
|
// Computed via PropagateScopeInfo.
|
368
371
|
bool outer_scope_calls_eval_;
|
@@ -413,12 +416,19 @@ class Scope: public ZoneObject {
|
|
413
416
|
private:
|
414
417
|
Scope(Scope* inner_scope, SerializedScopeInfo* scope_info);
|
415
418
|
|
419
|
+
void AddInnerScope(Scope* inner_scope) {
|
420
|
+
if (inner_scope != NULL) {
|
421
|
+
inner_scopes_.Add(inner_scope);
|
422
|
+
inner_scope->outer_scope_ = this;
|
423
|
+
}
|
424
|
+
}
|
425
|
+
|
416
426
|
void SetDefaults(Type type,
|
417
427
|
Scope* outer_scope,
|
418
428
|
SerializedScopeInfo* scope_info) {
|
419
429
|
outer_scope_ = outer_scope;
|
420
430
|
type_ = type;
|
421
|
-
scope_name_ =
|
431
|
+
scope_name_ = FACTORY->empty_symbol();
|
422
432
|
dynamics_ = NULL;
|
423
433
|
receiver_ = NULL;
|
424
434
|
function_ = NULL;
|
@@ -428,6 +438,8 @@ class Scope: public ZoneObject {
|
|
428
438
|
scope_inside_with_ = false;
|
429
439
|
scope_contains_with_ = false;
|
430
440
|
scope_calls_eval_ = false;
|
441
|
+
// Inherit the strict mode from the parent scope.
|
442
|
+
strict_mode_ = (outer_scope != NULL) && outer_scope->strict_mode_;
|
431
443
|
outer_scope_calls_eval_ = false;
|
432
444
|
inner_scope_calls_eval_ = false;
|
433
445
|
outer_scope_is_eval_scope_ = false;
|
@@ -469,7 +481,9 @@ class DummyScope : public Scope {
|
|
469
481
|
|
470
482
|
virtual Variable* Lookup(Handle<String> name) { return NULL; }
|
471
483
|
|
472
|
-
virtual VariableProxy* NewUnresolved(Handle<String> name,
|
484
|
+
virtual VariableProxy* NewUnresolved(Handle<String> name,
|
485
|
+
bool inside_with,
|
486
|
+
int position = RelocInfo::kNoPosition) {
|
473
487
|
return NULL;
|
474
488
|
}
|
475
489
|
|