libv8 3.11.8.17 → 3.16.14.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.travis.yml +1 -2
- data/Gemfile +1 -1
- data/Rakefile +6 -7
- data/lib/libv8/version.rb +1 -1
- data/vendor/v8/.gitignore +24 -3
- data/vendor/v8/AUTHORS +7 -0
- data/vendor/v8/ChangeLog +839 -0
- data/vendor/v8/DEPS +1 -1
- data/vendor/v8/Makefile.android +92 -0
- data/vendor/v8/OWNERS +11 -0
- data/vendor/v8/PRESUBMIT.py +71 -0
- data/vendor/v8/SConstruct +34 -39
- data/vendor/v8/build/android.gypi +56 -37
- data/vendor/v8/build/common.gypi +112 -30
- data/vendor/v8/build/gyp_v8 +1 -1
- data/vendor/v8/build/standalone.gypi +15 -11
- data/vendor/v8/include/v8-debug.h +9 -1
- data/vendor/v8/include/v8-preparser.h +4 -3
- data/vendor/v8/include/v8-profiler.h +25 -25
- data/vendor/v8/include/v8-testing.h +4 -3
- data/vendor/v8/include/v8.h +994 -540
- data/vendor/v8/preparser/preparser-process.cc +3 -3
- data/vendor/v8/samples/lineprocessor.cc +20 -27
- data/vendor/v8/samples/process.cc +18 -14
- data/vendor/v8/samples/shell.cc +16 -15
- data/vendor/v8/src/SConscript +15 -14
- data/vendor/v8/src/accessors.cc +169 -77
- data/vendor/v8/src/accessors.h +4 -0
- data/vendor/v8/src/allocation-inl.h +2 -2
- data/vendor/v8/src/allocation.h +7 -7
- data/vendor/v8/src/api.cc +810 -497
- data/vendor/v8/src/api.h +85 -60
- data/vendor/v8/src/arm/assembler-arm-inl.h +179 -22
- data/vendor/v8/src/arm/assembler-arm.cc +633 -264
- data/vendor/v8/src/arm/assembler-arm.h +264 -197
- data/vendor/v8/src/arm/builtins-arm.cc +117 -27
- data/vendor/v8/src/arm/code-stubs-arm.cc +1241 -700
- data/vendor/v8/src/arm/code-stubs-arm.h +35 -138
- data/vendor/v8/src/arm/codegen-arm.cc +285 -16
- data/vendor/v8/src/arm/codegen-arm.h +22 -0
- data/vendor/v8/src/arm/constants-arm.cc +5 -3
- data/vendor/v8/src/arm/constants-arm.h +24 -11
- data/vendor/v8/src/arm/debug-arm.cc +3 -3
- data/vendor/v8/src/arm/deoptimizer-arm.cc +382 -92
- data/vendor/v8/src/arm/disasm-arm.cc +61 -12
- data/vendor/v8/src/arm/frames-arm.h +0 -14
- data/vendor/v8/src/arm/full-codegen-arm.cc +332 -304
- data/vendor/v8/src/arm/ic-arm.cc +180 -259
- data/vendor/v8/src/arm/lithium-arm.cc +364 -316
- data/vendor/v8/src/arm/lithium-arm.h +512 -275
- data/vendor/v8/src/arm/lithium-codegen-arm.cc +1768 -809
- data/vendor/v8/src/arm/lithium-codegen-arm.h +97 -35
- data/vendor/v8/src/arm/lithium-gap-resolver-arm.cc +12 -5
- data/vendor/v8/src/arm/macro-assembler-arm.cc +439 -228
- data/vendor/v8/src/arm/macro-assembler-arm.h +116 -70
- data/vendor/v8/src/arm/regexp-macro-assembler-arm.cc +54 -44
- data/vendor/v8/src/arm/regexp-macro-assembler-arm.h +3 -10
- data/vendor/v8/src/arm/simulator-arm.cc +272 -238
- data/vendor/v8/src/arm/simulator-arm.h +38 -8
- data/vendor/v8/src/arm/stub-cache-arm.cc +522 -895
- data/vendor/v8/src/array.js +101 -70
- data/vendor/v8/src/assembler.cc +270 -19
- data/vendor/v8/src/assembler.h +110 -15
- data/vendor/v8/src/ast.cc +79 -69
- data/vendor/v8/src/ast.h +255 -301
- data/vendor/v8/src/atomicops.h +7 -1
- data/vendor/v8/src/atomicops_internals_tsan.h +335 -0
- data/vendor/v8/src/bootstrapper.cc +481 -418
- data/vendor/v8/src/bootstrapper.h +4 -4
- data/vendor/v8/src/builtins.cc +498 -311
- data/vendor/v8/src/builtins.h +75 -47
- data/vendor/v8/src/checks.cc +2 -1
- data/vendor/v8/src/checks.h +8 -0
- data/vendor/v8/src/code-stubs-hydrogen.cc +253 -0
- data/vendor/v8/src/code-stubs.cc +249 -84
- data/vendor/v8/src/code-stubs.h +501 -169
- data/vendor/v8/src/codegen.cc +36 -18
- data/vendor/v8/src/codegen.h +25 -3
- data/vendor/v8/src/collection.js +54 -17
- data/vendor/v8/src/compilation-cache.cc +24 -16
- data/vendor/v8/src/compilation-cache.h +15 -6
- data/vendor/v8/src/compiler.cc +497 -195
- data/vendor/v8/src/compiler.h +246 -38
- data/vendor/v8/src/contexts.cc +64 -24
- data/vendor/v8/src/contexts.h +60 -29
- data/vendor/v8/src/conversions-inl.h +24 -14
- data/vendor/v8/src/conversions.h +7 -4
- data/vendor/v8/src/counters.cc +21 -12
- data/vendor/v8/src/counters.h +44 -16
- data/vendor/v8/src/cpu-profiler.h +1 -1
- data/vendor/v8/src/d8-debug.cc +2 -2
- data/vendor/v8/src/d8-readline.cc +13 -2
- data/vendor/v8/src/d8.cc +681 -273
- data/vendor/v8/src/d8.gyp +4 -4
- data/vendor/v8/src/d8.h +38 -18
- data/vendor/v8/src/d8.js +0 -617
- data/vendor/v8/src/data-flow.h +55 -0
- data/vendor/v8/src/date.js +1 -42
- data/vendor/v8/src/dateparser-inl.h +5 -1
- data/vendor/v8/src/debug-agent.cc +10 -15
- data/vendor/v8/src/debug-debugger.js +147 -149
- data/vendor/v8/src/debug.cc +323 -164
- data/vendor/v8/src/debug.h +26 -14
- data/vendor/v8/src/deoptimizer.cc +765 -290
- data/vendor/v8/src/deoptimizer.h +130 -28
- data/vendor/v8/src/disassembler.cc +10 -4
- data/vendor/v8/src/elements-kind.cc +7 -2
- data/vendor/v8/src/elements-kind.h +19 -0
- data/vendor/v8/src/elements.cc +607 -285
- data/vendor/v8/src/elements.h +36 -13
- data/vendor/v8/src/execution.cc +52 -31
- data/vendor/v8/src/execution.h +4 -4
- data/vendor/v8/src/extensions/externalize-string-extension.cc +5 -4
- data/vendor/v8/src/extensions/gc-extension.cc +5 -1
- data/vendor/v8/src/extensions/statistics-extension.cc +153 -0
- data/vendor/v8/src/{inspector.h → extensions/statistics-extension.h} +12 -23
- data/vendor/v8/src/factory.cc +101 -134
- data/vendor/v8/src/factory.h +36 -31
- data/vendor/v8/src/flag-definitions.h +102 -25
- data/vendor/v8/src/flags.cc +9 -5
- data/vendor/v8/src/frames-inl.h +10 -0
- data/vendor/v8/src/frames.cc +116 -26
- data/vendor/v8/src/frames.h +96 -12
- data/vendor/v8/src/full-codegen.cc +219 -74
- data/vendor/v8/src/full-codegen.h +63 -21
- data/vendor/v8/src/func-name-inferrer.cc +8 -7
- data/vendor/v8/src/func-name-inferrer.h +5 -3
- data/vendor/v8/src/gdb-jit.cc +71 -57
- data/vendor/v8/src/global-handles.cc +230 -101
- data/vendor/v8/src/global-handles.h +26 -27
- data/vendor/v8/src/globals.h +17 -19
- data/vendor/v8/src/handles-inl.h +59 -12
- data/vendor/v8/src/handles.cc +180 -200
- data/vendor/v8/src/handles.h +80 -11
- data/vendor/v8/src/hashmap.h +60 -40
- data/vendor/v8/src/heap-inl.h +107 -45
- data/vendor/v8/src/heap-profiler.cc +38 -19
- data/vendor/v8/src/heap-profiler.h +24 -14
- data/vendor/v8/src/heap.cc +1123 -738
- data/vendor/v8/src/heap.h +385 -146
- data/vendor/v8/src/hydrogen-instructions.cc +700 -217
- data/vendor/v8/src/hydrogen-instructions.h +1158 -472
- data/vendor/v8/src/hydrogen.cc +3319 -1662
- data/vendor/v8/src/hydrogen.h +411 -170
- data/vendor/v8/src/ia32/assembler-ia32-inl.h +46 -16
- data/vendor/v8/src/ia32/assembler-ia32.cc +131 -61
- data/vendor/v8/src/ia32/assembler-ia32.h +115 -57
- data/vendor/v8/src/ia32/builtins-ia32.cc +99 -5
- data/vendor/v8/src/ia32/code-stubs-ia32.cc +787 -495
- data/vendor/v8/src/ia32/code-stubs-ia32.h +10 -100
- data/vendor/v8/src/ia32/codegen-ia32.cc +227 -23
- data/vendor/v8/src/ia32/codegen-ia32.h +14 -0
- data/vendor/v8/src/ia32/deoptimizer-ia32.cc +428 -87
- data/vendor/v8/src/ia32/disasm-ia32.cc +28 -1
- data/vendor/v8/src/ia32/frames-ia32.h +6 -16
- data/vendor/v8/src/ia32/full-codegen-ia32.cc +280 -272
- data/vendor/v8/src/ia32/ic-ia32.cc +150 -250
- data/vendor/v8/src/ia32/lithium-codegen-ia32.cc +1600 -517
- data/vendor/v8/src/ia32/lithium-codegen-ia32.h +90 -24
- data/vendor/v8/src/ia32/lithium-gap-resolver-ia32.cc +10 -6
- data/vendor/v8/src/ia32/lithium-gap-resolver-ia32.h +2 -2
- data/vendor/v8/src/ia32/lithium-ia32.cc +405 -302
- data/vendor/v8/src/ia32/lithium-ia32.h +526 -271
- data/vendor/v8/src/ia32/macro-assembler-ia32.cc +378 -119
- data/vendor/v8/src/ia32/macro-assembler-ia32.h +62 -28
- data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.cc +43 -30
- data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.h +2 -10
- data/vendor/v8/src/ia32/stub-cache-ia32.cc +492 -678
- data/vendor/v8/src/ic-inl.h +9 -4
- data/vendor/v8/src/ic.cc +836 -923
- data/vendor/v8/src/ic.h +228 -247
- data/vendor/v8/src/incremental-marking-inl.h +26 -30
- data/vendor/v8/src/incremental-marking.cc +276 -248
- data/vendor/v8/src/incremental-marking.h +29 -37
- data/vendor/v8/src/interface.cc +34 -25
- data/vendor/v8/src/interface.h +69 -25
- data/vendor/v8/src/interpreter-irregexp.cc +2 -2
- data/vendor/v8/src/isolate.cc +382 -76
- data/vendor/v8/src/isolate.h +109 -56
- data/vendor/v8/src/json-parser.h +217 -104
- data/vendor/v8/src/json-stringifier.h +745 -0
- data/vendor/v8/src/json.js +10 -132
- data/vendor/v8/src/jsregexp-inl.h +106 -0
- data/vendor/v8/src/jsregexp.cc +517 -285
- data/vendor/v8/src/jsregexp.h +145 -117
- data/vendor/v8/src/list-inl.h +35 -22
- data/vendor/v8/src/list.h +46 -19
- data/vendor/v8/src/lithium-allocator-inl.h +22 -2
- data/vendor/v8/src/lithium-allocator.cc +85 -70
- data/vendor/v8/src/lithium-allocator.h +21 -39
- data/vendor/v8/src/lithium.cc +259 -5
- data/vendor/v8/src/lithium.h +131 -32
- data/vendor/v8/src/liveedit-debugger.js +52 -3
- data/vendor/v8/src/liveedit.cc +393 -113
- data/vendor/v8/src/liveedit.h +7 -3
- data/vendor/v8/src/log-utils.cc +4 -2
- data/vendor/v8/src/log.cc +170 -140
- data/vendor/v8/src/log.h +62 -11
- data/vendor/v8/src/macro-assembler.h +17 -0
- data/vendor/v8/src/macros.py +2 -0
- data/vendor/v8/src/mark-compact-inl.h +3 -23
- data/vendor/v8/src/mark-compact.cc +801 -830
- data/vendor/v8/src/mark-compact.h +154 -47
- data/vendor/v8/src/marking-thread.cc +85 -0
- data/vendor/v8/src/{inspector.cc → marking-thread.h} +32 -24
- data/vendor/v8/src/math.js +12 -18
- data/vendor/v8/src/messages.cc +18 -8
- data/vendor/v8/src/messages.js +314 -261
- data/vendor/v8/src/mips/assembler-mips-inl.h +58 -6
- data/vendor/v8/src/mips/assembler-mips.cc +92 -75
- data/vendor/v8/src/mips/assembler-mips.h +54 -60
- data/vendor/v8/src/mips/builtins-mips.cc +116 -17
- data/vendor/v8/src/mips/code-stubs-mips.cc +919 -556
- data/vendor/v8/src/mips/code-stubs-mips.h +22 -131
- data/vendor/v8/src/mips/codegen-mips.cc +281 -6
- data/vendor/v8/src/mips/codegen-mips.h +22 -0
- data/vendor/v8/src/mips/constants-mips.cc +2 -0
- data/vendor/v8/src/mips/constants-mips.h +12 -2
- data/vendor/v8/src/mips/deoptimizer-mips.cc +286 -50
- data/vendor/v8/src/mips/disasm-mips.cc +13 -0
- data/vendor/v8/src/mips/full-codegen-mips.cc +297 -284
- data/vendor/v8/src/mips/ic-mips.cc +182 -263
- data/vendor/v8/src/mips/lithium-codegen-mips.cc +1208 -556
- data/vendor/v8/src/mips/lithium-codegen-mips.h +72 -19
- data/vendor/v8/src/mips/lithium-gap-resolver-mips.cc +9 -2
- data/vendor/v8/src/mips/lithium-mips.cc +290 -302
- data/vendor/v8/src/mips/lithium-mips.h +463 -266
- data/vendor/v8/src/mips/macro-assembler-mips.cc +208 -115
- data/vendor/v8/src/mips/macro-assembler-mips.h +67 -24
- data/vendor/v8/src/mips/regexp-macro-assembler-mips.cc +40 -25
- data/vendor/v8/src/mips/regexp-macro-assembler-mips.h +3 -9
- data/vendor/v8/src/mips/simulator-mips.cc +112 -40
- data/vendor/v8/src/mips/simulator-mips.h +5 -0
- data/vendor/v8/src/mips/stub-cache-mips.cc +502 -884
- data/vendor/v8/src/mirror-debugger.js +157 -30
- data/vendor/v8/src/mksnapshot.cc +88 -14
- data/vendor/v8/src/object-observe.js +235 -0
- data/vendor/v8/src/objects-debug.cc +178 -176
- data/vendor/v8/src/objects-inl.h +1333 -486
- data/vendor/v8/src/objects-printer.cc +125 -43
- data/vendor/v8/src/objects-visiting-inl.h +578 -6
- data/vendor/v8/src/objects-visiting.cc +2 -2
- data/vendor/v8/src/objects-visiting.h +172 -79
- data/vendor/v8/src/objects.cc +3533 -2885
- data/vendor/v8/src/objects.h +1352 -1131
- data/vendor/v8/src/optimizing-compiler-thread.cc +152 -0
- data/vendor/v8/src/optimizing-compiler-thread.h +111 -0
- data/vendor/v8/src/parser.cc +390 -500
- data/vendor/v8/src/parser.h +45 -33
- data/vendor/v8/src/platform-cygwin.cc +10 -21
- data/vendor/v8/src/platform-freebsd.cc +36 -41
- data/vendor/v8/src/platform-linux.cc +160 -124
- data/vendor/v8/src/platform-macos.cc +30 -27
- data/vendor/v8/src/platform-nullos.cc +17 -1
- data/vendor/v8/src/platform-openbsd.cc +19 -50
- data/vendor/v8/src/platform-posix.cc +14 -0
- data/vendor/v8/src/platform-solaris.cc +20 -53
- data/vendor/v8/src/platform-win32.cc +49 -26
- data/vendor/v8/src/platform.h +40 -1
- data/vendor/v8/src/preparser.cc +8 -5
- data/vendor/v8/src/preparser.h +2 -2
- data/vendor/v8/src/prettyprinter.cc +16 -0
- data/vendor/v8/src/prettyprinter.h +2 -0
- data/vendor/v8/src/profile-generator-inl.h +1 -0
- data/vendor/v8/src/profile-generator.cc +209 -147
- data/vendor/v8/src/profile-generator.h +15 -12
- data/vendor/v8/src/property-details.h +46 -31
- data/vendor/v8/src/property.cc +27 -46
- data/vendor/v8/src/property.h +163 -83
- data/vendor/v8/src/proxy.js +7 -2
- data/vendor/v8/src/regexp-macro-assembler-irregexp.cc +4 -13
- data/vendor/v8/src/regexp-macro-assembler-irregexp.h +1 -2
- data/vendor/v8/src/regexp-macro-assembler-tracer.cc +1 -11
- data/vendor/v8/src/regexp-macro-assembler-tracer.h +0 -1
- data/vendor/v8/src/regexp-macro-assembler.cc +31 -14
- data/vendor/v8/src/regexp-macro-assembler.h +14 -11
- data/vendor/v8/src/regexp-stack.cc +1 -0
- data/vendor/v8/src/regexp.js +9 -8
- data/vendor/v8/src/rewriter.cc +18 -7
- data/vendor/v8/src/runtime-profiler.cc +52 -43
- data/vendor/v8/src/runtime-profiler.h +0 -25
- data/vendor/v8/src/runtime.cc +2006 -2023
- data/vendor/v8/src/runtime.h +56 -49
- data/vendor/v8/src/safepoint-table.cc +12 -18
- data/vendor/v8/src/safepoint-table.h +11 -8
- data/vendor/v8/src/scanner.cc +1 -0
- data/vendor/v8/src/scanner.h +4 -10
- data/vendor/v8/src/scopeinfo.cc +35 -9
- data/vendor/v8/src/scopeinfo.h +64 -3
- data/vendor/v8/src/scopes.cc +251 -156
- data/vendor/v8/src/scopes.h +61 -27
- data/vendor/v8/src/serialize.cc +348 -396
- data/vendor/v8/src/serialize.h +125 -114
- data/vendor/v8/src/small-pointer-list.h +11 -11
- data/vendor/v8/src/{smart-array-pointer.h → smart-pointers.h} +64 -15
- data/vendor/v8/src/snapshot-common.cc +64 -15
- data/vendor/v8/src/snapshot-empty.cc +7 -1
- data/vendor/v8/src/snapshot.h +9 -2
- data/vendor/v8/src/spaces-inl.h +17 -0
- data/vendor/v8/src/spaces.cc +477 -183
- data/vendor/v8/src/spaces.h +238 -58
- data/vendor/v8/src/splay-tree-inl.h +8 -7
- data/vendor/v8/src/splay-tree.h +24 -10
- data/vendor/v8/src/store-buffer.cc +12 -5
- data/vendor/v8/src/store-buffer.h +2 -4
- data/vendor/v8/src/string-search.h +22 -6
- data/vendor/v8/src/string-stream.cc +11 -8
- data/vendor/v8/src/string.js +47 -15
- data/vendor/v8/src/stub-cache.cc +461 -224
- data/vendor/v8/src/stub-cache.h +164 -102
- data/vendor/v8/src/sweeper-thread.cc +105 -0
- data/vendor/v8/src/sweeper-thread.h +81 -0
- data/vendor/v8/src/token.h +1 -0
- data/vendor/v8/src/transitions-inl.h +220 -0
- data/vendor/v8/src/transitions.cc +160 -0
- data/vendor/v8/src/transitions.h +207 -0
- data/vendor/v8/src/type-info.cc +182 -181
- data/vendor/v8/src/type-info.h +31 -19
- data/vendor/v8/src/unicode-inl.h +62 -106
- data/vendor/v8/src/unicode.cc +57 -67
- data/vendor/v8/src/unicode.h +45 -91
- data/vendor/v8/src/uri.js +57 -29
- data/vendor/v8/src/utils.h +105 -5
- data/vendor/v8/src/v8-counters.cc +54 -11
- data/vendor/v8/src/v8-counters.h +134 -19
- data/vendor/v8/src/v8.cc +29 -29
- data/vendor/v8/src/v8.h +1 -0
- data/vendor/v8/src/v8conversions.cc +26 -22
- data/vendor/v8/src/v8globals.h +56 -43
- data/vendor/v8/src/v8natives.js +83 -30
- data/vendor/v8/src/v8threads.cc +42 -21
- data/vendor/v8/src/v8threads.h +4 -1
- data/vendor/v8/src/v8utils.cc +9 -93
- data/vendor/v8/src/v8utils.h +37 -33
- data/vendor/v8/src/variables.cc +6 -3
- data/vendor/v8/src/variables.h +6 -13
- data/vendor/v8/src/version.cc +2 -2
- data/vendor/v8/src/vm-state-inl.h +11 -0
- data/vendor/v8/src/x64/assembler-x64-inl.h +39 -8
- data/vendor/v8/src/x64/assembler-x64.cc +78 -64
- data/vendor/v8/src/x64/assembler-x64.h +38 -33
- data/vendor/v8/src/x64/builtins-x64.cc +105 -7
- data/vendor/v8/src/x64/code-stubs-x64.cc +790 -413
- data/vendor/v8/src/x64/code-stubs-x64.h +10 -106
- data/vendor/v8/src/x64/codegen-x64.cc +210 -8
- data/vendor/v8/src/x64/codegen-x64.h +20 -1
- data/vendor/v8/src/x64/deoptimizer-x64.cc +336 -75
- data/vendor/v8/src/x64/disasm-x64.cc +15 -0
- data/vendor/v8/src/x64/frames-x64.h +0 -14
- data/vendor/v8/src/x64/full-codegen-x64.cc +293 -270
- data/vendor/v8/src/x64/ic-x64.cc +153 -251
- data/vendor/v8/src/x64/lithium-codegen-x64.cc +1379 -531
- data/vendor/v8/src/x64/lithium-codegen-x64.h +67 -23
- data/vendor/v8/src/x64/lithium-gap-resolver-x64.cc +2 -2
- data/vendor/v8/src/x64/lithium-x64.cc +349 -289
- data/vendor/v8/src/x64/lithium-x64.h +460 -250
- data/vendor/v8/src/x64/macro-assembler-x64.cc +350 -177
- data/vendor/v8/src/x64/macro-assembler-x64.h +67 -49
- data/vendor/v8/src/x64/regexp-macro-assembler-x64.cc +46 -33
- data/vendor/v8/src/x64/regexp-macro-assembler-x64.h +2 -3
- data/vendor/v8/src/x64/stub-cache-x64.cc +484 -653
- data/vendor/v8/src/zone-inl.h +9 -27
- data/vendor/v8/src/zone.cc +5 -5
- data/vendor/v8/src/zone.h +53 -27
- data/vendor/v8/test/benchmarks/testcfg.py +5 -0
- data/vendor/v8/test/cctest/cctest.cc +4 -0
- data/vendor/v8/test/cctest/cctest.gyp +3 -1
- data/vendor/v8/test/cctest/cctest.h +57 -9
- data/vendor/v8/test/cctest/cctest.status +15 -15
- data/vendor/v8/test/cctest/test-accessors.cc +26 -0
- data/vendor/v8/test/cctest/test-alloc.cc +22 -30
- data/vendor/v8/test/cctest/test-api.cc +1943 -314
- data/vendor/v8/test/cctest/test-assembler-arm.cc +133 -13
- data/vendor/v8/test/cctest/test-assembler-ia32.cc +1 -1
- data/vendor/v8/test/cctest/test-assembler-mips.cc +12 -0
- data/vendor/v8/test/cctest/test-ast.cc +4 -2
- data/vendor/v8/test/cctest/test-compiler.cc +61 -29
- data/vendor/v8/test/cctest/test-dataflow.cc +2 -2
- data/vendor/v8/test/cctest/test-debug.cc +212 -33
- data/vendor/v8/test/cctest/test-decls.cc +257 -11
- data/vendor/v8/test/cctest/test-dictionary.cc +24 -10
- data/vendor/v8/test/cctest/test-disasm-arm.cc +118 -1
- data/vendor/v8/test/cctest/test-disasm-ia32.cc +3 -2
- data/vendor/v8/test/cctest/test-flags.cc +14 -1
- data/vendor/v8/test/cctest/test-func-name-inference.cc +7 -4
- data/vendor/v8/test/cctest/test-global-object.cc +51 -0
- data/vendor/v8/test/cctest/test-hashing.cc +32 -23
- data/vendor/v8/test/cctest/test-heap-profiler.cc +131 -77
- data/vendor/v8/test/cctest/test-heap.cc +1084 -143
- data/vendor/v8/test/cctest/test-list.cc +1 -1
- data/vendor/v8/test/cctest/test-liveedit.cc +3 -2
- data/vendor/v8/test/cctest/test-lockers.cc +12 -13
- data/vendor/v8/test/cctest/test-log.cc +10 -8
- data/vendor/v8/test/cctest/test-macro-assembler-x64.cc +2 -2
- data/vendor/v8/test/cctest/test-mark-compact.cc +44 -22
- data/vendor/v8/test/cctest/test-object-observe.cc +434 -0
- data/vendor/v8/test/cctest/test-parsing.cc +86 -39
- data/vendor/v8/test/cctest/test-platform-linux.cc +6 -0
- data/vendor/v8/test/cctest/test-platform-win32.cc +7 -0
- data/vendor/v8/test/cctest/test-random.cc +5 -4
- data/vendor/v8/test/cctest/test-regexp.cc +137 -101
- data/vendor/v8/test/cctest/test-serialize.cc +150 -230
- data/vendor/v8/test/cctest/test-sockets.cc +1 -1
- data/vendor/v8/test/cctest/test-spaces.cc +139 -0
- data/vendor/v8/test/cctest/test-strings.cc +736 -74
- data/vendor/v8/test/cctest/test-thread-termination.cc +10 -11
- data/vendor/v8/test/cctest/test-threads.cc +4 -4
- data/vendor/v8/test/cctest/test-utils.cc +16 -0
- data/vendor/v8/test/cctest/test-weakmaps.cc +7 -3
- data/vendor/v8/test/cctest/testcfg.py +64 -5
- data/vendor/v8/test/es5conform/testcfg.py +5 -0
- data/vendor/v8/test/message/message.status +1 -1
- data/vendor/v8/test/message/overwritten-builtins.out +3 -0
- data/vendor/v8/test/message/testcfg.py +89 -8
- data/vendor/v8/test/message/try-catch-finally-no-message.out +26 -26
- data/vendor/v8/test/mjsunit/accessor-map-sharing.js +18 -2
- data/vendor/v8/test/mjsunit/allocation-site-info.js +126 -0
- data/vendor/v8/test/mjsunit/array-bounds-check-removal.js +62 -1
- data/vendor/v8/test/mjsunit/array-iteration.js +1 -1
- data/vendor/v8/test/mjsunit/array-literal-transitions.js +2 -0
- data/vendor/v8/test/mjsunit/array-natives-elements.js +317 -0
- data/vendor/v8/test/mjsunit/array-reduce.js +8 -8
- data/vendor/v8/test/mjsunit/array-slice.js +12 -0
- data/vendor/v8/test/mjsunit/array-store-and-grow.js +4 -1
- data/vendor/v8/test/mjsunit/assert-opt-and-deopt.js +1 -1
- data/vendor/v8/test/mjsunit/bugs/bug-2337.js +53 -0
- data/vendor/v8/test/mjsunit/compare-known-objects-slow.js +69 -0
- data/vendor/v8/test/mjsunit/compiler/alloc-object-huge.js +3 -1
- data/vendor/v8/test/mjsunit/compiler/inline-accessors.js +368 -0
- data/vendor/v8/test/mjsunit/compiler/inline-arguments.js +87 -1
- data/vendor/v8/test/mjsunit/compiler/inline-closures.js +49 -0
- data/vendor/v8/test/mjsunit/compiler/inline-construct.js +55 -43
- data/vendor/v8/test/mjsunit/compiler/inline-literals.js +39 -0
- data/vendor/v8/test/mjsunit/compiler/multiply-add.js +69 -0
- data/vendor/v8/test/mjsunit/compiler/optimized-closures.js +57 -0
- data/vendor/v8/test/mjsunit/compiler/parallel-proto-change.js +44 -0
- data/vendor/v8/test/mjsunit/compiler/property-static.js +69 -0
- data/vendor/v8/test/mjsunit/compiler/proto-chain-constant.js +55 -0
- data/vendor/v8/test/mjsunit/compiler/proto-chain-load.js +44 -0
- data/vendor/v8/test/mjsunit/compiler/regress-gvn.js +3 -2
- data/vendor/v8/test/mjsunit/compiler/regress-or.js +6 -2
- data/vendor/v8/test/mjsunit/compiler/rotate.js +224 -0
- data/vendor/v8/test/mjsunit/compiler/uint32.js +173 -0
- data/vendor/v8/test/mjsunit/count-based-osr.js +2 -1
- data/vendor/v8/test/mjsunit/d8-os.js +3 -3
- data/vendor/v8/test/mjsunit/date-parse.js +3 -0
- data/vendor/v8/test/mjsunit/date.js +22 -0
- data/vendor/v8/test/mjsunit/debug-break-inline.js +1 -0
- data/vendor/v8/test/mjsunit/debug-evaluate-locals-optimized-double.js +22 -12
- data/vendor/v8/test/mjsunit/debug-evaluate-locals-optimized.js +21 -10
- data/vendor/v8/test/mjsunit/debug-liveedit-compile-error.js +60 -0
- data/vendor/v8/test/mjsunit/debug-liveedit-double-call.js +142 -0
- data/vendor/v8/test/mjsunit/debug-liveedit-literals.js +94 -0
- data/vendor/v8/test/mjsunit/debug-liveedit-restart-frame.js +153 -0
- data/vendor/v8/test/mjsunit/debug-multiple-breakpoints.js +1 -1
- data/vendor/v8/test/mjsunit/debug-script-breakpoints-closure.js +67 -0
- data/vendor/v8/test/mjsunit/debug-script-breakpoints-nested.js +82 -0
- data/vendor/v8/test/mjsunit/debug-script.js +4 -2
- data/vendor/v8/test/mjsunit/debug-set-variable-value.js +308 -0
- data/vendor/v8/test/mjsunit/debug-stepout-scope-part1.js +190 -0
- data/vendor/v8/test/mjsunit/debug-stepout-scope-part2.js +83 -0
- data/vendor/v8/test/mjsunit/debug-stepout-scope-part3.js +80 -0
- data/vendor/v8/test/mjsunit/debug-stepout-scope-part4.js +80 -0
- data/vendor/v8/test/mjsunit/debug-stepout-scope-part5.js +77 -0
- data/vendor/v8/test/mjsunit/debug-stepout-scope-part6.js +79 -0
- data/vendor/v8/test/mjsunit/debug-stepout-scope-part7.js +79 -0
- data/vendor/v8/test/mjsunit/{debug-stepout-scope.js → debug-stepout-scope-part8.js} +0 -189
- data/vendor/v8/test/mjsunit/delete-non-configurable.js +74 -0
- data/vendor/v8/test/mjsunit/deopt-minus-zero.js +56 -0
- data/vendor/v8/test/mjsunit/elements-kind.js +6 -4
- data/vendor/v8/test/mjsunit/elements-length-no-holey.js +33 -0
- data/vendor/v8/test/mjsunit/elements-transition-hoisting.js +46 -19
- data/vendor/v8/test/mjsunit/error-accessors.js +54 -0
- data/vendor/v8/test/mjsunit/error-constructors.js +1 -14
- data/vendor/v8/test/mjsunit/error-tostring.js +8 -0
- data/vendor/v8/test/mjsunit/eval-stack-trace.js +204 -0
- data/vendor/v8/test/mjsunit/external-array.js +364 -1
- data/vendor/v8/test/mjsunit/fast-array-length.js +37 -0
- data/vendor/v8/test/mjsunit/fast-non-keyed.js +113 -0
- data/vendor/v8/test/mjsunit/fast-prototype.js +117 -0
- data/vendor/v8/test/mjsunit/function-call.js +14 -18
- data/vendor/v8/test/mjsunit/fuzz-natives-part1.js +230 -0
- data/vendor/v8/test/mjsunit/fuzz-natives-part2.js +229 -0
- data/vendor/v8/test/mjsunit/fuzz-natives-part3.js +229 -0
- data/vendor/v8/test/mjsunit/{fuzz-natives.js → fuzz-natives-part4.js} +12 -2
- data/vendor/v8/test/mjsunit/generated-transition-stub.js +218 -0
- data/vendor/v8/test/mjsunit/greedy.js +1 -1
- data/vendor/v8/test/mjsunit/harmony/block-conflicts.js +2 -1
- data/vendor/v8/test/mjsunit/harmony/block-let-crankshaft.js +1 -1
- data/vendor/v8/test/mjsunit/harmony/collections.js +69 -11
- data/vendor/v8/test/mjsunit/harmony/debug-blockscopes.js +2 -2
- data/vendor/v8/test/mjsunit/harmony/module-linking.js +180 -3
- data/vendor/v8/test/mjsunit/harmony/module-parsing.js +31 -0
- data/vendor/v8/test/mjsunit/harmony/module-recompile.js +87 -0
- data/vendor/v8/test/mjsunit/harmony/module-resolution.js +15 -2
- data/vendor/v8/test/mjsunit/harmony/object-observe.js +1056 -0
- data/vendor/v8/test/mjsunit/harmony/proxies-json.js +178 -0
- data/vendor/v8/test/mjsunit/harmony/proxies.js +25 -10
- data/vendor/v8/test/mjsunit/json-parser-recursive.js +33 -0
- data/vendor/v8/test/mjsunit/json-stringify-recursive.js +52 -0
- data/vendor/v8/test/mjsunit/json.js +38 -2
- data/vendor/v8/test/mjsunit/json2.js +153 -0
- data/vendor/v8/test/mjsunit/limit-locals.js +5 -4
- data/vendor/v8/test/mjsunit/manual-parallel-recompile.js +79 -0
- data/vendor/v8/test/mjsunit/math-exp-precision.js +64 -0
- data/vendor/v8/test/mjsunit/math-floor-negative.js +59 -0
- data/vendor/v8/test/mjsunit/math-floor-of-div-minus-zero.js +41 -0
- data/vendor/v8/test/mjsunit/math-floor-of-div-nosudiv.js +288 -0
- data/vendor/v8/test/mjsunit/math-floor-of-div.js +81 -9
- data/vendor/v8/test/mjsunit/{math-floor.js → math-floor-part1.js} +1 -72
- data/vendor/v8/test/mjsunit/math-floor-part2.js +76 -0
- data/vendor/v8/test/mjsunit/math-floor-part3.js +78 -0
- data/vendor/v8/test/mjsunit/math-floor-part4.js +76 -0
- data/vendor/v8/test/mjsunit/mirror-object.js +43 -9
- data/vendor/v8/test/mjsunit/mjsunit.js +1 -1
- data/vendor/v8/test/mjsunit/mjsunit.status +52 -27
- data/vendor/v8/test/mjsunit/mul-exhaustive-part1.js +491 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part10.js +470 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part2.js +525 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part3.js +532 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part4.js +509 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part5.js +505 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part6.js +554 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part7.js +497 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part8.js +526 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part9.js +533 -0
- data/vendor/v8/test/mjsunit/new-function.js +34 -0
- data/vendor/v8/test/mjsunit/numops-fuzz-part1.js +1172 -0
- data/vendor/v8/test/mjsunit/numops-fuzz-part2.js +1178 -0
- data/vendor/v8/test/mjsunit/numops-fuzz-part3.js +1178 -0
- data/vendor/v8/test/mjsunit/numops-fuzz-part4.js +1177 -0
- data/vendor/v8/test/mjsunit/object-define-property.js +107 -2
- data/vendor/v8/test/mjsunit/override-read-only-property.js +6 -4
- data/vendor/v8/test/mjsunit/packed-elements.js +2 -2
- data/vendor/v8/test/mjsunit/parse-int-float.js +4 -4
- data/vendor/v8/test/mjsunit/pixel-array-rounding.js +1 -1
- data/vendor/v8/test/mjsunit/readonly.js +228 -0
- data/vendor/v8/test/mjsunit/regexp-capture-3.js +16 -18
- data/vendor/v8/test/mjsunit/regexp-capture.js +2 -0
- data/vendor/v8/test/mjsunit/regexp-global.js +122 -0
- data/vendor/v8/test/mjsunit/regexp-results-cache.js +78 -0
- data/vendor/v8/test/mjsunit/regress/regress-1117.js +12 -3
- data/vendor/v8/test/mjsunit/regress/regress-1118.js +1 -1
- data/vendor/v8/test/mjsunit/regress/regress-115100.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-1199637.js +1 -3
- data/vendor/v8/test/mjsunit/regress/regress-121407.js +1 -1
- data/vendor/v8/test/mjsunit/regress/regress-131923.js +30 -0
- data/vendor/v8/test/mjsunit/regress/regress-131994.js +70 -0
- data/vendor/v8/test/mjsunit/regress/regress-133211.js +35 -0
- data/vendor/v8/test/mjsunit/regress/regress-133211b.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-136048.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-137768.js +73 -0
- data/vendor/v8/test/mjsunit/regress/regress-143967.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-145201.js +107 -0
- data/vendor/v8/test/mjsunit/regress/regress-147497.js +45 -0
- data/vendor/v8/test/mjsunit/regress/regress-148378.js +38 -0
- data/vendor/v8/test/mjsunit/regress/regress-1563.js +1 -1
- data/vendor/v8/test/mjsunit/regress/regress-1591.js +48 -0
- data/vendor/v8/test/mjsunit/regress/regress-164442.js +45 -0
- data/vendor/v8/test/mjsunit/regress/regress-165637.js +61 -0
- data/vendor/v8/test/mjsunit/regress/regress-166379.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-166553.js +33 -0
- data/vendor/v8/test/mjsunit/regress/regress-1692.js +1 -1
- data/vendor/v8/test/mjsunit/regress/regress-171641.js +40 -0
- data/vendor/v8/test/mjsunit/regress/regress-1980.js +1 -1
- data/vendor/v8/test/mjsunit/regress/regress-2073.js +99 -0
- data/vendor/v8/test/mjsunit/regress/regress-2119.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-2156.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-2163.js +70 -0
- data/vendor/v8/test/mjsunit/regress/regress-2170.js +58 -0
- data/vendor/v8/test/mjsunit/regress/regress-2172.js +35 -0
- data/vendor/v8/test/mjsunit/regress/regress-2185-2.js +145 -0
- data/vendor/v8/test/mjsunit/regress/regress-2185.js +38 -0
- data/vendor/v8/test/mjsunit/regress/regress-2186.js +49 -0
- data/vendor/v8/test/mjsunit/regress/regress-2193.js +58 -0
- data/vendor/v8/test/mjsunit/regress/regress-2219.js +32 -0
- data/vendor/v8/test/mjsunit/regress/regress-2225.js +65 -0
- data/vendor/v8/test/mjsunit/regress/regress-2226.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-2234.js +41 -0
- data/vendor/v8/test/mjsunit/regress/regress-2243.js +31 -0
- data/vendor/v8/test/mjsunit/regress/regress-2249.js +33 -0
- data/vendor/v8/test/mjsunit/regress/regress-2250.js +68 -0
- data/vendor/v8/test/mjsunit/regress/regress-2261.js +113 -0
- data/vendor/v8/test/mjsunit/regress/regress-2263.js +30 -0
- data/vendor/v8/test/mjsunit/regress/regress-2284.js +32 -0
- data/vendor/v8/test/mjsunit/regress/regress-2285.js +32 -0
- data/vendor/v8/test/mjsunit/regress/regress-2286.js +32 -0
- data/vendor/v8/test/mjsunit/regress/regress-2289.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-2291.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-2294.js +70 -0
- data/vendor/v8/test/mjsunit/regress/regress-2296.js +40 -0
- data/vendor/v8/test/mjsunit/regress/regress-2315.js +40 -0
- data/vendor/v8/test/mjsunit/regress/regress-2318.js +66 -0
- data/vendor/v8/test/mjsunit/regress/regress-2322.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-2326.js +54 -0
- data/vendor/v8/test/mjsunit/regress/regress-2336.js +53 -0
- data/vendor/v8/test/mjsunit/regress/regress-2339.js +59 -0
- data/vendor/v8/test/mjsunit/regress/regress-2346.js +123 -0
- data/vendor/v8/test/mjsunit/regress/regress-2373.js +29 -0
- data/vendor/v8/test/mjsunit/regress/regress-2374.js +33 -0
- data/vendor/v8/test/mjsunit/regress/regress-2398.js +41 -0
- data/vendor/v8/test/mjsunit/regress/regress-2410.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-2416.js +75 -0
- data/vendor/v8/test/mjsunit/regress/regress-2419.js +37 -0
- data/vendor/v8/test/mjsunit/regress/regress-2433.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-2437.js +156 -0
- data/vendor/v8/test/mjsunit/regress/regress-2438.js +52 -0
- data/vendor/v8/test/mjsunit/regress/regress-2443.js +129 -0
- data/vendor/v8/test/mjsunit/regress/regress-2444.js +120 -0
- data/vendor/v8/test/mjsunit/regress/regress-2489.js +50 -0
- data/vendor/v8/test/mjsunit/regress/regress-2499.js +40 -0
- data/vendor/v8/test/mjsunit/regress/regress-334.js +1 -1
- data/vendor/v8/test/mjsunit/regress/regress-492.js +39 -1
- data/vendor/v8/test/mjsunit/regress/regress-builtin-array-op.js +38 -0
- data/vendor/v8/test/mjsunit/regress/regress-cnlt-elements.js +43 -0
- data/vendor/v8/test/mjsunit/regress/regress-cnlt-enum-indices.js +45 -0
- data/vendor/v8/test/mjsunit/regress/regress-cntl-descriptors-enum.js +46 -0
- data/vendor/v8/test/mjsunit/regress/regress-convert-enum.js +60 -0
- data/vendor/v8/test/mjsunit/regress/regress-convert-enum2.js +46 -0
- data/vendor/v8/test/mjsunit/regress/regress-convert-transition.js +40 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-119926.js +3 -1
- data/vendor/v8/test/mjsunit/regress/regress-crbug-125148.js +90 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-134055.js +63 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-134609.js +59 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-135008.js +45 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-135066.js +55 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-137689.js +47 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-138887.js +48 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-140083.js +44 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-142087.js +38 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-142218.js +44 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-145961.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-146910.js +33 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-147475.js +48 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-148376.js +35 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-150545.js +53 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-150729.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-157019.js +54 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-157520.js +38 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-158185.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-160010.js +35 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-162085.js +71 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-168545.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-170856.js +33 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-172345.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-173974.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-18639.js +9 -5
- data/vendor/v8/test/mjsunit/regress/regress-debug-code-recompilation.js +2 -1
- data/vendor/v8/test/mjsunit/regress/regress-deep-proto.js +45 -0
- data/vendor/v8/test/mjsunit/regress/regress-delete-empty-double.js +40 -0
- data/vendor/v8/test/mjsunit/regress/regress-iteration-order.js +42 -0
- data/vendor/v8/test/mjsunit/regress/regress-json-stringify-gc.js +41 -0
- data/vendor/v8/test/mjsunit/regress/regress-latin-1.js +78 -0
- data/vendor/v8/test/mjsunit/regress/regress-load-elements.js +49 -0
- data/vendor/v8/test/mjsunit/regress/regress-observe-empty-double-array.js +38 -0
- data/vendor/v8/test/mjsunit/regress/regress-undefined-store-keyed-fast-element.js +37 -0
- data/vendor/v8/test/mjsunit/shift-for-integer-div.js +59 -0
- data/vendor/v8/test/mjsunit/stack-traces-gc.js +119 -0
- data/vendor/v8/test/mjsunit/stack-traces-overflow.js +122 -0
- data/vendor/v8/test/mjsunit/stack-traces.js +39 -1
- data/vendor/v8/test/mjsunit/str-to-num.js +7 -2
- data/vendor/v8/test/mjsunit/strict-mode.js +36 -11
- data/vendor/v8/test/mjsunit/string-charcodeat.js +3 -0
- data/vendor/v8/test/mjsunit/string-natives.js +72 -0
- data/vendor/v8/test/mjsunit/string-split.js +17 -0
- data/vendor/v8/test/mjsunit/testcfg.py +76 -6
- data/vendor/v8/test/mjsunit/tools/tickprocessor.js +4 -1
- data/vendor/v8/test/mjsunit/try-finally-continue.js +72 -0
- data/vendor/v8/test/mjsunit/typed-array-slice.js +61 -0
- data/vendor/v8/test/mjsunit/unbox-double-arrays.js +2 -0
- data/vendor/v8/test/mjsunit/uri.js +12 -0
- data/vendor/v8/test/mjsunit/with-readonly.js +4 -2
- data/vendor/v8/test/mozilla/mozilla.status +19 -113
- data/vendor/v8/test/mozilla/testcfg.py +122 -3
- data/vendor/v8/test/preparser/preparser.status +5 -0
- data/vendor/v8/test/preparser/strict-identifiers.pyt +1 -1
- data/vendor/v8/test/preparser/testcfg.py +101 -5
- data/vendor/v8/test/sputnik/sputnik.status +1 -1
- data/vendor/v8/test/sputnik/testcfg.py +5 -0
- data/vendor/v8/test/test262/README +2 -2
- data/vendor/v8/test/test262/test262.status +13 -36
- data/vendor/v8/test/test262/testcfg.py +102 -8
- data/vendor/v8/tools/android-build.sh +0 -0
- data/vendor/v8/tools/android-ll-prof.sh +69 -0
- data/vendor/v8/tools/android-run.py +109 -0
- data/vendor/v8/tools/android-sync.sh +105 -0
- data/vendor/v8/tools/bash-completion.sh +0 -0
- data/vendor/v8/tools/check-static-initializers.sh +0 -0
- data/vendor/v8/tools/common-includes.sh +15 -22
- data/vendor/v8/tools/disasm.py +4 -4
- data/vendor/v8/tools/fuzz-harness.sh +0 -0
- data/vendor/v8/tools/gen-postmortem-metadata.py +6 -8
- data/vendor/v8/tools/grokdump.py +404 -129
- data/vendor/v8/tools/gyp/v8.gyp +105 -43
- data/vendor/v8/tools/linux-tick-processor +5 -5
- data/vendor/v8/tools/ll_prof.py +75 -15
- data/vendor/v8/tools/merge-to-branch.sh +2 -2
- data/vendor/v8/tools/plot-timer-events +70 -0
- data/vendor/v8/tools/plot-timer-events.js +510 -0
- data/vendor/v8/tools/presubmit.py +1 -0
- data/vendor/v8/tools/push-to-trunk.sh +14 -4
- data/vendor/v8/tools/run-llprof.sh +69 -0
- data/vendor/v8/tools/run-tests.py +372 -0
- data/vendor/v8/tools/run-valgrind.py +1 -1
- data/vendor/v8/tools/status-file-converter.py +39 -0
- data/vendor/v8/tools/test-server.py +224 -0
- data/vendor/v8/tools/test-wrapper-gypbuild.py +13 -16
- data/vendor/v8/tools/test.py +10 -19
- data/vendor/v8/tools/testrunner/README +174 -0
- data/vendor/v8/tools/testrunner/__init__.py +26 -0
- data/vendor/v8/tools/testrunner/local/__init__.py +26 -0
- data/vendor/v8/tools/testrunner/local/commands.py +153 -0
- data/vendor/v8/tools/testrunner/local/execution.py +182 -0
- data/vendor/v8/tools/testrunner/local/old_statusfile.py +460 -0
- data/vendor/v8/tools/testrunner/local/progress.py +238 -0
- data/vendor/v8/tools/testrunner/local/statusfile.py +145 -0
- data/vendor/v8/tools/testrunner/local/testsuite.py +187 -0
- data/vendor/v8/tools/testrunner/local/utils.py +108 -0
- data/vendor/v8/tools/testrunner/local/verbose.py +99 -0
- data/vendor/v8/tools/testrunner/network/__init__.py +26 -0
- data/vendor/v8/tools/testrunner/network/distro.py +90 -0
- data/vendor/v8/tools/testrunner/network/endpoint.py +124 -0
- data/vendor/v8/tools/testrunner/network/network_execution.py +253 -0
- data/vendor/v8/tools/testrunner/network/perfdata.py +120 -0
- data/vendor/v8/tools/testrunner/objects/__init__.py +26 -0
- data/vendor/v8/tools/testrunner/objects/context.py +50 -0
- data/vendor/v8/tools/testrunner/objects/output.py +60 -0
- data/vendor/v8/tools/testrunner/objects/peer.py +80 -0
- data/vendor/v8/tools/testrunner/objects/testcase.py +83 -0
- data/vendor/v8/tools/testrunner/objects/workpacket.py +90 -0
- data/vendor/v8/tools/testrunner/server/__init__.py +26 -0
- data/vendor/v8/tools/testrunner/server/compression.py +111 -0
- data/vendor/v8/tools/testrunner/server/constants.py +51 -0
- data/vendor/v8/tools/testrunner/server/daemon.py +147 -0
- data/vendor/v8/tools/testrunner/server/local_handler.py +119 -0
- data/vendor/v8/tools/testrunner/server/main.py +245 -0
- data/vendor/v8/tools/testrunner/server/presence_handler.py +120 -0
- data/vendor/v8/tools/testrunner/server/signatures.py +63 -0
- data/vendor/v8/tools/testrunner/server/status_handler.py +112 -0
- data/vendor/v8/tools/testrunner/server/work_handler.py +150 -0
- data/vendor/v8/tools/tick-processor.html +168 -0
- data/vendor/v8/tools/tickprocessor-driver.js +5 -3
- data/vendor/v8/tools/tickprocessor.js +58 -15
- metadata +534 -30
- data/patches/add-freebsd9-and-freebsd10-to-gyp-GetFlavor.patch +0 -11
- data/patches/do-not-imply-vfp3-and-armv7.patch +0 -44
- data/patches/fPIC-on-x64.patch +0 -14
- data/vendor/v8/src/liveobjectlist-inl.h +0 -126
- data/vendor/v8/src/liveobjectlist.cc +0 -2631
- data/vendor/v8/src/liveobjectlist.h +0 -319
- data/vendor/v8/test/mjsunit/mul-exhaustive.js +0 -4629
- data/vendor/v8/test/mjsunit/numops-fuzz.js +0 -4609
- data/vendor/v8/test/mjsunit/regress/regress-1969.js +0 -5045
@@ -1,4 +1,4 @@
|
|
1
|
-
// Copyright
|
1
|
+
// Copyright 2010 the V8 project authors. All rights reserved.
|
2
2
|
// Redistribution and use in source and binary forms, with or without
|
3
3
|
// modification, are permitted provided that the following conditions are
|
4
4
|
// met:
|
@@ -25,36 +25,25 @@
|
|
25
25
|
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
26
26
|
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
27
27
|
|
28
|
-
|
29
|
-
#
|
30
|
-
#define V8_INSPECTOR_H_
|
31
|
-
|
32
|
-
// Only build this code if we're configured with the INSPECTOR.
|
33
|
-
#ifdef INSPECTOR
|
28
|
+
#ifndef V8_EXTENSIONS_STATISTICS_EXTENSION_H_
|
29
|
+
#define V8_EXTENSIONS_STATISTICS_EXTENSION_H_
|
34
30
|
|
35
31
|
#include "v8.h"
|
36
32
|
|
37
|
-
#include "objects.h"
|
38
|
-
|
39
33
|
namespace v8 {
|
40
34
|
namespace internal {
|
41
35
|
|
42
|
-
class
|
36
|
+
class StatisticsExtension : public v8::Extension {
|
43
37
|
public:
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
static void
|
49
|
-
|
50
|
-
|
51
|
-
static void DumpObjectType(Object* obj) {
|
52
|
-
DumpObjectType(stdout, obj, false);
|
53
|
-
}
|
38
|
+
StatisticsExtension() : v8::Extension("v8/statistics", kSource) {}
|
39
|
+
virtual v8::Handle<v8::FunctionTemplate> GetNativeFunction(
|
40
|
+
v8::Handle<v8::String> name);
|
41
|
+
static v8::Handle<v8::Value> GetCounters(const v8::Arguments& args);
|
42
|
+
static void Register();
|
43
|
+
private:
|
44
|
+
static const char* const kSource;
|
54
45
|
};
|
55
46
|
|
56
47
|
} } // namespace v8::internal
|
57
48
|
|
58
|
-
#endif //
|
59
|
-
|
60
|
-
#endif // V8_INSPECTOR_H_
|
49
|
+
#endif // V8_EXTENSIONS_STATISTICS_EXTENSION_H_
|
data/vendor/v8/src/factory.cc
CHANGED
@@ -112,10 +112,11 @@ Handle<ObjectHashTable> Factory::NewObjectHashTable(int at_least_space_for) {
|
|
112
112
|
}
|
113
113
|
|
114
114
|
|
115
|
-
Handle<DescriptorArray> Factory::NewDescriptorArray(int number_of_descriptors
|
115
|
+
Handle<DescriptorArray> Factory::NewDescriptorArray(int number_of_descriptors,
|
116
|
+
int slack) {
|
116
117
|
ASSERT(0 <= number_of_descriptors);
|
117
118
|
CALL_HEAP_FUNCTION(isolate(),
|
118
|
-
DescriptorArray::Allocate(number_of_descriptors),
|
119
|
+
DescriptorArray::Allocate(number_of_descriptors, slack),
|
119
120
|
DescriptorArray);
|
120
121
|
}
|
121
122
|
|
@@ -157,9 +158,9 @@ Handle<TypeFeedbackInfo> Factory::NewTypeFeedbackInfo() {
|
|
157
158
|
|
158
159
|
|
159
160
|
// Symbols are created in the old generation (data space).
|
160
|
-
Handle<String> Factory::
|
161
|
+
Handle<String> Factory::LookupUtf8Symbol(Vector<const char> string) {
|
161
162
|
CALL_HEAP_FUNCTION(isolate(),
|
162
|
-
isolate()->heap()->
|
163
|
+
isolate()->heap()->LookupUtf8Symbol(string),
|
163
164
|
String);
|
164
165
|
}
|
165
166
|
|
@@ -170,18 +171,18 @@ Handle<String> Factory::LookupSymbol(Handle<String> string) {
|
|
170
171
|
String);
|
171
172
|
}
|
172
173
|
|
173
|
-
Handle<String> Factory::
|
174
|
+
Handle<String> Factory::LookupOneByteSymbol(Vector<const uint8_t> string) {
|
174
175
|
CALL_HEAP_FUNCTION(isolate(),
|
175
|
-
isolate()->heap()->
|
176
|
+
isolate()->heap()->LookupOneByteSymbol(string),
|
176
177
|
String);
|
177
178
|
}
|
178
179
|
|
179
180
|
|
180
|
-
Handle<String> Factory::
|
181
|
+
Handle<String> Factory::LookupOneByteSymbol(Handle<SeqOneByteString> string,
|
181
182
|
int from,
|
182
183
|
int length) {
|
183
184
|
CALL_HEAP_FUNCTION(isolate(),
|
184
|
-
isolate()->heap()->
|
185
|
+
isolate()->heap()->LookupOneByteSymbol(string,
|
185
186
|
from,
|
186
187
|
length),
|
187
188
|
String);
|
@@ -195,11 +196,11 @@ Handle<String> Factory::LookupTwoByteSymbol(Vector<const uc16> string) {
|
|
195
196
|
}
|
196
197
|
|
197
198
|
|
198
|
-
Handle<String> Factory::
|
199
|
-
|
199
|
+
Handle<String> Factory::NewStringFromOneByte(Vector<const uint8_t> string,
|
200
|
+
PretenureFlag pretenure) {
|
200
201
|
CALL_HEAP_FUNCTION(
|
201
202
|
isolate(),
|
202
|
-
isolate()->heap()->
|
203
|
+
isolate()->heap()->AllocateStringFromOneByte(string, pretenure),
|
203
204
|
String);
|
204
205
|
}
|
205
206
|
|
@@ -221,12 +222,12 @@ Handle<String> Factory::NewStringFromTwoByte(Vector<const uc16> string,
|
|
221
222
|
}
|
222
223
|
|
223
224
|
|
224
|
-
Handle<
|
225
|
+
Handle<SeqOneByteString> Factory::NewRawOneByteString(int length,
|
225
226
|
PretenureFlag pretenure) {
|
226
227
|
CALL_HEAP_FUNCTION(
|
227
228
|
isolate(),
|
228
|
-
isolate()->heap()->
|
229
|
-
|
229
|
+
isolate()->heap()->AllocateRawOneByteString(length, pretenure),
|
230
|
+
SeqOneByteString);
|
230
231
|
}
|
231
232
|
|
232
233
|
|
@@ -284,19 +285,27 @@ Handle<String> Factory::NewExternalStringFromTwoByte(
|
|
284
285
|
}
|
285
286
|
|
286
287
|
|
287
|
-
Handle<Context> Factory::
|
288
|
+
Handle<Context> Factory::NewNativeContext() {
|
288
289
|
CALL_HEAP_FUNCTION(
|
289
290
|
isolate(),
|
290
|
-
isolate()->heap()->
|
291
|
+
isolate()->heap()->AllocateNativeContext(),
|
291
292
|
Context);
|
292
293
|
}
|
293
294
|
|
294
295
|
|
295
|
-
Handle<Context> Factory::
|
296
|
+
Handle<Context> Factory::NewGlobalContext(Handle<JSFunction> function,
|
296
297
|
Handle<ScopeInfo> scope_info) {
|
297
298
|
CALL_HEAP_FUNCTION(
|
298
299
|
isolate(),
|
299
|
-
isolate()->heap()->
|
300
|
+
isolate()->heap()->AllocateGlobalContext(*function, *scope_info),
|
301
|
+
Context);
|
302
|
+
}
|
303
|
+
|
304
|
+
|
305
|
+
Handle<Context> Factory::NewModuleContext(Handle<ScopeInfo> scope_info) {
|
306
|
+
CALL_HEAP_FUNCTION(
|
307
|
+
isolate(),
|
308
|
+
isolate()->heap()->AllocateModuleContext(*scope_info),
|
300
309
|
Context);
|
301
310
|
}
|
302
311
|
|
@@ -465,14 +474,15 @@ Handle<JSObject> Factory::NewFunctionPrototype(Handle<JSFunction> function) {
|
|
465
474
|
}
|
466
475
|
|
467
476
|
|
468
|
-
Handle<Map> Factory::
|
469
|
-
CALL_HEAP_FUNCTION(
|
477
|
+
Handle<Map> Factory::CopyWithPreallocatedFieldDescriptors(Handle<Map> src) {
|
478
|
+
CALL_HEAP_FUNCTION(
|
479
|
+
isolate(), src->CopyWithPreallocatedFieldDescriptors(), Map);
|
470
480
|
}
|
471
481
|
|
472
482
|
|
473
483
|
Handle<Map> Factory::CopyMap(Handle<Map> src,
|
474
484
|
int extra_inobject_properties) {
|
475
|
-
Handle<Map> copy =
|
485
|
+
Handle<Map> copy = CopyWithPreallocatedFieldDescriptors(src);
|
476
486
|
// Check that we do not overflow the instance size when adding the
|
477
487
|
// extra inobject properties.
|
478
488
|
int instance_size_delta = extra_inobject_properties * kPointerSize;
|
@@ -495,8 +505,8 @@ Handle<Map> Factory::CopyMap(Handle<Map> src,
|
|
495
505
|
}
|
496
506
|
|
497
507
|
|
498
|
-
Handle<Map> Factory::
|
499
|
-
CALL_HEAP_FUNCTION(isolate(), src->
|
508
|
+
Handle<Map> Factory::CopyMap(Handle<Map> src) {
|
509
|
+
CALL_HEAP_FUNCTION(isolate(), src->Copy(), Map);
|
500
510
|
}
|
501
511
|
|
502
512
|
|
@@ -515,6 +525,12 @@ Handle<FixedArray> Factory::CopyFixedArray(Handle<FixedArray> array) {
|
|
515
525
|
}
|
516
526
|
|
517
527
|
|
528
|
+
Handle<FixedArray> Factory::CopySizeFixedArray(Handle<FixedArray> array,
|
529
|
+
int new_length) {
|
530
|
+
CALL_HEAP_FUNCTION(isolate(), array->CopySize(new_length), FixedArray);
|
531
|
+
}
|
532
|
+
|
533
|
+
|
518
534
|
Handle<FixedDoubleArray> Factory::CopyFixedDoubleArray(
|
519
535
|
Handle<FixedDoubleArray> array) {
|
520
536
|
CALL_HEAP_FUNCTION(isolate(), array->Copy(), FixedDoubleArray);
|
@@ -551,18 +567,27 @@ Handle<JSFunction> Factory::NewFunctionFromSharedFunctionInfo(
|
|
551
567
|
}
|
552
568
|
|
553
569
|
result->set_context(*context);
|
554
|
-
|
570
|
+
|
571
|
+
int index = function_info->SearchOptimizedCodeMap(context->native_context());
|
572
|
+
if (!function_info->bound() && index < 0) {
|
555
573
|
int number_of_literals = function_info->num_literals();
|
556
574
|
Handle<FixedArray> literals = NewFixedArray(number_of_literals, pretenure);
|
557
575
|
if (number_of_literals > 0) {
|
558
|
-
// Store the
|
559
|
-
//
|
560
|
-
//
|
561
|
-
literals->set(JSFunction::
|
562
|
-
context->
|
576
|
+
// Store the native context in the literals array prefix. This
|
577
|
+
// context will be used when creating object, regexp and array
|
578
|
+
// literals in this function.
|
579
|
+
literals->set(JSFunction::kLiteralNativeContextIndex,
|
580
|
+
context->native_context());
|
563
581
|
}
|
564
582
|
result->set_literals(*literals);
|
565
583
|
}
|
584
|
+
|
585
|
+
if (index > 0) {
|
586
|
+
// Caching of optimized code enabled and optimized code found.
|
587
|
+
function_info->InstallFromOptimizedCodeMap(*result, index);
|
588
|
+
return result;
|
589
|
+
}
|
590
|
+
|
566
591
|
if (V8::UseCrankshaft() &&
|
567
592
|
FLAG_always_opt &&
|
568
593
|
result->is_compiled() &&
|
@@ -696,7 +721,7 @@ Handle<String> Factory::EmergencyNewError(const char* type,
|
|
696
721
|
MaybeObject* maybe_arg = args->GetElement(i);
|
697
722
|
Handle<String> arg_str(reinterpret_cast<String*>(maybe_arg));
|
698
723
|
const char* arg = *arg_str->ToCString();
|
699
|
-
Vector<char> v2(p, space);
|
724
|
+
Vector<char> v2(p, static_cast<int>(space));
|
700
725
|
OS::StrNCpy(v2, arg, space);
|
701
726
|
space -= Min(space, strlen(arg));
|
702
727
|
p = &buffer[kBufferSize] - space;
|
@@ -716,7 +741,7 @@ Handle<String> Factory::EmergencyNewError(const char* type,
|
|
716
741
|
Handle<Object> Factory::NewError(const char* maker,
|
717
742
|
const char* type,
|
718
743
|
Handle<JSArray> args) {
|
719
|
-
Handle<String> make_str =
|
744
|
+
Handle<String> make_str = LookupUtf8Symbol(maker);
|
720
745
|
Handle<Object> fun_obj(
|
721
746
|
isolate()->js_builtins_object()->GetPropertyNoExceptionThrown(*make_str));
|
722
747
|
// If the builtins haven't been properly configured yet this error
|
@@ -725,7 +750,7 @@ Handle<Object> Factory::NewError(const char* maker,
|
|
725
750
|
return EmergencyNewError(type, args);
|
726
751
|
}
|
727
752
|
Handle<JSFunction> fun = Handle<JSFunction>::cast(fun_obj);
|
728
|
-
Handle<Object> type_obj =
|
753
|
+
Handle<Object> type_obj = LookupUtf8Symbol(type);
|
729
754
|
Handle<Object> argv[] = { type_obj, args };
|
730
755
|
|
731
756
|
// Invoke the JavaScript factory method. If an exception is thrown while
|
@@ -747,7 +772,7 @@ Handle<Object> Factory::NewError(Handle<String> message) {
|
|
747
772
|
|
748
773
|
Handle<Object> Factory::NewError(const char* constructor,
|
749
774
|
Handle<String> message) {
|
750
|
-
Handle<String> constr =
|
775
|
+
Handle<String> constr = LookupUtf8Symbol(constructor);
|
751
776
|
Handle<JSFunction> fun = Handle<JSFunction>(
|
752
777
|
JSFunction::cast(isolate()->js_builtins_object()->
|
753
778
|
GetPropertyNoExceptionThrown(*constr)));
|
@@ -851,6 +876,13 @@ Handle<ScopeInfo> Factory::NewScopeInfo(int length) {
|
|
851
876
|
}
|
852
877
|
|
853
878
|
|
879
|
+
Handle<JSObject> Factory::NewExternal(void* value) {
|
880
|
+
CALL_HEAP_FUNCTION(isolate(),
|
881
|
+
isolate()->heap()->AllocateExternal(value),
|
882
|
+
JSObject);
|
883
|
+
}
|
884
|
+
|
885
|
+
|
854
886
|
Handle<Code> Factory::NewCode(const CodeDesc& desc,
|
855
887
|
Code::Flags flags,
|
856
888
|
Handle<Object> self_ref,
|
@@ -876,97 +908,12 @@ Handle<Code> Factory::CopyCode(Handle<Code> code, Vector<byte> reloc_info) {
|
|
876
908
|
}
|
877
909
|
|
878
910
|
|
879
|
-
MUST_USE_RESULT static inline MaybeObject* DoCopyInsert(
|
880
|
-
DescriptorArray* array,
|
881
|
-
String* key,
|
882
|
-
Object* value,
|
883
|
-
PropertyAttributes attributes) {
|
884
|
-
CallbacksDescriptor desc(key, value, attributes);
|
885
|
-
MaybeObject* obj = array->CopyInsert(&desc, REMOVE_TRANSITIONS);
|
886
|
-
return obj;
|
887
|
-
}
|
888
|
-
|
889
|
-
|
890
|
-
// Allocate the new array.
|
891
|
-
Handle<DescriptorArray> Factory::CopyAppendForeignDescriptor(
|
892
|
-
Handle<DescriptorArray> array,
|
893
|
-
Handle<String> key,
|
894
|
-
Handle<Object> value,
|
895
|
-
PropertyAttributes attributes) {
|
896
|
-
CALL_HEAP_FUNCTION(isolate(),
|
897
|
-
DoCopyInsert(*array, *key, *value, attributes),
|
898
|
-
DescriptorArray);
|
899
|
-
}
|
900
|
-
|
901
|
-
|
902
911
|
Handle<String> Factory::SymbolFromString(Handle<String> value) {
|
903
912
|
CALL_HEAP_FUNCTION(isolate(),
|
904
913
|
isolate()->heap()->LookupSymbol(*value), String);
|
905
914
|
}
|
906
915
|
|
907
916
|
|
908
|
-
Handle<DescriptorArray> Factory::CopyAppendCallbackDescriptors(
|
909
|
-
Handle<DescriptorArray> array,
|
910
|
-
Handle<Object> descriptors) {
|
911
|
-
v8::NeanderArray callbacks(descriptors);
|
912
|
-
int nof_callbacks = callbacks.length();
|
913
|
-
Handle<DescriptorArray> result =
|
914
|
-
NewDescriptorArray(array->number_of_descriptors() + nof_callbacks);
|
915
|
-
|
916
|
-
// Number of descriptors added to the result so far.
|
917
|
-
int descriptor_count = 0;
|
918
|
-
|
919
|
-
// Ensure that marking will not progress and change color of objects.
|
920
|
-
DescriptorArray::WhitenessWitness witness(*result);
|
921
|
-
|
922
|
-
// Copy the descriptors from the array.
|
923
|
-
for (int i = 0; i < array->number_of_descriptors(); i++) {
|
924
|
-
if (!array->IsNullDescriptor(i)) {
|
925
|
-
DescriptorArray::CopyFrom(result, descriptor_count++, array, i, witness);
|
926
|
-
}
|
927
|
-
}
|
928
|
-
|
929
|
-
// Number of duplicates detected.
|
930
|
-
int duplicates = 0;
|
931
|
-
|
932
|
-
// Fill in new callback descriptors. Process the callbacks from
|
933
|
-
// back to front so that the last callback with a given name takes
|
934
|
-
// precedence over previously added callbacks with that name.
|
935
|
-
for (int i = nof_callbacks - 1; i >= 0; i--) {
|
936
|
-
Handle<AccessorInfo> entry =
|
937
|
-
Handle<AccessorInfo>(AccessorInfo::cast(callbacks.get(i)));
|
938
|
-
// Ensure the key is a symbol before writing into the instance descriptor.
|
939
|
-
Handle<String> key =
|
940
|
-
SymbolFromString(Handle<String>(String::cast(entry->name())));
|
941
|
-
// Check if a descriptor with this name already exists before writing.
|
942
|
-
if (result->LinearSearch(*key, descriptor_count) ==
|
943
|
-
DescriptorArray::kNotFound) {
|
944
|
-
CallbacksDescriptor desc(*key, *entry, entry->property_attributes());
|
945
|
-
result->Set(descriptor_count, &desc, witness);
|
946
|
-
descriptor_count++;
|
947
|
-
} else {
|
948
|
-
duplicates++;
|
949
|
-
}
|
950
|
-
}
|
951
|
-
|
952
|
-
// If duplicates were detected, allocate a result of the right size
|
953
|
-
// and transfer the elements.
|
954
|
-
if (duplicates > 0) {
|
955
|
-
int number_of_descriptors = result->number_of_descriptors() - duplicates;
|
956
|
-
Handle<DescriptorArray> new_result =
|
957
|
-
NewDescriptorArray(number_of_descriptors);
|
958
|
-
for (int i = 0; i < number_of_descriptors; i++) {
|
959
|
-
DescriptorArray::CopyFrom(new_result, i, result, i, witness);
|
960
|
-
}
|
961
|
-
result = new_result;
|
962
|
-
}
|
963
|
-
|
964
|
-
// Sort the result before returning.
|
965
|
-
result->Sort(witness);
|
966
|
-
return result;
|
967
|
-
}
|
968
|
-
|
969
|
-
|
970
917
|
Handle<JSObject> Factory::NewJSObject(Handle<JSFunction> constructor,
|
971
918
|
PretenureFlag pretenure) {
|
972
919
|
CALL_HEAP_FUNCTION(
|
@@ -975,10 +922,11 @@ Handle<JSObject> Factory::NewJSObject(Handle<JSFunction> constructor,
|
|
975
922
|
}
|
976
923
|
|
977
924
|
|
978
|
-
Handle<JSModule> Factory::NewJSModule(
|
925
|
+
Handle<JSModule> Factory::NewJSModule(Handle<Context> context,
|
926
|
+
Handle<ScopeInfo> scope_info) {
|
979
927
|
CALL_HEAP_FUNCTION(
|
980
928
|
isolate(),
|
981
|
-
isolate()->heap()->AllocateJSModule(), JSModule);
|
929
|
+
isolate()->heap()->AllocateJSModule(*context, *scope_info), JSModule);
|
982
930
|
}
|
983
931
|
|
984
932
|
|
@@ -1002,6 +950,9 @@ Handle<JSObject> Factory::NewJSObjectFromMap(Handle<Map> map) {
|
|
1002
950
|
Handle<JSArray> Factory::NewJSArray(int capacity,
|
1003
951
|
ElementsKind elements_kind,
|
1004
952
|
PretenureFlag pretenure) {
|
953
|
+
if (capacity != 0) {
|
954
|
+
elements_kind = GetHoleyElementsKind(elements_kind);
|
955
|
+
}
|
1005
956
|
CALL_HEAP_FUNCTION(isolate(),
|
1006
957
|
isolate()->heap()->AllocateJSArrayAndStorage(
|
1007
958
|
elements_kind,
|
@@ -1020,6 +971,7 @@ Handle<JSArray> Factory::NewJSArrayWithElements(Handle<FixedArrayBase> elements,
|
|
1020
971
|
isolate(),
|
1021
972
|
isolate()->heap()->AllocateJSArrayWithElements(*elements,
|
1022
973
|
elements_kind,
|
974
|
+
elements->length(),
|
1023
975
|
pretenure),
|
1024
976
|
JSArray);
|
1025
977
|
}
|
@@ -1085,7 +1037,7 @@ void Factory::BecomeJSFunction(Handle<JSReceiver> object) {
|
|
1085
1037
|
}
|
1086
1038
|
|
1087
1039
|
|
1088
|
-
void Factory::SetIdentityHash(Handle<JSObject> object,
|
1040
|
+
void Factory::SetIdentityHash(Handle<JSObject> object, Smi* hash) {
|
1089
1041
|
CALL_HEAP_FUNCTION_VOID(
|
1090
1042
|
isolate(),
|
1091
1043
|
object->SetIdentityHash(hash, ALLOW_CREATION));
|
@@ -1185,7 +1137,7 @@ Handle<JSFunction> Factory::NewFunctionHelper(Handle<String> name,
|
|
1185
1137
|
Handle<JSFunction> Factory::NewFunction(Handle<String> name,
|
1186
1138
|
Handle<Object> prototype) {
|
1187
1139
|
Handle<JSFunction> fun = NewFunctionHelper(name, prototype);
|
1188
|
-
fun->set_context(isolate()->context()->
|
1140
|
+
fun->set_context(isolate()->context()->native_context());
|
1189
1141
|
return fun;
|
1190
1142
|
}
|
1191
1143
|
|
@@ -1211,7 +1163,7 @@ Handle<JSFunction> Factory::NewFunctionWithoutPrototype(
|
|
1211
1163
|
LanguageMode language_mode) {
|
1212
1164
|
Handle<JSFunction> fun =
|
1213
1165
|
NewFunctionWithoutPrototypeHelper(name, language_mode);
|
1214
|
-
fun->set_context(isolate()->context()->
|
1166
|
+
fun->set_context(isolate()->context()->native_context());
|
1215
1167
|
return fun;
|
1216
1168
|
}
|
1217
1169
|
|
@@ -1222,8 +1174,8 @@ Handle<Object> Factory::ToObject(Handle<Object> object) {
|
|
1222
1174
|
|
1223
1175
|
|
1224
1176
|
Handle<Object> Factory::ToObject(Handle<Object> object,
|
1225
|
-
Handle<Context>
|
1226
|
-
CALL_HEAP_FUNCTION(isolate(), object->ToObject(*
|
1177
|
+
Handle<Context> native_context) {
|
1178
|
+
CALL_HEAP_FUNCTION(isolate(), object->ToObject(*native_context), Object);
|
1227
1179
|
}
|
1228
1180
|
|
1229
1181
|
|
@@ -1308,6 +1260,10 @@ Handle<JSFunction> Factory::CreateApiFunction(
|
|
1308
1260
|
instance_size,
|
1309
1261
|
code,
|
1310
1262
|
true);
|
1263
|
+
|
1264
|
+
// Set length.
|
1265
|
+
result->shared()->set_length(obj->length());
|
1266
|
+
|
1311
1267
|
// Set class name.
|
1312
1268
|
Handle<Object> class_name = Handle<Object>(obj->class_name());
|
1313
1269
|
if (class_name->IsString()) {
|
@@ -1350,20 +1306,31 @@ Handle<JSFunction> Factory::CreateApiFunction(
|
|
1350
1306
|
result->shared()->DontAdaptArguments();
|
1351
1307
|
|
1352
1308
|
// Recursively copy parent templates' accessors, 'data' may be modified.
|
1353
|
-
|
1354
|
-
|
1309
|
+
int max_number_of_additional_properties = 0;
|
1310
|
+
FunctionTemplateInfo* info = *obj;
|
1311
|
+
while (true) {
|
1312
|
+
Object* props = info->property_accessors();
|
1313
|
+
if (!props->IsUndefined()) {
|
1314
|
+
Handle<Object> props_handle(props);
|
1315
|
+
NeanderArray props_array(props_handle);
|
1316
|
+
max_number_of_additional_properties += props_array.length();
|
1317
|
+
}
|
1318
|
+
Object* parent = info->parent_template();
|
1319
|
+
if (parent->IsUndefined()) break;
|
1320
|
+
info = FunctionTemplateInfo::cast(parent);
|
1321
|
+
}
|
1322
|
+
|
1323
|
+
Map::EnsureDescriptorSlack(map, max_number_of_additional_properties);
|
1324
|
+
|
1355
1325
|
while (true) {
|
1356
1326
|
Handle<Object> props = Handle<Object>(obj->property_accessors());
|
1357
1327
|
if (!props->IsUndefined()) {
|
1358
|
-
|
1328
|
+
Map::AppendCallbackDescriptors(map, props);
|
1359
1329
|
}
|
1360
1330
|
Handle<Object> parent = Handle<Object>(obj->parent_template());
|
1361
1331
|
if (parent->IsUndefined()) break;
|
1362
1332
|
obj = Handle<FunctionTemplateInfo>::cast(parent);
|
1363
1333
|
}
|
1364
|
-
if (!array->IsEmpty()) {
|
1365
|
-
map->set_instance_descriptors(*array);
|
1366
|
-
}
|
1367
1334
|
|
1368
1335
|
ASSERT(result->shared()->IsApiFunction());
|
1369
1336
|
return result;
|
@@ -1400,14 +1367,14 @@ Handle<MapCache> Factory::AddToMapCache(Handle<Context> context,
|
|
1400
1367
|
Handle<Map> Factory::ObjectLiteralMapFromCache(Handle<Context> context,
|
1401
1368
|
Handle<FixedArray> keys) {
|
1402
1369
|
if (context->map_cache()->IsUndefined()) {
|
1403
|
-
// Allocate the new map cache for the
|
1370
|
+
// Allocate the new map cache for the native context.
|
1404
1371
|
Handle<MapCache> new_cache = NewMapCache(24);
|
1405
1372
|
context->set_map_cache(*new_cache);
|
1406
1373
|
}
|
1407
1374
|
// Check to see whether there is a matching element in the cache.
|
1408
1375
|
Handle<MapCache> cache =
|
1409
1376
|
Handle<MapCache>(MapCache::cast(context->map_cache()));
|
1410
|
-
Handle<Object> result = Handle<Object>(cache->Lookup(*keys));
|
1377
|
+
Handle<Object> result = Handle<Object>(cache->Lookup(*keys), isolate());
|
1411
1378
|
if (result->IsMap()) return Handle<Map>::cast(result);
|
1412
1379
|
// Create a new map and add it to the cache.
|
1413
1380
|
Handle<Map> map =
|
@@ -1459,7 +1426,7 @@ void Factory::ConfigureInstance(Handle<FunctionTemplateInfo> desc,
|
|
1459
1426
|
bool* pending_exception) {
|
1460
1427
|
// Configure the instance by adding the properties specified by the
|
1461
1428
|
// instance template.
|
1462
|
-
Handle<Object> instance_template
|
1429
|
+
Handle<Object> instance_template(desc->instance_template(), isolate());
|
1463
1430
|
if (!instance_template->IsUndefined()) {
|
1464
1431
|
Execution::ConfigureInstance(instance,
|
1465
1432
|
instance_template,
|