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.
Files changed (754) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +1 -2
  3. data/Gemfile +1 -1
  4. data/Rakefile +6 -7
  5. data/lib/libv8/version.rb +1 -1
  6. data/vendor/v8/.gitignore +24 -3
  7. data/vendor/v8/AUTHORS +7 -0
  8. data/vendor/v8/ChangeLog +839 -0
  9. data/vendor/v8/DEPS +1 -1
  10. data/vendor/v8/Makefile.android +92 -0
  11. data/vendor/v8/OWNERS +11 -0
  12. data/vendor/v8/PRESUBMIT.py +71 -0
  13. data/vendor/v8/SConstruct +34 -39
  14. data/vendor/v8/build/android.gypi +56 -37
  15. data/vendor/v8/build/common.gypi +112 -30
  16. data/vendor/v8/build/gyp_v8 +1 -1
  17. data/vendor/v8/build/standalone.gypi +15 -11
  18. data/vendor/v8/include/v8-debug.h +9 -1
  19. data/vendor/v8/include/v8-preparser.h +4 -3
  20. data/vendor/v8/include/v8-profiler.h +25 -25
  21. data/vendor/v8/include/v8-testing.h +4 -3
  22. data/vendor/v8/include/v8.h +994 -540
  23. data/vendor/v8/preparser/preparser-process.cc +3 -3
  24. data/vendor/v8/samples/lineprocessor.cc +20 -27
  25. data/vendor/v8/samples/process.cc +18 -14
  26. data/vendor/v8/samples/shell.cc +16 -15
  27. data/vendor/v8/src/SConscript +15 -14
  28. data/vendor/v8/src/accessors.cc +169 -77
  29. data/vendor/v8/src/accessors.h +4 -0
  30. data/vendor/v8/src/allocation-inl.h +2 -2
  31. data/vendor/v8/src/allocation.h +7 -7
  32. data/vendor/v8/src/api.cc +810 -497
  33. data/vendor/v8/src/api.h +85 -60
  34. data/vendor/v8/src/arm/assembler-arm-inl.h +179 -22
  35. data/vendor/v8/src/arm/assembler-arm.cc +633 -264
  36. data/vendor/v8/src/arm/assembler-arm.h +264 -197
  37. data/vendor/v8/src/arm/builtins-arm.cc +117 -27
  38. data/vendor/v8/src/arm/code-stubs-arm.cc +1241 -700
  39. data/vendor/v8/src/arm/code-stubs-arm.h +35 -138
  40. data/vendor/v8/src/arm/codegen-arm.cc +285 -16
  41. data/vendor/v8/src/arm/codegen-arm.h +22 -0
  42. data/vendor/v8/src/arm/constants-arm.cc +5 -3
  43. data/vendor/v8/src/arm/constants-arm.h +24 -11
  44. data/vendor/v8/src/arm/debug-arm.cc +3 -3
  45. data/vendor/v8/src/arm/deoptimizer-arm.cc +382 -92
  46. data/vendor/v8/src/arm/disasm-arm.cc +61 -12
  47. data/vendor/v8/src/arm/frames-arm.h +0 -14
  48. data/vendor/v8/src/arm/full-codegen-arm.cc +332 -304
  49. data/vendor/v8/src/arm/ic-arm.cc +180 -259
  50. data/vendor/v8/src/arm/lithium-arm.cc +364 -316
  51. data/vendor/v8/src/arm/lithium-arm.h +512 -275
  52. data/vendor/v8/src/arm/lithium-codegen-arm.cc +1768 -809
  53. data/vendor/v8/src/arm/lithium-codegen-arm.h +97 -35
  54. data/vendor/v8/src/arm/lithium-gap-resolver-arm.cc +12 -5
  55. data/vendor/v8/src/arm/macro-assembler-arm.cc +439 -228
  56. data/vendor/v8/src/arm/macro-assembler-arm.h +116 -70
  57. data/vendor/v8/src/arm/regexp-macro-assembler-arm.cc +54 -44
  58. data/vendor/v8/src/arm/regexp-macro-assembler-arm.h +3 -10
  59. data/vendor/v8/src/arm/simulator-arm.cc +272 -238
  60. data/vendor/v8/src/arm/simulator-arm.h +38 -8
  61. data/vendor/v8/src/arm/stub-cache-arm.cc +522 -895
  62. data/vendor/v8/src/array.js +101 -70
  63. data/vendor/v8/src/assembler.cc +270 -19
  64. data/vendor/v8/src/assembler.h +110 -15
  65. data/vendor/v8/src/ast.cc +79 -69
  66. data/vendor/v8/src/ast.h +255 -301
  67. data/vendor/v8/src/atomicops.h +7 -1
  68. data/vendor/v8/src/atomicops_internals_tsan.h +335 -0
  69. data/vendor/v8/src/bootstrapper.cc +481 -418
  70. data/vendor/v8/src/bootstrapper.h +4 -4
  71. data/vendor/v8/src/builtins.cc +498 -311
  72. data/vendor/v8/src/builtins.h +75 -47
  73. data/vendor/v8/src/checks.cc +2 -1
  74. data/vendor/v8/src/checks.h +8 -0
  75. data/vendor/v8/src/code-stubs-hydrogen.cc +253 -0
  76. data/vendor/v8/src/code-stubs.cc +249 -84
  77. data/vendor/v8/src/code-stubs.h +501 -169
  78. data/vendor/v8/src/codegen.cc +36 -18
  79. data/vendor/v8/src/codegen.h +25 -3
  80. data/vendor/v8/src/collection.js +54 -17
  81. data/vendor/v8/src/compilation-cache.cc +24 -16
  82. data/vendor/v8/src/compilation-cache.h +15 -6
  83. data/vendor/v8/src/compiler.cc +497 -195
  84. data/vendor/v8/src/compiler.h +246 -38
  85. data/vendor/v8/src/contexts.cc +64 -24
  86. data/vendor/v8/src/contexts.h +60 -29
  87. data/vendor/v8/src/conversions-inl.h +24 -14
  88. data/vendor/v8/src/conversions.h +7 -4
  89. data/vendor/v8/src/counters.cc +21 -12
  90. data/vendor/v8/src/counters.h +44 -16
  91. data/vendor/v8/src/cpu-profiler.h +1 -1
  92. data/vendor/v8/src/d8-debug.cc +2 -2
  93. data/vendor/v8/src/d8-readline.cc +13 -2
  94. data/vendor/v8/src/d8.cc +681 -273
  95. data/vendor/v8/src/d8.gyp +4 -4
  96. data/vendor/v8/src/d8.h +38 -18
  97. data/vendor/v8/src/d8.js +0 -617
  98. data/vendor/v8/src/data-flow.h +55 -0
  99. data/vendor/v8/src/date.js +1 -42
  100. data/vendor/v8/src/dateparser-inl.h +5 -1
  101. data/vendor/v8/src/debug-agent.cc +10 -15
  102. data/vendor/v8/src/debug-debugger.js +147 -149
  103. data/vendor/v8/src/debug.cc +323 -164
  104. data/vendor/v8/src/debug.h +26 -14
  105. data/vendor/v8/src/deoptimizer.cc +765 -290
  106. data/vendor/v8/src/deoptimizer.h +130 -28
  107. data/vendor/v8/src/disassembler.cc +10 -4
  108. data/vendor/v8/src/elements-kind.cc +7 -2
  109. data/vendor/v8/src/elements-kind.h +19 -0
  110. data/vendor/v8/src/elements.cc +607 -285
  111. data/vendor/v8/src/elements.h +36 -13
  112. data/vendor/v8/src/execution.cc +52 -31
  113. data/vendor/v8/src/execution.h +4 -4
  114. data/vendor/v8/src/extensions/externalize-string-extension.cc +5 -4
  115. data/vendor/v8/src/extensions/gc-extension.cc +5 -1
  116. data/vendor/v8/src/extensions/statistics-extension.cc +153 -0
  117. data/vendor/v8/src/{inspector.h → extensions/statistics-extension.h} +12 -23
  118. data/vendor/v8/src/factory.cc +101 -134
  119. data/vendor/v8/src/factory.h +36 -31
  120. data/vendor/v8/src/flag-definitions.h +102 -25
  121. data/vendor/v8/src/flags.cc +9 -5
  122. data/vendor/v8/src/frames-inl.h +10 -0
  123. data/vendor/v8/src/frames.cc +116 -26
  124. data/vendor/v8/src/frames.h +96 -12
  125. data/vendor/v8/src/full-codegen.cc +219 -74
  126. data/vendor/v8/src/full-codegen.h +63 -21
  127. data/vendor/v8/src/func-name-inferrer.cc +8 -7
  128. data/vendor/v8/src/func-name-inferrer.h +5 -3
  129. data/vendor/v8/src/gdb-jit.cc +71 -57
  130. data/vendor/v8/src/global-handles.cc +230 -101
  131. data/vendor/v8/src/global-handles.h +26 -27
  132. data/vendor/v8/src/globals.h +17 -19
  133. data/vendor/v8/src/handles-inl.h +59 -12
  134. data/vendor/v8/src/handles.cc +180 -200
  135. data/vendor/v8/src/handles.h +80 -11
  136. data/vendor/v8/src/hashmap.h +60 -40
  137. data/vendor/v8/src/heap-inl.h +107 -45
  138. data/vendor/v8/src/heap-profiler.cc +38 -19
  139. data/vendor/v8/src/heap-profiler.h +24 -14
  140. data/vendor/v8/src/heap.cc +1123 -738
  141. data/vendor/v8/src/heap.h +385 -146
  142. data/vendor/v8/src/hydrogen-instructions.cc +700 -217
  143. data/vendor/v8/src/hydrogen-instructions.h +1158 -472
  144. data/vendor/v8/src/hydrogen.cc +3319 -1662
  145. data/vendor/v8/src/hydrogen.h +411 -170
  146. data/vendor/v8/src/ia32/assembler-ia32-inl.h +46 -16
  147. data/vendor/v8/src/ia32/assembler-ia32.cc +131 -61
  148. data/vendor/v8/src/ia32/assembler-ia32.h +115 -57
  149. data/vendor/v8/src/ia32/builtins-ia32.cc +99 -5
  150. data/vendor/v8/src/ia32/code-stubs-ia32.cc +787 -495
  151. data/vendor/v8/src/ia32/code-stubs-ia32.h +10 -100
  152. data/vendor/v8/src/ia32/codegen-ia32.cc +227 -23
  153. data/vendor/v8/src/ia32/codegen-ia32.h +14 -0
  154. data/vendor/v8/src/ia32/deoptimizer-ia32.cc +428 -87
  155. data/vendor/v8/src/ia32/disasm-ia32.cc +28 -1
  156. data/vendor/v8/src/ia32/frames-ia32.h +6 -16
  157. data/vendor/v8/src/ia32/full-codegen-ia32.cc +280 -272
  158. data/vendor/v8/src/ia32/ic-ia32.cc +150 -250
  159. data/vendor/v8/src/ia32/lithium-codegen-ia32.cc +1600 -517
  160. data/vendor/v8/src/ia32/lithium-codegen-ia32.h +90 -24
  161. data/vendor/v8/src/ia32/lithium-gap-resolver-ia32.cc +10 -6
  162. data/vendor/v8/src/ia32/lithium-gap-resolver-ia32.h +2 -2
  163. data/vendor/v8/src/ia32/lithium-ia32.cc +405 -302
  164. data/vendor/v8/src/ia32/lithium-ia32.h +526 -271
  165. data/vendor/v8/src/ia32/macro-assembler-ia32.cc +378 -119
  166. data/vendor/v8/src/ia32/macro-assembler-ia32.h +62 -28
  167. data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.cc +43 -30
  168. data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.h +2 -10
  169. data/vendor/v8/src/ia32/stub-cache-ia32.cc +492 -678
  170. data/vendor/v8/src/ic-inl.h +9 -4
  171. data/vendor/v8/src/ic.cc +836 -923
  172. data/vendor/v8/src/ic.h +228 -247
  173. data/vendor/v8/src/incremental-marking-inl.h +26 -30
  174. data/vendor/v8/src/incremental-marking.cc +276 -248
  175. data/vendor/v8/src/incremental-marking.h +29 -37
  176. data/vendor/v8/src/interface.cc +34 -25
  177. data/vendor/v8/src/interface.h +69 -25
  178. data/vendor/v8/src/interpreter-irregexp.cc +2 -2
  179. data/vendor/v8/src/isolate.cc +382 -76
  180. data/vendor/v8/src/isolate.h +109 -56
  181. data/vendor/v8/src/json-parser.h +217 -104
  182. data/vendor/v8/src/json-stringifier.h +745 -0
  183. data/vendor/v8/src/json.js +10 -132
  184. data/vendor/v8/src/jsregexp-inl.h +106 -0
  185. data/vendor/v8/src/jsregexp.cc +517 -285
  186. data/vendor/v8/src/jsregexp.h +145 -117
  187. data/vendor/v8/src/list-inl.h +35 -22
  188. data/vendor/v8/src/list.h +46 -19
  189. data/vendor/v8/src/lithium-allocator-inl.h +22 -2
  190. data/vendor/v8/src/lithium-allocator.cc +85 -70
  191. data/vendor/v8/src/lithium-allocator.h +21 -39
  192. data/vendor/v8/src/lithium.cc +259 -5
  193. data/vendor/v8/src/lithium.h +131 -32
  194. data/vendor/v8/src/liveedit-debugger.js +52 -3
  195. data/vendor/v8/src/liveedit.cc +393 -113
  196. data/vendor/v8/src/liveedit.h +7 -3
  197. data/vendor/v8/src/log-utils.cc +4 -2
  198. data/vendor/v8/src/log.cc +170 -140
  199. data/vendor/v8/src/log.h +62 -11
  200. data/vendor/v8/src/macro-assembler.h +17 -0
  201. data/vendor/v8/src/macros.py +2 -0
  202. data/vendor/v8/src/mark-compact-inl.h +3 -23
  203. data/vendor/v8/src/mark-compact.cc +801 -830
  204. data/vendor/v8/src/mark-compact.h +154 -47
  205. data/vendor/v8/src/marking-thread.cc +85 -0
  206. data/vendor/v8/src/{inspector.cc → marking-thread.h} +32 -24
  207. data/vendor/v8/src/math.js +12 -18
  208. data/vendor/v8/src/messages.cc +18 -8
  209. data/vendor/v8/src/messages.js +314 -261
  210. data/vendor/v8/src/mips/assembler-mips-inl.h +58 -6
  211. data/vendor/v8/src/mips/assembler-mips.cc +92 -75
  212. data/vendor/v8/src/mips/assembler-mips.h +54 -60
  213. data/vendor/v8/src/mips/builtins-mips.cc +116 -17
  214. data/vendor/v8/src/mips/code-stubs-mips.cc +919 -556
  215. data/vendor/v8/src/mips/code-stubs-mips.h +22 -131
  216. data/vendor/v8/src/mips/codegen-mips.cc +281 -6
  217. data/vendor/v8/src/mips/codegen-mips.h +22 -0
  218. data/vendor/v8/src/mips/constants-mips.cc +2 -0
  219. data/vendor/v8/src/mips/constants-mips.h +12 -2
  220. data/vendor/v8/src/mips/deoptimizer-mips.cc +286 -50
  221. data/vendor/v8/src/mips/disasm-mips.cc +13 -0
  222. data/vendor/v8/src/mips/full-codegen-mips.cc +297 -284
  223. data/vendor/v8/src/mips/ic-mips.cc +182 -263
  224. data/vendor/v8/src/mips/lithium-codegen-mips.cc +1208 -556
  225. data/vendor/v8/src/mips/lithium-codegen-mips.h +72 -19
  226. data/vendor/v8/src/mips/lithium-gap-resolver-mips.cc +9 -2
  227. data/vendor/v8/src/mips/lithium-mips.cc +290 -302
  228. data/vendor/v8/src/mips/lithium-mips.h +463 -266
  229. data/vendor/v8/src/mips/macro-assembler-mips.cc +208 -115
  230. data/vendor/v8/src/mips/macro-assembler-mips.h +67 -24
  231. data/vendor/v8/src/mips/regexp-macro-assembler-mips.cc +40 -25
  232. data/vendor/v8/src/mips/regexp-macro-assembler-mips.h +3 -9
  233. data/vendor/v8/src/mips/simulator-mips.cc +112 -40
  234. data/vendor/v8/src/mips/simulator-mips.h +5 -0
  235. data/vendor/v8/src/mips/stub-cache-mips.cc +502 -884
  236. data/vendor/v8/src/mirror-debugger.js +157 -30
  237. data/vendor/v8/src/mksnapshot.cc +88 -14
  238. data/vendor/v8/src/object-observe.js +235 -0
  239. data/vendor/v8/src/objects-debug.cc +178 -176
  240. data/vendor/v8/src/objects-inl.h +1333 -486
  241. data/vendor/v8/src/objects-printer.cc +125 -43
  242. data/vendor/v8/src/objects-visiting-inl.h +578 -6
  243. data/vendor/v8/src/objects-visiting.cc +2 -2
  244. data/vendor/v8/src/objects-visiting.h +172 -79
  245. data/vendor/v8/src/objects.cc +3533 -2885
  246. data/vendor/v8/src/objects.h +1352 -1131
  247. data/vendor/v8/src/optimizing-compiler-thread.cc +152 -0
  248. data/vendor/v8/src/optimizing-compiler-thread.h +111 -0
  249. data/vendor/v8/src/parser.cc +390 -500
  250. data/vendor/v8/src/parser.h +45 -33
  251. data/vendor/v8/src/platform-cygwin.cc +10 -21
  252. data/vendor/v8/src/platform-freebsd.cc +36 -41
  253. data/vendor/v8/src/platform-linux.cc +160 -124
  254. data/vendor/v8/src/platform-macos.cc +30 -27
  255. data/vendor/v8/src/platform-nullos.cc +17 -1
  256. data/vendor/v8/src/platform-openbsd.cc +19 -50
  257. data/vendor/v8/src/platform-posix.cc +14 -0
  258. data/vendor/v8/src/platform-solaris.cc +20 -53
  259. data/vendor/v8/src/platform-win32.cc +49 -26
  260. data/vendor/v8/src/platform.h +40 -1
  261. data/vendor/v8/src/preparser.cc +8 -5
  262. data/vendor/v8/src/preparser.h +2 -2
  263. data/vendor/v8/src/prettyprinter.cc +16 -0
  264. data/vendor/v8/src/prettyprinter.h +2 -0
  265. data/vendor/v8/src/profile-generator-inl.h +1 -0
  266. data/vendor/v8/src/profile-generator.cc +209 -147
  267. data/vendor/v8/src/profile-generator.h +15 -12
  268. data/vendor/v8/src/property-details.h +46 -31
  269. data/vendor/v8/src/property.cc +27 -46
  270. data/vendor/v8/src/property.h +163 -83
  271. data/vendor/v8/src/proxy.js +7 -2
  272. data/vendor/v8/src/regexp-macro-assembler-irregexp.cc +4 -13
  273. data/vendor/v8/src/regexp-macro-assembler-irregexp.h +1 -2
  274. data/vendor/v8/src/regexp-macro-assembler-tracer.cc +1 -11
  275. data/vendor/v8/src/regexp-macro-assembler-tracer.h +0 -1
  276. data/vendor/v8/src/regexp-macro-assembler.cc +31 -14
  277. data/vendor/v8/src/regexp-macro-assembler.h +14 -11
  278. data/vendor/v8/src/regexp-stack.cc +1 -0
  279. data/vendor/v8/src/regexp.js +9 -8
  280. data/vendor/v8/src/rewriter.cc +18 -7
  281. data/vendor/v8/src/runtime-profiler.cc +52 -43
  282. data/vendor/v8/src/runtime-profiler.h +0 -25
  283. data/vendor/v8/src/runtime.cc +2006 -2023
  284. data/vendor/v8/src/runtime.h +56 -49
  285. data/vendor/v8/src/safepoint-table.cc +12 -18
  286. data/vendor/v8/src/safepoint-table.h +11 -8
  287. data/vendor/v8/src/scanner.cc +1 -0
  288. data/vendor/v8/src/scanner.h +4 -10
  289. data/vendor/v8/src/scopeinfo.cc +35 -9
  290. data/vendor/v8/src/scopeinfo.h +64 -3
  291. data/vendor/v8/src/scopes.cc +251 -156
  292. data/vendor/v8/src/scopes.h +61 -27
  293. data/vendor/v8/src/serialize.cc +348 -396
  294. data/vendor/v8/src/serialize.h +125 -114
  295. data/vendor/v8/src/small-pointer-list.h +11 -11
  296. data/vendor/v8/src/{smart-array-pointer.h → smart-pointers.h} +64 -15
  297. data/vendor/v8/src/snapshot-common.cc +64 -15
  298. data/vendor/v8/src/snapshot-empty.cc +7 -1
  299. data/vendor/v8/src/snapshot.h +9 -2
  300. data/vendor/v8/src/spaces-inl.h +17 -0
  301. data/vendor/v8/src/spaces.cc +477 -183
  302. data/vendor/v8/src/spaces.h +238 -58
  303. data/vendor/v8/src/splay-tree-inl.h +8 -7
  304. data/vendor/v8/src/splay-tree.h +24 -10
  305. data/vendor/v8/src/store-buffer.cc +12 -5
  306. data/vendor/v8/src/store-buffer.h +2 -4
  307. data/vendor/v8/src/string-search.h +22 -6
  308. data/vendor/v8/src/string-stream.cc +11 -8
  309. data/vendor/v8/src/string.js +47 -15
  310. data/vendor/v8/src/stub-cache.cc +461 -224
  311. data/vendor/v8/src/stub-cache.h +164 -102
  312. data/vendor/v8/src/sweeper-thread.cc +105 -0
  313. data/vendor/v8/src/sweeper-thread.h +81 -0
  314. data/vendor/v8/src/token.h +1 -0
  315. data/vendor/v8/src/transitions-inl.h +220 -0
  316. data/vendor/v8/src/transitions.cc +160 -0
  317. data/vendor/v8/src/transitions.h +207 -0
  318. data/vendor/v8/src/type-info.cc +182 -181
  319. data/vendor/v8/src/type-info.h +31 -19
  320. data/vendor/v8/src/unicode-inl.h +62 -106
  321. data/vendor/v8/src/unicode.cc +57 -67
  322. data/vendor/v8/src/unicode.h +45 -91
  323. data/vendor/v8/src/uri.js +57 -29
  324. data/vendor/v8/src/utils.h +105 -5
  325. data/vendor/v8/src/v8-counters.cc +54 -11
  326. data/vendor/v8/src/v8-counters.h +134 -19
  327. data/vendor/v8/src/v8.cc +29 -29
  328. data/vendor/v8/src/v8.h +1 -0
  329. data/vendor/v8/src/v8conversions.cc +26 -22
  330. data/vendor/v8/src/v8globals.h +56 -43
  331. data/vendor/v8/src/v8natives.js +83 -30
  332. data/vendor/v8/src/v8threads.cc +42 -21
  333. data/vendor/v8/src/v8threads.h +4 -1
  334. data/vendor/v8/src/v8utils.cc +9 -93
  335. data/vendor/v8/src/v8utils.h +37 -33
  336. data/vendor/v8/src/variables.cc +6 -3
  337. data/vendor/v8/src/variables.h +6 -13
  338. data/vendor/v8/src/version.cc +2 -2
  339. data/vendor/v8/src/vm-state-inl.h +11 -0
  340. data/vendor/v8/src/x64/assembler-x64-inl.h +39 -8
  341. data/vendor/v8/src/x64/assembler-x64.cc +78 -64
  342. data/vendor/v8/src/x64/assembler-x64.h +38 -33
  343. data/vendor/v8/src/x64/builtins-x64.cc +105 -7
  344. data/vendor/v8/src/x64/code-stubs-x64.cc +790 -413
  345. data/vendor/v8/src/x64/code-stubs-x64.h +10 -106
  346. data/vendor/v8/src/x64/codegen-x64.cc +210 -8
  347. data/vendor/v8/src/x64/codegen-x64.h +20 -1
  348. data/vendor/v8/src/x64/deoptimizer-x64.cc +336 -75
  349. data/vendor/v8/src/x64/disasm-x64.cc +15 -0
  350. data/vendor/v8/src/x64/frames-x64.h +0 -14
  351. data/vendor/v8/src/x64/full-codegen-x64.cc +293 -270
  352. data/vendor/v8/src/x64/ic-x64.cc +153 -251
  353. data/vendor/v8/src/x64/lithium-codegen-x64.cc +1379 -531
  354. data/vendor/v8/src/x64/lithium-codegen-x64.h +67 -23
  355. data/vendor/v8/src/x64/lithium-gap-resolver-x64.cc +2 -2
  356. data/vendor/v8/src/x64/lithium-x64.cc +349 -289
  357. data/vendor/v8/src/x64/lithium-x64.h +460 -250
  358. data/vendor/v8/src/x64/macro-assembler-x64.cc +350 -177
  359. data/vendor/v8/src/x64/macro-assembler-x64.h +67 -49
  360. data/vendor/v8/src/x64/regexp-macro-assembler-x64.cc +46 -33
  361. data/vendor/v8/src/x64/regexp-macro-assembler-x64.h +2 -3
  362. data/vendor/v8/src/x64/stub-cache-x64.cc +484 -653
  363. data/vendor/v8/src/zone-inl.h +9 -27
  364. data/vendor/v8/src/zone.cc +5 -5
  365. data/vendor/v8/src/zone.h +53 -27
  366. data/vendor/v8/test/benchmarks/testcfg.py +5 -0
  367. data/vendor/v8/test/cctest/cctest.cc +4 -0
  368. data/vendor/v8/test/cctest/cctest.gyp +3 -1
  369. data/vendor/v8/test/cctest/cctest.h +57 -9
  370. data/vendor/v8/test/cctest/cctest.status +15 -15
  371. data/vendor/v8/test/cctest/test-accessors.cc +26 -0
  372. data/vendor/v8/test/cctest/test-alloc.cc +22 -30
  373. data/vendor/v8/test/cctest/test-api.cc +1943 -314
  374. data/vendor/v8/test/cctest/test-assembler-arm.cc +133 -13
  375. data/vendor/v8/test/cctest/test-assembler-ia32.cc +1 -1
  376. data/vendor/v8/test/cctest/test-assembler-mips.cc +12 -0
  377. data/vendor/v8/test/cctest/test-ast.cc +4 -2
  378. data/vendor/v8/test/cctest/test-compiler.cc +61 -29
  379. data/vendor/v8/test/cctest/test-dataflow.cc +2 -2
  380. data/vendor/v8/test/cctest/test-debug.cc +212 -33
  381. data/vendor/v8/test/cctest/test-decls.cc +257 -11
  382. data/vendor/v8/test/cctest/test-dictionary.cc +24 -10
  383. data/vendor/v8/test/cctest/test-disasm-arm.cc +118 -1
  384. data/vendor/v8/test/cctest/test-disasm-ia32.cc +3 -2
  385. data/vendor/v8/test/cctest/test-flags.cc +14 -1
  386. data/vendor/v8/test/cctest/test-func-name-inference.cc +7 -4
  387. data/vendor/v8/test/cctest/test-global-object.cc +51 -0
  388. data/vendor/v8/test/cctest/test-hashing.cc +32 -23
  389. data/vendor/v8/test/cctest/test-heap-profiler.cc +131 -77
  390. data/vendor/v8/test/cctest/test-heap.cc +1084 -143
  391. data/vendor/v8/test/cctest/test-list.cc +1 -1
  392. data/vendor/v8/test/cctest/test-liveedit.cc +3 -2
  393. data/vendor/v8/test/cctest/test-lockers.cc +12 -13
  394. data/vendor/v8/test/cctest/test-log.cc +10 -8
  395. data/vendor/v8/test/cctest/test-macro-assembler-x64.cc +2 -2
  396. data/vendor/v8/test/cctest/test-mark-compact.cc +44 -22
  397. data/vendor/v8/test/cctest/test-object-observe.cc +434 -0
  398. data/vendor/v8/test/cctest/test-parsing.cc +86 -39
  399. data/vendor/v8/test/cctest/test-platform-linux.cc +6 -0
  400. data/vendor/v8/test/cctest/test-platform-win32.cc +7 -0
  401. data/vendor/v8/test/cctest/test-random.cc +5 -4
  402. data/vendor/v8/test/cctest/test-regexp.cc +137 -101
  403. data/vendor/v8/test/cctest/test-serialize.cc +150 -230
  404. data/vendor/v8/test/cctest/test-sockets.cc +1 -1
  405. data/vendor/v8/test/cctest/test-spaces.cc +139 -0
  406. data/vendor/v8/test/cctest/test-strings.cc +736 -74
  407. data/vendor/v8/test/cctest/test-thread-termination.cc +10 -11
  408. data/vendor/v8/test/cctest/test-threads.cc +4 -4
  409. data/vendor/v8/test/cctest/test-utils.cc +16 -0
  410. data/vendor/v8/test/cctest/test-weakmaps.cc +7 -3
  411. data/vendor/v8/test/cctest/testcfg.py +64 -5
  412. data/vendor/v8/test/es5conform/testcfg.py +5 -0
  413. data/vendor/v8/test/message/message.status +1 -1
  414. data/vendor/v8/test/message/overwritten-builtins.out +3 -0
  415. data/vendor/v8/test/message/testcfg.py +89 -8
  416. data/vendor/v8/test/message/try-catch-finally-no-message.out +26 -26
  417. data/vendor/v8/test/mjsunit/accessor-map-sharing.js +18 -2
  418. data/vendor/v8/test/mjsunit/allocation-site-info.js +126 -0
  419. data/vendor/v8/test/mjsunit/array-bounds-check-removal.js +62 -1
  420. data/vendor/v8/test/mjsunit/array-iteration.js +1 -1
  421. data/vendor/v8/test/mjsunit/array-literal-transitions.js +2 -0
  422. data/vendor/v8/test/mjsunit/array-natives-elements.js +317 -0
  423. data/vendor/v8/test/mjsunit/array-reduce.js +8 -8
  424. data/vendor/v8/test/mjsunit/array-slice.js +12 -0
  425. data/vendor/v8/test/mjsunit/array-store-and-grow.js +4 -1
  426. data/vendor/v8/test/mjsunit/assert-opt-and-deopt.js +1 -1
  427. data/vendor/v8/test/mjsunit/bugs/bug-2337.js +53 -0
  428. data/vendor/v8/test/mjsunit/compare-known-objects-slow.js +69 -0
  429. data/vendor/v8/test/mjsunit/compiler/alloc-object-huge.js +3 -1
  430. data/vendor/v8/test/mjsunit/compiler/inline-accessors.js +368 -0
  431. data/vendor/v8/test/mjsunit/compiler/inline-arguments.js +87 -1
  432. data/vendor/v8/test/mjsunit/compiler/inline-closures.js +49 -0
  433. data/vendor/v8/test/mjsunit/compiler/inline-construct.js +55 -43
  434. data/vendor/v8/test/mjsunit/compiler/inline-literals.js +39 -0
  435. data/vendor/v8/test/mjsunit/compiler/multiply-add.js +69 -0
  436. data/vendor/v8/test/mjsunit/compiler/optimized-closures.js +57 -0
  437. data/vendor/v8/test/mjsunit/compiler/parallel-proto-change.js +44 -0
  438. data/vendor/v8/test/mjsunit/compiler/property-static.js +69 -0
  439. data/vendor/v8/test/mjsunit/compiler/proto-chain-constant.js +55 -0
  440. data/vendor/v8/test/mjsunit/compiler/proto-chain-load.js +44 -0
  441. data/vendor/v8/test/mjsunit/compiler/regress-gvn.js +3 -2
  442. data/vendor/v8/test/mjsunit/compiler/regress-or.js +6 -2
  443. data/vendor/v8/test/mjsunit/compiler/rotate.js +224 -0
  444. data/vendor/v8/test/mjsunit/compiler/uint32.js +173 -0
  445. data/vendor/v8/test/mjsunit/count-based-osr.js +2 -1
  446. data/vendor/v8/test/mjsunit/d8-os.js +3 -3
  447. data/vendor/v8/test/mjsunit/date-parse.js +3 -0
  448. data/vendor/v8/test/mjsunit/date.js +22 -0
  449. data/vendor/v8/test/mjsunit/debug-break-inline.js +1 -0
  450. data/vendor/v8/test/mjsunit/debug-evaluate-locals-optimized-double.js +22 -12
  451. data/vendor/v8/test/mjsunit/debug-evaluate-locals-optimized.js +21 -10
  452. data/vendor/v8/test/mjsunit/debug-liveedit-compile-error.js +60 -0
  453. data/vendor/v8/test/mjsunit/debug-liveedit-double-call.js +142 -0
  454. data/vendor/v8/test/mjsunit/debug-liveedit-literals.js +94 -0
  455. data/vendor/v8/test/mjsunit/debug-liveedit-restart-frame.js +153 -0
  456. data/vendor/v8/test/mjsunit/debug-multiple-breakpoints.js +1 -1
  457. data/vendor/v8/test/mjsunit/debug-script-breakpoints-closure.js +67 -0
  458. data/vendor/v8/test/mjsunit/debug-script-breakpoints-nested.js +82 -0
  459. data/vendor/v8/test/mjsunit/debug-script.js +4 -2
  460. data/vendor/v8/test/mjsunit/debug-set-variable-value.js +308 -0
  461. data/vendor/v8/test/mjsunit/debug-stepout-scope-part1.js +190 -0
  462. data/vendor/v8/test/mjsunit/debug-stepout-scope-part2.js +83 -0
  463. data/vendor/v8/test/mjsunit/debug-stepout-scope-part3.js +80 -0
  464. data/vendor/v8/test/mjsunit/debug-stepout-scope-part4.js +80 -0
  465. data/vendor/v8/test/mjsunit/debug-stepout-scope-part5.js +77 -0
  466. data/vendor/v8/test/mjsunit/debug-stepout-scope-part6.js +79 -0
  467. data/vendor/v8/test/mjsunit/debug-stepout-scope-part7.js +79 -0
  468. data/vendor/v8/test/mjsunit/{debug-stepout-scope.js → debug-stepout-scope-part8.js} +0 -189
  469. data/vendor/v8/test/mjsunit/delete-non-configurable.js +74 -0
  470. data/vendor/v8/test/mjsunit/deopt-minus-zero.js +56 -0
  471. data/vendor/v8/test/mjsunit/elements-kind.js +6 -4
  472. data/vendor/v8/test/mjsunit/elements-length-no-holey.js +33 -0
  473. data/vendor/v8/test/mjsunit/elements-transition-hoisting.js +46 -19
  474. data/vendor/v8/test/mjsunit/error-accessors.js +54 -0
  475. data/vendor/v8/test/mjsunit/error-constructors.js +1 -14
  476. data/vendor/v8/test/mjsunit/error-tostring.js +8 -0
  477. data/vendor/v8/test/mjsunit/eval-stack-trace.js +204 -0
  478. data/vendor/v8/test/mjsunit/external-array.js +364 -1
  479. data/vendor/v8/test/mjsunit/fast-array-length.js +37 -0
  480. data/vendor/v8/test/mjsunit/fast-non-keyed.js +113 -0
  481. data/vendor/v8/test/mjsunit/fast-prototype.js +117 -0
  482. data/vendor/v8/test/mjsunit/function-call.js +14 -18
  483. data/vendor/v8/test/mjsunit/fuzz-natives-part1.js +230 -0
  484. data/vendor/v8/test/mjsunit/fuzz-natives-part2.js +229 -0
  485. data/vendor/v8/test/mjsunit/fuzz-natives-part3.js +229 -0
  486. data/vendor/v8/test/mjsunit/{fuzz-natives.js → fuzz-natives-part4.js} +12 -2
  487. data/vendor/v8/test/mjsunit/generated-transition-stub.js +218 -0
  488. data/vendor/v8/test/mjsunit/greedy.js +1 -1
  489. data/vendor/v8/test/mjsunit/harmony/block-conflicts.js +2 -1
  490. data/vendor/v8/test/mjsunit/harmony/block-let-crankshaft.js +1 -1
  491. data/vendor/v8/test/mjsunit/harmony/collections.js +69 -11
  492. data/vendor/v8/test/mjsunit/harmony/debug-blockscopes.js +2 -2
  493. data/vendor/v8/test/mjsunit/harmony/module-linking.js +180 -3
  494. data/vendor/v8/test/mjsunit/harmony/module-parsing.js +31 -0
  495. data/vendor/v8/test/mjsunit/harmony/module-recompile.js +87 -0
  496. data/vendor/v8/test/mjsunit/harmony/module-resolution.js +15 -2
  497. data/vendor/v8/test/mjsunit/harmony/object-observe.js +1056 -0
  498. data/vendor/v8/test/mjsunit/harmony/proxies-json.js +178 -0
  499. data/vendor/v8/test/mjsunit/harmony/proxies.js +25 -10
  500. data/vendor/v8/test/mjsunit/json-parser-recursive.js +33 -0
  501. data/vendor/v8/test/mjsunit/json-stringify-recursive.js +52 -0
  502. data/vendor/v8/test/mjsunit/json.js +38 -2
  503. data/vendor/v8/test/mjsunit/json2.js +153 -0
  504. data/vendor/v8/test/mjsunit/limit-locals.js +5 -4
  505. data/vendor/v8/test/mjsunit/manual-parallel-recompile.js +79 -0
  506. data/vendor/v8/test/mjsunit/math-exp-precision.js +64 -0
  507. data/vendor/v8/test/mjsunit/math-floor-negative.js +59 -0
  508. data/vendor/v8/test/mjsunit/math-floor-of-div-minus-zero.js +41 -0
  509. data/vendor/v8/test/mjsunit/math-floor-of-div-nosudiv.js +288 -0
  510. data/vendor/v8/test/mjsunit/math-floor-of-div.js +81 -9
  511. data/vendor/v8/test/mjsunit/{math-floor.js → math-floor-part1.js} +1 -72
  512. data/vendor/v8/test/mjsunit/math-floor-part2.js +76 -0
  513. data/vendor/v8/test/mjsunit/math-floor-part3.js +78 -0
  514. data/vendor/v8/test/mjsunit/math-floor-part4.js +76 -0
  515. data/vendor/v8/test/mjsunit/mirror-object.js +43 -9
  516. data/vendor/v8/test/mjsunit/mjsunit.js +1 -1
  517. data/vendor/v8/test/mjsunit/mjsunit.status +52 -27
  518. data/vendor/v8/test/mjsunit/mul-exhaustive-part1.js +491 -0
  519. data/vendor/v8/test/mjsunit/mul-exhaustive-part10.js +470 -0
  520. data/vendor/v8/test/mjsunit/mul-exhaustive-part2.js +525 -0
  521. data/vendor/v8/test/mjsunit/mul-exhaustive-part3.js +532 -0
  522. data/vendor/v8/test/mjsunit/mul-exhaustive-part4.js +509 -0
  523. data/vendor/v8/test/mjsunit/mul-exhaustive-part5.js +505 -0
  524. data/vendor/v8/test/mjsunit/mul-exhaustive-part6.js +554 -0
  525. data/vendor/v8/test/mjsunit/mul-exhaustive-part7.js +497 -0
  526. data/vendor/v8/test/mjsunit/mul-exhaustive-part8.js +526 -0
  527. data/vendor/v8/test/mjsunit/mul-exhaustive-part9.js +533 -0
  528. data/vendor/v8/test/mjsunit/new-function.js +34 -0
  529. data/vendor/v8/test/mjsunit/numops-fuzz-part1.js +1172 -0
  530. data/vendor/v8/test/mjsunit/numops-fuzz-part2.js +1178 -0
  531. data/vendor/v8/test/mjsunit/numops-fuzz-part3.js +1178 -0
  532. data/vendor/v8/test/mjsunit/numops-fuzz-part4.js +1177 -0
  533. data/vendor/v8/test/mjsunit/object-define-property.js +107 -2
  534. data/vendor/v8/test/mjsunit/override-read-only-property.js +6 -4
  535. data/vendor/v8/test/mjsunit/packed-elements.js +2 -2
  536. data/vendor/v8/test/mjsunit/parse-int-float.js +4 -4
  537. data/vendor/v8/test/mjsunit/pixel-array-rounding.js +1 -1
  538. data/vendor/v8/test/mjsunit/readonly.js +228 -0
  539. data/vendor/v8/test/mjsunit/regexp-capture-3.js +16 -18
  540. data/vendor/v8/test/mjsunit/regexp-capture.js +2 -0
  541. data/vendor/v8/test/mjsunit/regexp-global.js +122 -0
  542. data/vendor/v8/test/mjsunit/regexp-results-cache.js +78 -0
  543. data/vendor/v8/test/mjsunit/regress/regress-1117.js +12 -3
  544. data/vendor/v8/test/mjsunit/regress/regress-1118.js +1 -1
  545. data/vendor/v8/test/mjsunit/regress/regress-115100.js +36 -0
  546. data/vendor/v8/test/mjsunit/regress/regress-1199637.js +1 -3
  547. data/vendor/v8/test/mjsunit/regress/regress-121407.js +1 -1
  548. data/vendor/v8/test/mjsunit/regress/regress-131923.js +30 -0
  549. data/vendor/v8/test/mjsunit/regress/regress-131994.js +70 -0
  550. data/vendor/v8/test/mjsunit/regress/regress-133211.js +35 -0
  551. data/vendor/v8/test/mjsunit/regress/regress-133211b.js +39 -0
  552. data/vendor/v8/test/mjsunit/regress/regress-136048.js +34 -0
  553. data/vendor/v8/test/mjsunit/regress/regress-137768.js +73 -0
  554. data/vendor/v8/test/mjsunit/regress/regress-143967.js +34 -0
  555. data/vendor/v8/test/mjsunit/regress/regress-145201.js +107 -0
  556. data/vendor/v8/test/mjsunit/regress/regress-147497.js +45 -0
  557. data/vendor/v8/test/mjsunit/regress/regress-148378.js +38 -0
  558. data/vendor/v8/test/mjsunit/regress/regress-1563.js +1 -1
  559. data/vendor/v8/test/mjsunit/regress/regress-1591.js +48 -0
  560. data/vendor/v8/test/mjsunit/regress/regress-164442.js +45 -0
  561. data/vendor/v8/test/mjsunit/regress/regress-165637.js +61 -0
  562. data/vendor/v8/test/mjsunit/regress/regress-166379.js +39 -0
  563. data/vendor/v8/test/mjsunit/regress/regress-166553.js +33 -0
  564. data/vendor/v8/test/mjsunit/regress/regress-1692.js +1 -1
  565. data/vendor/v8/test/mjsunit/regress/regress-171641.js +40 -0
  566. data/vendor/v8/test/mjsunit/regress/regress-1980.js +1 -1
  567. data/vendor/v8/test/mjsunit/regress/regress-2073.js +99 -0
  568. data/vendor/v8/test/mjsunit/regress/regress-2119.js +36 -0
  569. data/vendor/v8/test/mjsunit/regress/regress-2156.js +39 -0
  570. data/vendor/v8/test/mjsunit/regress/regress-2163.js +70 -0
  571. data/vendor/v8/test/mjsunit/regress/regress-2170.js +58 -0
  572. data/vendor/v8/test/mjsunit/regress/regress-2172.js +35 -0
  573. data/vendor/v8/test/mjsunit/regress/regress-2185-2.js +145 -0
  574. data/vendor/v8/test/mjsunit/regress/regress-2185.js +38 -0
  575. data/vendor/v8/test/mjsunit/regress/regress-2186.js +49 -0
  576. data/vendor/v8/test/mjsunit/regress/regress-2193.js +58 -0
  577. data/vendor/v8/test/mjsunit/regress/regress-2219.js +32 -0
  578. data/vendor/v8/test/mjsunit/regress/regress-2225.js +65 -0
  579. data/vendor/v8/test/mjsunit/regress/regress-2226.js +36 -0
  580. data/vendor/v8/test/mjsunit/regress/regress-2234.js +41 -0
  581. data/vendor/v8/test/mjsunit/regress/regress-2243.js +31 -0
  582. data/vendor/v8/test/mjsunit/regress/regress-2249.js +33 -0
  583. data/vendor/v8/test/mjsunit/regress/regress-2250.js +68 -0
  584. data/vendor/v8/test/mjsunit/regress/regress-2261.js +113 -0
  585. data/vendor/v8/test/mjsunit/regress/regress-2263.js +30 -0
  586. data/vendor/v8/test/mjsunit/regress/regress-2284.js +32 -0
  587. data/vendor/v8/test/mjsunit/regress/regress-2285.js +32 -0
  588. data/vendor/v8/test/mjsunit/regress/regress-2286.js +32 -0
  589. data/vendor/v8/test/mjsunit/regress/regress-2289.js +34 -0
  590. data/vendor/v8/test/mjsunit/regress/regress-2291.js +36 -0
  591. data/vendor/v8/test/mjsunit/regress/regress-2294.js +70 -0
  592. data/vendor/v8/test/mjsunit/regress/regress-2296.js +40 -0
  593. data/vendor/v8/test/mjsunit/regress/regress-2315.js +40 -0
  594. data/vendor/v8/test/mjsunit/regress/regress-2318.js +66 -0
  595. data/vendor/v8/test/mjsunit/regress/regress-2322.js +36 -0
  596. data/vendor/v8/test/mjsunit/regress/regress-2326.js +54 -0
  597. data/vendor/v8/test/mjsunit/regress/regress-2336.js +53 -0
  598. data/vendor/v8/test/mjsunit/regress/regress-2339.js +59 -0
  599. data/vendor/v8/test/mjsunit/regress/regress-2346.js +123 -0
  600. data/vendor/v8/test/mjsunit/regress/regress-2373.js +29 -0
  601. data/vendor/v8/test/mjsunit/regress/regress-2374.js +33 -0
  602. data/vendor/v8/test/mjsunit/regress/regress-2398.js +41 -0
  603. data/vendor/v8/test/mjsunit/regress/regress-2410.js +36 -0
  604. data/vendor/v8/test/mjsunit/regress/regress-2416.js +75 -0
  605. data/vendor/v8/test/mjsunit/regress/regress-2419.js +37 -0
  606. data/vendor/v8/test/mjsunit/regress/regress-2433.js +36 -0
  607. data/vendor/v8/test/mjsunit/regress/regress-2437.js +156 -0
  608. data/vendor/v8/test/mjsunit/regress/regress-2438.js +52 -0
  609. data/vendor/v8/test/mjsunit/regress/regress-2443.js +129 -0
  610. data/vendor/v8/test/mjsunit/regress/regress-2444.js +120 -0
  611. data/vendor/v8/test/mjsunit/regress/regress-2489.js +50 -0
  612. data/vendor/v8/test/mjsunit/regress/regress-2499.js +40 -0
  613. data/vendor/v8/test/mjsunit/regress/regress-334.js +1 -1
  614. data/vendor/v8/test/mjsunit/regress/regress-492.js +39 -1
  615. data/vendor/v8/test/mjsunit/regress/regress-builtin-array-op.js +38 -0
  616. data/vendor/v8/test/mjsunit/regress/regress-cnlt-elements.js +43 -0
  617. data/vendor/v8/test/mjsunit/regress/regress-cnlt-enum-indices.js +45 -0
  618. data/vendor/v8/test/mjsunit/regress/regress-cntl-descriptors-enum.js +46 -0
  619. data/vendor/v8/test/mjsunit/regress/regress-convert-enum.js +60 -0
  620. data/vendor/v8/test/mjsunit/regress/regress-convert-enum2.js +46 -0
  621. data/vendor/v8/test/mjsunit/regress/regress-convert-transition.js +40 -0
  622. data/vendor/v8/test/mjsunit/regress/regress-crbug-119926.js +3 -1
  623. data/vendor/v8/test/mjsunit/regress/regress-crbug-125148.js +90 -0
  624. data/vendor/v8/test/mjsunit/regress/regress-crbug-134055.js +63 -0
  625. data/vendor/v8/test/mjsunit/regress/regress-crbug-134609.js +59 -0
  626. data/vendor/v8/test/mjsunit/regress/regress-crbug-135008.js +45 -0
  627. data/vendor/v8/test/mjsunit/regress/regress-crbug-135066.js +55 -0
  628. data/vendor/v8/test/mjsunit/regress/regress-crbug-137689.js +47 -0
  629. data/vendor/v8/test/mjsunit/regress/regress-crbug-138887.js +48 -0
  630. data/vendor/v8/test/mjsunit/regress/regress-crbug-140083.js +44 -0
  631. data/vendor/v8/test/mjsunit/regress/regress-crbug-142087.js +38 -0
  632. data/vendor/v8/test/mjsunit/regress/regress-crbug-142218.js +44 -0
  633. data/vendor/v8/test/mjsunit/regress/regress-crbug-145961.js +39 -0
  634. data/vendor/v8/test/mjsunit/regress/regress-crbug-146910.js +33 -0
  635. data/vendor/v8/test/mjsunit/regress/regress-crbug-147475.js +48 -0
  636. data/vendor/v8/test/mjsunit/regress/regress-crbug-148376.js +35 -0
  637. data/vendor/v8/test/mjsunit/regress/regress-crbug-150545.js +53 -0
  638. data/vendor/v8/test/mjsunit/regress/regress-crbug-150729.js +39 -0
  639. data/vendor/v8/test/mjsunit/regress/regress-crbug-157019.js +54 -0
  640. data/vendor/v8/test/mjsunit/regress/regress-crbug-157520.js +38 -0
  641. data/vendor/v8/test/mjsunit/regress/regress-crbug-158185.js +39 -0
  642. data/vendor/v8/test/mjsunit/regress/regress-crbug-160010.js +35 -0
  643. data/vendor/v8/test/mjsunit/regress/regress-crbug-162085.js +71 -0
  644. data/vendor/v8/test/mjsunit/regress/regress-crbug-168545.js +34 -0
  645. data/vendor/v8/test/mjsunit/regress/regress-crbug-170856.js +33 -0
  646. data/vendor/v8/test/mjsunit/regress/regress-crbug-172345.js +34 -0
  647. data/vendor/v8/test/mjsunit/regress/regress-crbug-173974.js +36 -0
  648. data/vendor/v8/test/mjsunit/regress/regress-crbug-18639.js +9 -5
  649. data/vendor/v8/test/mjsunit/regress/regress-debug-code-recompilation.js +2 -1
  650. data/vendor/v8/test/mjsunit/regress/regress-deep-proto.js +45 -0
  651. data/vendor/v8/test/mjsunit/regress/regress-delete-empty-double.js +40 -0
  652. data/vendor/v8/test/mjsunit/regress/regress-iteration-order.js +42 -0
  653. data/vendor/v8/test/mjsunit/regress/regress-json-stringify-gc.js +41 -0
  654. data/vendor/v8/test/mjsunit/regress/regress-latin-1.js +78 -0
  655. data/vendor/v8/test/mjsunit/regress/regress-load-elements.js +49 -0
  656. data/vendor/v8/test/mjsunit/regress/regress-observe-empty-double-array.js +38 -0
  657. data/vendor/v8/test/mjsunit/regress/regress-undefined-store-keyed-fast-element.js +37 -0
  658. data/vendor/v8/test/mjsunit/shift-for-integer-div.js +59 -0
  659. data/vendor/v8/test/mjsunit/stack-traces-gc.js +119 -0
  660. data/vendor/v8/test/mjsunit/stack-traces-overflow.js +122 -0
  661. data/vendor/v8/test/mjsunit/stack-traces.js +39 -1
  662. data/vendor/v8/test/mjsunit/str-to-num.js +7 -2
  663. data/vendor/v8/test/mjsunit/strict-mode.js +36 -11
  664. data/vendor/v8/test/mjsunit/string-charcodeat.js +3 -0
  665. data/vendor/v8/test/mjsunit/string-natives.js +72 -0
  666. data/vendor/v8/test/mjsunit/string-split.js +17 -0
  667. data/vendor/v8/test/mjsunit/testcfg.py +76 -6
  668. data/vendor/v8/test/mjsunit/tools/tickprocessor.js +4 -1
  669. data/vendor/v8/test/mjsunit/try-finally-continue.js +72 -0
  670. data/vendor/v8/test/mjsunit/typed-array-slice.js +61 -0
  671. data/vendor/v8/test/mjsunit/unbox-double-arrays.js +2 -0
  672. data/vendor/v8/test/mjsunit/uri.js +12 -0
  673. data/vendor/v8/test/mjsunit/with-readonly.js +4 -2
  674. data/vendor/v8/test/mozilla/mozilla.status +19 -113
  675. data/vendor/v8/test/mozilla/testcfg.py +122 -3
  676. data/vendor/v8/test/preparser/preparser.status +5 -0
  677. data/vendor/v8/test/preparser/strict-identifiers.pyt +1 -1
  678. data/vendor/v8/test/preparser/testcfg.py +101 -5
  679. data/vendor/v8/test/sputnik/sputnik.status +1 -1
  680. data/vendor/v8/test/sputnik/testcfg.py +5 -0
  681. data/vendor/v8/test/test262/README +2 -2
  682. data/vendor/v8/test/test262/test262.status +13 -36
  683. data/vendor/v8/test/test262/testcfg.py +102 -8
  684. data/vendor/v8/tools/android-build.sh +0 -0
  685. data/vendor/v8/tools/android-ll-prof.sh +69 -0
  686. data/vendor/v8/tools/android-run.py +109 -0
  687. data/vendor/v8/tools/android-sync.sh +105 -0
  688. data/vendor/v8/tools/bash-completion.sh +0 -0
  689. data/vendor/v8/tools/check-static-initializers.sh +0 -0
  690. data/vendor/v8/tools/common-includes.sh +15 -22
  691. data/vendor/v8/tools/disasm.py +4 -4
  692. data/vendor/v8/tools/fuzz-harness.sh +0 -0
  693. data/vendor/v8/tools/gen-postmortem-metadata.py +6 -8
  694. data/vendor/v8/tools/grokdump.py +404 -129
  695. data/vendor/v8/tools/gyp/v8.gyp +105 -43
  696. data/vendor/v8/tools/linux-tick-processor +5 -5
  697. data/vendor/v8/tools/ll_prof.py +75 -15
  698. data/vendor/v8/tools/merge-to-branch.sh +2 -2
  699. data/vendor/v8/tools/plot-timer-events +70 -0
  700. data/vendor/v8/tools/plot-timer-events.js +510 -0
  701. data/vendor/v8/tools/presubmit.py +1 -0
  702. data/vendor/v8/tools/push-to-trunk.sh +14 -4
  703. data/vendor/v8/tools/run-llprof.sh +69 -0
  704. data/vendor/v8/tools/run-tests.py +372 -0
  705. data/vendor/v8/tools/run-valgrind.py +1 -1
  706. data/vendor/v8/tools/status-file-converter.py +39 -0
  707. data/vendor/v8/tools/test-server.py +224 -0
  708. data/vendor/v8/tools/test-wrapper-gypbuild.py +13 -16
  709. data/vendor/v8/tools/test.py +10 -19
  710. data/vendor/v8/tools/testrunner/README +174 -0
  711. data/vendor/v8/tools/testrunner/__init__.py +26 -0
  712. data/vendor/v8/tools/testrunner/local/__init__.py +26 -0
  713. data/vendor/v8/tools/testrunner/local/commands.py +153 -0
  714. data/vendor/v8/tools/testrunner/local/execution.py +182 -0
  715. data/vendor/v8/tools/testrunner/local/old_statusfile.py +460 -0
  716. data/vendor/v8/tools/testrunner/local/progress.py +238 -0
  717. data/vendor/v8/tools/testrunner/local/statusfile.py +145 -0
  718. data/vendor/v8/tools/testrunner/local/testsuite.py +187 -0
  719. data/vendor/v8/tools/testrunner/local/utils.py +108 -0
  720. data/vendor/v8/tools/testrunner/local/verbose.py +99 -0
  721. data/vendor/v8/tools/testrunner/network/__init__.py +26 -0
  722. data/vendor/v8/tools/testrunner/network/distro.py +90 -0
  723. data/vendor/v8/tools/testrunner/network/endpoint.py +124 -0
  724. data/vendor/v8/tools/testrunner/network/network_execution.py +253 -0
  725. data/vendor/v8/tools/testrunner/network/perfdata.py +120 -0
  726. data/vendor/v8/tools/testrunner/objects/__init__.py +26 -0
  727. data/vendor/v8/tools/testrunner/objects/context.py +50 -0
  728. data/vendor/v8/tools/testrunner/objects/output.py +60 -0
  729. data/vendor/v8/tools/testrunner/objects/peer.py +80 -0
  730. data/vendor/v8/tools/testrunner/objects/testcase.py +83 -0
  731. data/vendor/v8/tools/testrunner/objects/workpacket.py +90 -0
  732. data/vendor/v8/tools/testrunner/server/__init__.py +26 -0
  733. data/vendor/v8/tools/testrunner/server/compression.py +111 -0
  734. data/vendor/v8/tools/testrunner/server/constants.py +51 -0
  735. data/vendor/v8/tools/testrunner/server/daemon.py +147 -0
  736. data/vendor/v8/tools/testrunner/server/local_handler.py +119 -0
  737. data/vendor/v8/tools/testrunner/server/main.py +245 -0
  738. data/vendor/v8/tools/testrunner/server/presence_handler.py +120 -0
  739. data/vendor/v8/tools/testrunner/server/signatures.py +63 -0
  740. data/vendor/v8/tools/testrunner/server/status_handler.py +112 -0
  741. data/vendor/v8/tools/testrunner/server/work_handler.py +150 -0
  742. data/vendor/v8/tools/tick-processor.html +168 -0
  743. data/vendor/v8/tools/tickprocessor-driver.js +5 -3
  744. data/vendor/v8/tools/tickprocessor.js +58 -15
  745. metadata +534 -30
  746. data/patches/add-freebsd9-and-freebsd10-to-gyp-GetFlavor.patch +0 -11
  747. data/patches/do-not-imply-vfp3-and-armv7.patch +0 -44
  748. data/patches/fPIC-on-x64.patch +0 -14
  749. data/vendor/v8/src/liveobjectlist-inl.h +0 -126
  750. data/vendor/v8/src/liveobjectlist.cc +0 -2631
  751. data/vendor/v8/src/liveobjectlist.h +0 -319
  752. data/vendor/v8/test/mjsunit/mul-exhaustive.js +0 -4629
  753. data/vendor/v8/test/mjsunit/numops-fuzz.js +0 -4609
  754. data/vendor/v8/test/mjsunit/regress/regress-1969.js +0 -5045
@@ -65,6 +65,9 @@ namespace v8 {
65
65
  namespace internal {
66
66
 
67
67
 
68
+ static const int kPackedSizeNotKnown = -1;
69
+
70
+
68
71
  // First argument in list is the accessor class, the second argument is the
69
72
  // accessor ElementsKind, and the third is the backing store class. Use the
70
73
  // fast element handler for smi-only arrays. The implementation is currently
@@ -143,33 +146,36 @@ static Failure* ThrowArrayLengthRangeError(Heap* heap) {
143
146
  }
144
147
 
145
148
 
146
- void CopyObjectToObjectElements(FixedArray* from,
147
- ElementsKind from_kind,
148
- uint32_t from_start,
149
- FixedArray* to,
150
- ElementsKind to_kind,
151
- uint32_t to_start,
152
- int raw_copy_size) {
153
- ASSERT(to->map() != HEAP->fixed_cow_array_map());
149
+ static void CopyObjectToObjectElements(FixedArrayBase* from_base,
150
+ ElementsKind from_kind,
151
+ uint32_t from_start,
152
+ FixedArrayBase* to_base,
153
+ ElementsKind to_kind,
154
+ uint32_t to_start,
155
+ int raw_copy_size) {
156
+ ASSERT(to_base->map() != HEAP->fixed_cow_array_map());
157
+ AssertNoAllocation no_allocation;
154
158
  int copy_size = raw_copy_size;
155
159
  if (raw_copy_size < 0) {
156
160
  ASSERT(raw_copy_size == ElementsAccessor::kCopyToEnd ||
157
161
  raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole);
158
- copy_size = Min(from->length() - from_start,
159
- to->length() - to_start);
160
- #ifdef DEBUG
161
- // FAST_*_ELEMENTS arrays cannot be uninitialized. Ensure they are already
162
- // marked with the hole.
162
+ copy_size = Min(from_base->length() - from_start,
163
+ to_base->length() - to_start);
163
164
  if (raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole) {
164
- for (int i = to_start + copy_size; i < to->length(); ++i) {
165
- ASSERT(to->get(i)->IsTheHole());
165
+ int start = to_start + copy_size;
166
+ int length = to_base->length() - start;
167
+ if (length > 0) {
168
+ Heap* heap = from_base->GetHeap();
169
+ MemsetPointer(FixedArray::cast(to_base)->data_start() + start,
170
+ heap->the_hole_value(), length);
166
171
  }
167
172
  }
168
- #endif
169
173
  }
170
- ASSERT((copy_size + static_cast<int>(to_start)) <= to->length() &&
171
- (copy_size + static_cast<int>(from_start)) <= from->length());
174
+ ASSERT((copy_size + static_cast<int>(to_start)) <= to_base->length() &&
175
+ (copy_size + static_cast<int>(from_start)) <= from_base->length());
172
176
  if (copy_size == 0) return;
177
+ FixedArray* from = FixedArray::cast(from_base);
178
+ FixedArray* to = FixedArray::cast(to_base);
173
179
  ASSERT(IsFastSmiOrObjectElementsKind(from_kind));
174
180
  ASSERT(IsFastSmiOrObjectElementsKind(to_kind));
175
181
  Address to_address = to->address() + FixedArray::kHeaderSize;
@@ -190,31 +196,34 @@ void CopyObjectToObjectElements(FixedArray* from,
190
196
  }
191
197
 
192
198
 
193
- static void CopyDictionaryToObjectElements(SeededNumberDictionary* from,
199
+ static void CopyDictionaryToObjectElements(FixedArrayBase* from_base,
194
200
  uint32_t from_start,
195
- FixedArray* to,
201
+ FixedArrayBase* to_base,
196
202
  ElementsKind to_kind,
197
203
  uint32_t to_start,
198
204
  int raw_copy_size) {
205
+ SeededNumberDictionary* from = SeededNumberDictionary::cast(from_base);
206
+ AssertNoAllocation no_allocation;
199
207
  int copy_size = raw_copy_size;
200
208
  Heap* heap = from->GetHeap();
201
209
  if (raw_copy_size < 0) {
202
210
  ASSERT(raw_copy_size == ElementsAccessor::kCopyToEnd ||
203
211
  raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole);
204
212
  copy_size = from->max_number_key() + 1 - from_start;
205
- #ifdef DEBUG
206
- // Fast object arrays cannot be uninitialized. Ensure they are already
207
- // marked with the hole.
208
213
  if (raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole) {
209
- for (int i = to_start + copy_size; i < to->length(); ++i) {
210
- ASSERT(to->get(i)->IsTheHole());
214
+ int start = to_start + copy_size;
215
+ int length = to_base->length() - start;
216
+ if (length > 0) {
217
+ Heap* heap = from->GetHeap();
218
+ MemsetPointer(FixedArray::cast(to_base)->data_start() + start,
219
+ heap->the_hole_value(), length);
211
220
  }
212
221
  }
213
- #endif
214
222
  }
215
- ASSERT(to != from);
223
+ ASSERT(to_base != from_base);
216
224
  ASSERT(IsFastSmiOrObjectElementsKind(to_kind));
217
225
  if (copy_size == 0) return;
226
+ FixedArray* to = FixedArray::cast(to_base);
218
227
  uint32_t to_length = to->length();
219
228
  if (to_start + copy_size > to_length) {
220
229
  copy_size = to_length - to_start;
@@ -241,9 +250,9 @@ static void CopyDictionaryToObjectElements(SeededNumberDictionary* from,
241
250
 
242
251
 
243
252
  MUST_USE_RESULT static MaybeObject* CopyDoubleToObjectElements(
244
- FixedDoubleArray* from,
253
+ FixedArrayBase* from_base,
245
254
  uint32_t from_start,
246
- FixedArray* to,
255
+ FixedArrayBase* to_base,
247
256
  ElementsKind to_kind,
248
257
  uint32_t to_start,
249
258
  int raw_copy_size) {
@@ -252,21 +261,26 @@ MUST_USE_RESULT static MaybeObject* CopyDoubleToObjectElements(
252
261
  if (raw_copy_size < 0) {
253
262
  ASSERT(raw_copy_size == ElementsAccessor::kCopyToEnd ||
254
263
  raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole);
255
- copy_size = Min(from->length() - from_start,
256
- to->length() - to_start);
257
- #ifdef DEBUG
258
- // FAST_*_ELEMENTS arrays cannot be uninitialized. Ensure they are already
259
- // marked with the hole.
264
+ copy_size = Min(from_base->length() - from_start,
265
+ to_base->length() - to_start);
260
266
  if (raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole) {
261
- for (int i = to_start + copy_size; i < to->length(); ++i) {
262
- ASSERT(to->get(i)->IsTheHole());
267
+ // Also initialize the area that will be copied over since HeapNumber
268
+ // allocation below can cause an incremental marking step, requiring all
269
+ // existing heap objects to be propertly initialized.
270
+ int start = to_start;
271
+ int length = to_base->length() - start;
272
+ if (length > 0) {
273
+ Heap* heap = from_base->GetHeap();
274
+ MemsetPointer(FixedArray::cast(to_base)->data_start() + start,
275
+ heap->the_hole_value(), length);
263
276
  }
264
277
  }
265
- #endif
266
278
  }
267
- ASSERT((copy_size + static_cast<int>(to_start)) <= to->length() &&
268
- (copy_size + static_cast<int>(from_start)) <= from->length());
269
- if (copy_size == 0) return from;
279
+ ASSERT((copy_size + static_cast<int>(to_start)) <= to_base->length() &&
280
+ (copy_size + static_cast<int>(from_start)) <= from_base->length());
281
+ if (copy_size == 0) return from_base;
282
+ FixedDoubleArray* from = FixedDoubleArray::cast(from_base);
283
+ FixedArray* to = FixedArray::cast(to_base);
270
284
  for (int i = 0; i < copy_size; ++i) {
271
285
  if (IsFastSmiElementsKind(to_kind)) {
272
286
  UNIMPLEMENTED();
@@ -295,26 +309,28 @@ MUST_USE_RESULT static MaybeObject* CopyDoubleToObjectElements(
295
309
  }
296
310
 
297
311
 
298
- static void CopyDoubleToDoubleElements(FixedDoubleArray* from,
312
+ static void CopyDoubleToDoubleElements(FixedArrayBase* from_base,
299
313
  uint32_t from_start,
300
- FixedDoubleArray* to,
314
+ FixedArrayBase* to_base,
301
315
  uint32_t to_start,
302
316
  int raw_copy_size) {
303
317
  int copy_size = raw_copy_size;
304
318
  if (raw_copy_size < 0) {
305
319
  ASSERT(raw_copy_size == ElementsAccessor::kCopyToEnd ||
306
320
  raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole);
307
- copy_size = Min(from->length() - from_start,
308
- to->length() - to_start);
321
+ copy_size = Min(from_base->length() - from_start,
322
+ to_base->length() - to_start);
309
323
  if (raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole) {
310
- for (int i = to_start + copy_size; i < to->length(); ++i) {
311
- to->set_the_hole(i);
324
+ for (int i = to_start + copy_size; i < to_base->length(); ++i) {
325
+ FixedDoubleArray::cast(to_base)->set_the_hole(i);
312
326
  }
313
327
  }
314
328
  }
315
- ASSERT((copy_size + static_cast<int>(to_start)) <= to->length() &&
316
- (copy_size + static_cast<int>(from_start)) <= from->length());
329
+ ASSERT((copy_size + static_cast<int>(to_start)) <= to_base->length() &&
330
+ (copy_size + static_cast<int>(from_start)) <= from_base->length());
317
331
  if (copy_size == 0) return;
332
+ FixedDoubleArray* from = FixedDoubleArray::cast(from_base);
333
+ FixedDoubleArray* to = FixedDoubleArray::cast(to_base);
318
334
  Address to_address = to->address() + FixedDoubleArray::kHeaderSize;
319
335
  Address from_address = from->address() + FixedDoubleArray::kHeaderSize;
320
336
  to_address += kDoubleSize * to_start;
@@ -326,53 +342,132 @@ static void CopyDoubleToDoubleElements(FixedDoubleArray* from,
326
342
  }
327
343
 
328
344
 
329
- static void CopyObjectToDoubleElements(FixedArray* from,
345
+ static void CopySmiToDoubleElements(FixedArrayBase* from_base,
346
+ uint32_t from_start,
347
+ FixedArrayBase* to_base,
348
+ uint32_t to_start,
349
+ int raw_copy_size) {
350
+ int copy_size = raw_copy_size;
351
+ if (raw_copy_size < 0) {
352
+ ASSERT(raw_copy_size == ElementsAccessor::kCopyToEnd ||
353
+ raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole);
354
+ copy_size = from_base->length() - from_start;
355
+ if (raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole) {
356
+ for (int i = to_start + copy_size; i < to_base->length(); ++i) {
357
+ FixedDoubleArray::cast(to_base)->set_the_hole(i);
358
+ }
359
+ }
360
+ }
361
+ ASSERT((copy_size + static_cast<int>(to_start)) <= to_base->length() &&
362
+ (copy_size + static_cast<int>(from_start)) <= from_base->length());
363
+ if (copy_size == 0) return;
364
+ FixedArray* from = FixedArray::cast(from_base);
365
+ FixedDoubleArray* to = FixedDoubleArray::cast(to_base);
366
+ Object* the_hole = from->GetHeap()->the_hole_value();
367
+ for (uint32_t from_end = from_start + static_cast<uint32_t>(copy_size);
368
+ from_start < from_end; from_start++, to_start++) {
369
+ Object* hole_or_smi = from->get(from_start);
370
+ if (hole_or_smi == the_hole) {
371
+ to->set_the_hole(to_start);
372
+ } else {
373
+ to->set(to_start, Smi::cast(hole_or_smi)->value());
374
+ }
375
+ }
376
+ }
377
+
378
+
379
+ static void CopyPackedSmiToDoubleElements(FixedArrayBase* from_base,
380
+ uint32_t from_start,
381
+ FixedArrayBase* to_base,
382
+ uint32_t to_start,
383
+ int packed_size,
384
+ int raw_copy_size) {
385
+ int copy_size = raw_copy_size;
386
+ uint32_t to_end;
387
+ if (raw_copy_size < 0) {
388
+ ASSERT(raw_copy_size == ElementsAccessor::kCopyToEnd ||
389
+ raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole);
390
+ copy_size = packed_size - from_start;
391
+ if (raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole) {
392
+ to_end = to_base->length();
393
+ for (uint32_t i = to_start + copy_size; i < to_end; ++i) {
394
+ FixedDoubleArray::cast(to_base)->set_the_hole(i);
395
+ }
396
+ } else {
397
+ to_end = to_start + static_cast<uint32_t>(copy_size);
398
+ }
399
+ } else {
400
+ to_end = to_start + static_cast<uint32_t>(copy_size);
401
+ }
402
+ ASSERT(static_cast<int>(to_end) <= to_base->length());
403
+ ASSERT(packed_size >= 0 && packed_size <= copy_size);
404
+ ASSERT((copy_size + static_cast<int>(to_start)) <= to_base->length() &&
405
+ (copy_size + static_cast<int>(from_start)) <= from_base->length());
406
+ if (copy_size == 0) return;
407
+ FixedArray* from = FixedArray::cast(from_base);
408
+ FixedDoubleArray* to = FixedDoubleArray::cast(to_base);
409
+ for (uint32_t from_end = from_start + static_cast<uint32_t>(packed_size);
410
+ from_start < from_end; from_start++, to_start++) {
411
+ Object* smi = from->get(from_start);
412
+ ASSERT(!smi->IsTheHole());
413
+ to->set(to_start, Smi::cast(smi)->value());
414
+ }
415
+ }
416
+
417
+
418
+ static void CopyObjectToDoubleElements(FixedArrayBase* from_base,
330
419
  uint32_t from_start,
331
- FixedDoubleArray* to,
420
+ FixedArrayBase* to_base,
332
421
  uint32_t to_start,
333
422
  int raw_copy_size) {
334
423
  int copy_size = raw_copy_size;
335
424
  if (raw_copy_size < 0) {
336
425
  ASSERT(raw_copy_size == ElementsAccessor::kCopyToEnd ||
337
426
  raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole);
338
- copy_size = from->length() - from_start;
427
+ copy_size = from_base->length() - from_start;
339
428
  if (raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole) {
340
- for (int i = to_start + copy_size; i < to->length(); ++i) {
341
- to->set_the_hole(i);
429
+ for (int i = to_start + copy_size; i < to_base->length(); ++i) {
430
+ FixedDoubleArray::cast(to_base)->set_the_hole(i);
342
431
  }
343
432
  }
344
433
  }
345
- ASSERT((copy_size + static_cast<int>(to_start)) <= to->length() &&
346
- (copy_size + static_cast<int>(from_start)) <= from->length());
434
+ ASSERT((copy_size + static_cast<int>(to_start)) <= to_base->length() &&
435
+ (copy_size + static_cast<int>(from_start)) <= from_base->length());
347
436
  if (copy_size == 0) return;
348
- for (int i = 0; i < copy_size; i++) {
349
- Object* hole_or_object = from->get(i + from_start);
350
- if (hole_or_object->IsTheHole()) {
351
- to->set_the_hole(i + to_start);
437
+ FixedArray* from = FixedArray::cast(from_base);
438
+ FixedDoubleArray* to = FixedDoubleArray::cast(to_base);
439
+ Object* the_hole = from->GetHeap()->the_hole_value();
440
+ for (uint32_t from_end = from_start + copy_size;
441
+ from_start < from_end; from_start++, to_start++) {
442
+ Object* hole_or_object = from->get(from_start);
443
+ if (hole_or_object == the_hole) {
444
+ to->set_the_hole(to_start);
352
445
  } else {
353
- to->set(i + to_start, hole_or_object->Number());
446
+ to->set(to_start, hole_or_object->Number());
354
447
  }
355
448
  }
356
449
  }
357
450
 
358
451
 
359
- static void CopyDictionaryToDoubleElements(SeededNumberDictionary* from,
452
+ static void CopyDictionaryToDoubleElements(FixedArrayBase* from_base,
360
453
  uint32_t from_start,
361
- FixedDoubleArray* to,
454
+ FixedArrayBase* to_base,
362
455
  uint32_t to_start,
363
456
  int raw_copy_size) {
457
+ SeededNumberDictionary* from = SeededNumberDictionary::cast(from_base);
364
458
  int copy_size = raw_copy_size;
365
459
  if (copy_size < 0) {
366
460
  ASSERT(copy_size == ElementsAccessor::kCopyToEnd ||
367
461
  copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole);
368
462
  copy_size = from->max_number_key() + 1 - from_start;
369
463
  if (raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole) {
370
- for (int i = to_start + copy_size; i < to->length(); ++i) {
371
- to->set_the_hole(i);
464
+ for (int i = to_start + copy_size; i < to_base->length(); ++i) {
465
+ FixedDoubleArray::cast(to_base)->set_the_hole(i);
372
466
  }
373
467
  }
374
468
  }
375
469
  if (copy_size == 0) return;
470
+ FixedDoubleArray* to = FixedDoubleArray::cast(to_base);
376
471
  uint32_t to_length = to->length();
377
472
  if (to_start + copy_size > to_length) {
378
473
  copy_size = to_length - to_start;
@@ -428,8 +523,8 @@ class ElementsAccessorBase : public ElementsAccessor {
428
523
  Map* map = fixed_array_base->map();
429
524
  // Arrays that have been shifted in place can't be verified.
430
525
  Heap* heap = holder->GetHeap();
431
- if (map == heap->raw_unchecked_one_pointer_filler_map() ||
432
- map == heap->raw_unchecked_two_pointer_filler_map() ||
526
+ if (map == heap->one_pointer_filler_map() ||
527
+ map == heap->two_pointer_filler_map() ||
433
528
  map == heap->free_space_map()) {
434
529
  return;
435
530
  }
@@ -452,10 +547,9 @@ class ElementsAccessorBase : public ElementsAccessor {
452
547
  static bool HasElementImpl(Object* receiver,
453
548
  JSObject* holder,
454
549
  uint32_t key,
455
- BackingStore* backing_store) {
456
- MaybeObject* element =
457
- ElementsAccessorSubclass::GetImpl(receiver, holder, key, backing_store);
458
- return !element->IsTheHole();
550
+ FixedArrayBase* backing_store) {
551
+ return ElementsAccessorSubclass::GetAttributesImpl(
552
+ receiver, holder, key, backing_store) != ABSENT;
459
553
  }
460
554
 
461
555
  virtual bool HasElement(Object* receiver,
@@ -466,7 +560,7 @@ class ElementsAccessorBase : public ElementsAccessor {
466
560
  backing_store = holder->elements();
467
561
  }
468
562
  return ElementsAccessorSubclass::HasElementImpl(
469
- receiver, holder, key, BackingStore::cast(backing_store));
563
+ receiver, holder, key, backing_store);
470
564
  }
471
565
 
472
566
  MUST_USE_RESULT virtual MaybeObject* Get(Object* receiver,
@@ -477,28 +571,95 @@ class ElementsAccessorBase : public ElementsAccessor {
477
571
  backing_store = holder->elements();
478
572
  }
479
573
  return ElementsAccessorSubclass::GetImpl(
480
- receiver, holder, key, BackingStore::cast(backing_store));
574
+ receiver, holder, key, backing_store);
481
575
  }
482
576
 
483
577
  MUST_USE_RESULT static MaybeObject* GetImpl(Object* receiver,
484
578
  JSObject* obj,
485
579
  uint32_t key,
486
- BackingStore* backing_store) {
580
+ FixedArrayBase* backing_store) {
487
581
  return (key < ElementsAccessorSubclass::GetCapacityImpl(backing_store))
488
- ? backing_store->get(key)
582
+ ? BackingStore::cast(backing_store)->get(key)
489
583
  : backing_store->GetHeap()->the_hole_value();
490
584
  }
491
585
 
586
+ MUST_USE_RESULT virtual PropertyAttributes GetAttributes(
587
+ Object* receiver,
588
+ JSObject* holder,
589
+ uint32_t key,
590
+ FixedArrayBase* backing_store) {
591
+ if (backing_store == NULL) {
592
+ backing_store = holder->elements();
593
+ }
594
+ return ElementsAccessorSubclass::GetAttributesImpl(
595
+ receiver, holder, key, backing_store);
596
+ }
597
+
598
+ MUST_USE_RESULT static PropertyAttributes GetAttributesImpl(
599
+ Object* receiver,
600
+ JSObject* obj,
601
+ uint32_t key,
602
+ FixedArrayBase* backing_store) {
603
+ if (key >= ElementsAccessorSubclass::GetCapacityImpl(backing_store)) {
604
+ return ABSENT;
605
+ }
606
+ return BackingStore::cast(backing_store)->is_the_hole(key) ? ABSENT : NONE;
607
+ }
608
+
609
+ MUST_USE_RESULT virtual PropertyType GetType(
610
+ Object* receiver,
611
+ JSObject* holder,
612
+ uint32_t key,
613
+ FixedArrayBase* backing_store) {
614
+ if (backing_store == NULL) {
615
+ backing_store = holder->elements();
616
+ }
617
+ return ElementsAccessorSubclass::GetTypeImpl(
618
+ receiver, holder, key, backing_store);
619
+ }
620
+
621
+ MUST_USE_RESULT static PropertyType GetTypeImpl(
622
+ Object* receiver,
623
+ JSObject* obj,
624
+ uint32_t key,
625
+ FixedArrayBase* backing_store) {
626
+ if (key >= ElementsAccessorSubclass::GetCapacityImpl(backing_store)) {
627
+ return NONEXISTENT;
628
+ }
629
+ return BackingStore::cast(backing_store)->is_the_hole(key)
630
+ ? NONEXISTENT : FIELD;
631
+ }
632
+
633
+ MUST_USE_RESULT virtual AccessorPair* GetAccessorPair(
634
+ Object* receiver,
635
+ JSObject* holder,
636
+ uint32_t key,
637
+ FixedArrayBase* backing_store) {
638
+ if (backing_store == NULL) {
639
+ backing_store = holder->elements();
640
+ }
641
+ return ElementsAccessorSubclass::GetAccessorPairImpl(
642
+ receiver, holder, key, backing_store);
643
+ }
644
+
645
+ MUST_USE_RESULT static AccessorPair* GetAccessorPairImpl(
646
+ Object* receiver,
647
+ JSObject* obj,
648
+ uint32_t key,
649
+ FixedArrayBase* backing_store) {
650
+ return NULL;
651
+ }
652
+
492
653
  MUST_USE_RESULT virtual MaybeObject* SetLength(JSArray* array,
493
654
  Object* length) {
494
655
  return ElementsAccessorSubclass::SetLengthImpl(
495
- array, length, BackingStore::cast(array->elements()));
656
+ array, length, array->elements());
496
657
  }
497
658
 
498
659
  MUST_USE_RESULT static MaybeObject* SetLengthImpl(
499
660
  JSObject* obj,
500
661
  Object* length,
501
- BackingStore* backing_store);
662
+ FixedArrayBase* backing_store);
502
663
 
503
664
  MUST_USE_RESULT virtual MaybeObject* SetCapacityAndLength(
504
665
  JSArray* array,
@@ -525,8 +686,9 @@ class ElementsAccessorBase : public ElementsAccessor {
525
686
  MUST_USE_RESULT static MaybeObject* CopyElementsImpl(FixedArrayBase* from,
526
687
  uint32_t from_start,
527
688
  FixedArrayBase* to,
528
- ElementsKind to_kind,
689
+ ElementsKind from_kind,
529
690
  uint32_t to_start,
691
+ int packed_size,
530
692
  int copy_size) {
531
693
  UNREACHABLE();
532
694
  return NULL;
@@ -534,19 +696,28 @@ class ElementsAccessorBase : public ElementsAccessor {
534
696
 
535
697
  MUST_USE_RESULT virtual MaybeObject* CopyElements(JSObject* from_holder,
536
698
  uint32_t from_start,
699
+ ElementsKind from_kind,
537
700
  FixedArrayBase* to,
538
- ElementsKind to_kind,
539
701
  uint32_t to_start,
540
702
  int copy_size,
541
703
  FixedArrayBase* from) {
704
+ int packed_size = kPackedSizeNotKnown;
542
705
  if (from == NULL) {
543
706
  from = from_holder->elements();
544
707
  }
545
- if (from->length() == 0) {
546
- return from;
708
+
709
+ if (from_holder) {
710
+ bool is_packed = IsFastPackedElementsKind(from_kind) &&
711
+ from_holder->IsJSArray();
712
+ if (is_packed) {
713
+ packed_size = Smi::cast(JSArray::cast(from_holder)->length())->value();
714
+ if (copy_size >= 0 && packed_size > copy_size) {
715
+ packed_size = copy_size;
716
+ }
717
+ }
547
718
  }
548
719
  return ElementsAccessorSubclass::CopyElementsImpl(
549
- from, from_start, to, to_kind, to_start, copy_size);
720
+ from, from_start, to, from_kind, to_start, packed_size, copy_size);
550
721
  }
551
722
 
552
723
  MUST_USE_RESULT virtual MaybeObject* AddElementsToFixedArray(
@@ -565,25 +736,22 @@ class ElementsAccessorBase : public ElementsAccessor {
565
736
  if (from == NULL) {
566
737
  from = holder->elements();
567
738
  }
568
- BackingStore* backing_store = BackingStore::cast(from);
569
- uint32_t len1 = ElementsAccessorSubclass::GetCapacityImpl(backing_store);
570
739
 
571
740
  // Optimize if 'other' is empty.
572
741
  // We cannot optimize if 'this' is empty, as other may have holes.
742
+ uint32_t len1 = ElementsAccessorSubclass::GetCapacityImpl(from);
573
743
  if (len1 == 0) return to;
574
744
 
575
745
  // Compute how many elements are not in other.
576
746
  uint32_t extra = 0;
577
747
  for (uint32_t y = 0; y < len1; y++) {
578
- uint32_t key =
579
- ElementsAccessorSubclass::GetKeyForIndexImpl(backing_store, y);
748
+ uint32_t key = ElementsAccessorSubclass::GetKeyForIndexImpl(from, y);
580
749
  if (ElementsAccessorSubclass::HasElementImpl(
581
- receiver, holder, key, backing_store)) {
750
+ receiver, holder, key, from)) {
582
751
  MaybeObject* maybe_value =
583
- ElementsAccessorSubclass::GetImpl(receiver, holder,
584
- key, backing_store);
752
+ ElementsAccessorSubclass::GetImpl(receiver, holder, key, from);
585
753
  Object* value;
586
- if (!maybe_value->ToObject(&value)) return maybe_value;
754
+ if (!maybe_value->To(&value)) return maybe_value;
587
755
  ASSERT(!value->IsTheHole());
588
756
  if (!HasKey(to, value)) {
589
757
  extra++;
@@ -595,9 +763,8 @@ class ElementsAccessorBase : public ElementsAccessor {
595
763
 
596
764
  // Allocate the result
597
765
  FixedArray* result;
598
- MaybeObject* maybe_obj =
599
- backing_store->GetHeap()->AllocateFixedArray(len0 + extra);
600
- if (!maybe_obj->To<FixedArray>(&result)) return maybe_obj;
766
+ MaybeObject* maybe_obj = from->GetHeap()->AllocateFixedArray(len0 + extra);
767
+ if (!maybe_obj->To(&result)) return maybe_obj;
601
768
 
602
769
  // Fill in the content
603
770
  {
@@ -613,14 +780,13 @@ class ElementsAccessorBase : public ElementsAccessor {
613
780
  uint32_t index = 0;
614
781
  for (uint32_t y = 0; y < len1; y++) {
615
782
  uint32_t key =
616
- ElementsAccessorSubclass::GetKeyForIndexImpl(backing_store, y);
783
+ ElementsAccessorSubclass::GetKeyForIndexImpl(from, y);
617
784
  if (ElementsAccessorSubclass::HasElementImpl(
618
- receiver, holder, key, backing_store)) {
785
+ receiver, holder, key, from)) {
619
786
  MaybeObject* maybe_value =
620
- ElementsAccessorSubclass::GetImpl(receiver, holder,
621
- key, backing_store);
787
+ ElementsAccessorSubclass::GetImpl(receiver, holder, key, from);
622
788
  Object* value;
623
- if (!maybe_value->ToObject(&value)) return maybe_value;
789
+ if (!maybe_value->To(&value)) return maybe_value;
624
790
  if (!value->IsTheHole() && !HasKey(to, value)) {
625
791
  result->set(len0 + index, value);
626
792
  index++;
@@ -632,24 +798,22 @@ class ElementsAccessorBase : public ElementsAccessor {
632
798
  }
633
799
 
634
800
  protected:
635
- static uint32_t GetCapacityImpl(BackingStore* backing_store) {
801
+ static uint32_t GetCapacityImpl(FixedArrayBase* backing_store) {
636
802
  return backing_store->length();
637
803
  }
638
804
 
639
805
  virtual uint32_t GetCapacity(FixedArrayBase* backing_store) {
640
- return ElementsAccessorSubclass::GetCapacityImpl(
641
- BackingStore::cast(backing_store));
806
+ return ElementsAccessorSubclass::GetCapacityImpl(backing_store);
642
807
  }
643
808
 
644
- static uint32_t GetKeyForIndexImpl(BackingStore* backing_store,
809
+ static uint32_t GetKeyForIndexImpl(FixedArrayBase* backing_store,
645
810
  uint32_t index) {
646
811
  return index;
647
812
  }
648
813
 
649
814
  virtual uint32_t GetKeyForIndex(FixedArrayBase* backing_store,
650
815
  uint32_t index) {
651
- return ElementsAccessorSubclass::GetKeyForIndexImpl(
652
- BackingStore::cast(backing_store), index);
816
+ return ElementsAccessorSubclass::GetKeyForIndexImpl(backing_store, index);
653
817
  }
654
818
 
655
819
  private:
@@ -675,17 +839,17 @@ class FastElementsAccessor
675
839
 
676
840
  // Adjusts the length of the fast backing store or returns the new length or
677
841
  // undefined in case conversion to a slow backing store should be performed.
678
- static MaybeObject* SetLengthWithoutNormalize(BackingStore* backing_store,
842
+ static MaybeObject* SetLengthWithoutNormalize(FixedArrayBase* backing_store,
679
843
  JSArray* array,
680
844
  Object* length_object,
681
845
  uint32_t length) {
682
846
  uint32_t old_capacity = backing_store->length();
683
847
  Object* old_length = array->length();
684
- bool same_size = old_length->IsSmi() &&
685
- static_cast<uint32_t>(Smi::cast(old_length)->value()) == length;
848
+ bool same_or_smaller_size = old_length->IsSmi() &&
849
+ static_cast<uint32_t>(Smi::cast(old_length)->value()) >= length;
686
850
  ElementsKind kind = array->GetElementsKind();
687
851
 
688
- if (!same_size && IsFastElementsKind(kind) &&
852
+ if (!same_or_smaller_size && IsFastElementsKind(kind) &&
689
853
  !IsFastHoleyElementsKind(kind)) {
690
854
  kind = GetHoleyElementsKind(kind);
691
855
  MaybeObject* maybe_obj = array->TransitionElementsKind(kind);
@@ -711,9 +875,9 @@ class FastElementsAccessor
711
875
  }
712
876
  } else {
713
877
  // Otherwise, fill the unused tail with holes.
714
- int old_length = FastD2I(array->length()->Number());
878
+ int old_length = FastD2IChecked(array->length()->Number());
715
879
  for (int i = length; i < old_length; i++) {
716
- backing_store->set_the_hole(i);
880
+ BackingStore::cast(backing_store)->set_the_hole(i);
717
881
  }
718
882
  }
719
883
  return length_object;
@@ -740,32 +904,38 @@ class FastElementsAccessor
740
904
  ASSERT(obj->HasFastSmiOrObjectElements() ||
741
905
  obj->HasFastDoubleElements() ||
742
906
  obj->HasFastArgumentsElements());
743
- typename KindTraits::BackingStore* backing_store =
744
- KindTraits::BackingStore::cast(obj->elements());
745
907
  Heap* heap = obj->GetHeap();
746
- if (backing_store->map() == heap->non_strict_arguments_elements_map()) {
747
- backing_store =
748
- KindTraits::BackingStore::cast(
749
- FixedArray::cast(backing_store)->get(1));
750
- } else {
751
- ElementsKind kind = KindTraits::Kind;
752
- if (IsFastPackedElementsKind(kind)) {
753
- MaybeObject* transitioned =
754
- obj->TransitionElementsKind(GetHoleyElementsKind(kind));
755
- if (transitioned->IsFailure()) return transitioned;
756
- }
757
- if (IsFastSmiOrObjectElementsKind(KindTraits::Kind)) {
758
- Object* writable;
759
- MaybeObject* maybe = obj->EnsureWritableFastElements();
760
- if (!maybe->ToObject(&writable)) return maybe;
761
- backing_store = KindTraits::BackingStore::cast(writable);
762
- }
908
+ Object* elements = obj->elements();
909
+ if (elements == heap->empty_fixed_array()) {
910
+ return heap->true_value();
911
+ }
912
+ typename KindTraits::BackingStore* backing_store =
913
+ KindTraits::BackingStore::cast(elements);
914
+ bool is_non_strict_arguments_elements_map =
915
+ backing_store->map() == heap->non_strict_arguments_elements_map();
916
+ if (is_non_strict_arguments_elements_map) {
917
+ backing_store = KindTraits::BackingStore::cast(
918
+ FixedArray::cast(backing_store)->get(1));
763
919
  }
764
920
  uint32_t length = static_cast<uint32_t>(
765
921
  obj->IsJSArray()
766
922
  ? Smi::cast(JSArray::cast(obj)->length())->value()
767
923
  : backing_store->length());
768
924
  if (key < length) {
925
+ if (!is_non_strict_arguments_elements_map) {
926
+ ElementsKind kind = KindTraits::Kind;
927
+ if (IsFastPackedElementsKind(kind)) {
928
+ MaybeObject* transitioned =
929
+ obj->TransitionElementsKind(GetHoleyElementsKind(kind));
930
+ if (transitioned->IsFailure()) return transitioned;
931
+ }
932
+ if (IsFastSmiOrObjectElementsKind(KindTraits::Kind)) {
933
+ Object* writable;
934
+ MaybeObject* maybe = obj->EnsureWritableFastElements();
935
+ if (!maybe->ToObject(&writable)) return maybe;
936
+ backing_store = KindTraits::BackingStore::cast(writable);
937
+ }
938
+ }
769
939
  backing_store->set_the_hole(key);
770
940
  // If an old space backing store is larger than a certain size and
771
941
  // has too few used values, normalize it.
@@ -801,11 +971,11 @@ class FastElementsAccessor
801
971
  Object* receiver,
802
972
  JSObject* holder,
803
973
  uint32_t key,
804
- typename KindTraits::BackingStore* backing_store) {
974
+ FixedArrayBase* backing_store) {
805
975
  if (key >= static_cast<uint32_t>(backing_store->length())) {
806
976
  return false;
807
977
  }
808
- return !backing_store->is_the_hole(key);
978
+ return !BackingStore::cast(backing_store)->is_the_hole(key);
809
979
  }
810
980
 
811
981
  static void ValidateContents(JSObject* holder, int length) {
@@ -832,6 +1002,41 @@ class FastElementsAccessor
832
1002
  };
833
1003
 
834
1004
 
1005
+ static inline ElementsKind ElementsKindForArray(FixedArrayBase* array) {
1006
+ switch (array->map()->instance_type()) {
1007
+ case FIXED_ARRAY_TYPE:
1008
+ if (array->IsDictionary()) {
1009
+ return DICTIONARY_ELEMENTS;
1010
+ } else {
1011
+ return FAST_HOLEY_ELEMENTS;
1012
+ }
1013
+ case FIXED_DOUBLE_ARRAY_TYPE:
1014
+ return FAST_HOLEY_DOUBLE_ELEMENTS;
1015
+ case EXTERNAL_BYTE_ARRAY_TYPE:
1016
+ return EXTERNAL_BYTE_ELEMENTS;
1017
+ case EXTERNAL_UNSIGNED_BYTE_ARRAY_TYPE:
1018
+ return EXTERNAL_UNSIGNED_BYTE_ELEMENTS;
1019
+ case EXTERNAL_SHORT_ARRAY_TYPE:
1020
+ return EXTERNAL_SHORT_ELEMENTS;
1021
+ case EXTERNAL_UNSIGNED_SHORT_ARRAY_TYPE:
1022
+ return EXTERNAL_UNSIGNED_SHORT_ELEMENTS;
1023
+ case EXTERNAL_INT_ARRAY_TYPE:
1024
+ return EXTERNAL_INT_ELEMENTS;
1025
+ case EXTERNAL_UNSIGNED_INT_ARRAY_TYPE:
1026
+ return EXTERNAL_UNSIGNED_INT_ELEMENTS;
1027
+ case EXTERNAL_FLOAT_ARRAY_TYPE:
1028
+ return EXTERNAL_FLOAT_ELEMENTS;
1029
+ case EXTERNAL_DOUBLE_ARRAY_TYPE:
1030
+ return EXTERNAL_DOUBLE_ELEMENTS;
1031
+ case EXTERNAL_PIXEL_ARRAY_TYPE:
1032
+ return EXTERNAL_PIXEL_ELEMENTS;
1033
+ default:
1034
+ UNREACHABLE();
1035
+ }
1036
+ return FAST_HOLEY_ELEMENTS;
1037
+ }
1038
+
1039
+
835
1040
  template<typename FastElementsAccessorSubclass,
836
1041
  typename KindTraits>
837
1042
  class FastSmiOrObjectElementsAccessor
@@ -847,21 +1052,49 @@ class FastSmiOrObjectElementsAccessor
847
1052
  static MaybeObject* CopyElementsImpl(FixedArrayBase* from,
848
1053
  uint32_t from_start,
849
1054
  FixedArrayBase* to,
850
- ElementsKind to_kind,
1055
+ ElementsKind from_kind,
851
1056
  uint32_t to_start,
1057
+ int packed_size,
852
1058
  int copy_size) {
853
- if (IsFastSmiOrObjectElementsKind(to_kind)) {
854
- CopyObjectToObjectElements(
855
- FixedArray::cast(from), KindTraits::Kind, from_start,
856
- FixedArray::cast(to), to_kind, to_start, copy_size);
857
- } else if (IsFastDoubleElementsKind(to_kind)) {
858
- CopyObjectToDoubleElements(
859
- FixedArray::cast(from), from_start,
860
- FixedDoubleArray::cast(to), to_start, copy_size);
861
- } else {
862
- UNREACHABLE();
1059
+ ElementsKind to_kind = KindTraits::Kind;
1060
+ switch (from_kind) {
1061
+ case FAST_SMI_ELEMENTS:
1062
+ case FAST_HOLEY_SMI_ELEMENTS:
1063
+ case FAST_ELEMENTS:
1064
+ case FAST_HOLEY_ELEMENTS:
1065
+ CopyObjectToObjectElements(
1066
+ from, from_kind, from_start, to, to_kind, to_start, copy_size);
1067
+ return to->GetHeap()->undefined_value();
1068
+ case FAST_DOUBLE_ELEMENTS:
1069
+ case FAST_HOLEY_DOUBLE_ELEMENTS:
1070
+ return CopyDoubleToObjectElements(
1071
+ from, from_start, to, to_kind, to_start, copy_size);
1072
+ case DICTIONARY_ELEMENTS:
1073
+ CopyDictionaryToObjectElements(
1074
+ from, from_start, to, to_kind, to_start, copy_size);
1075
+ return to->GetHeap()->undefined_value();
1076
+ case NON_STRICT_ARGUMENTS_ELEMENTS: {
1077
+ // TODO(verwaest): This is a temporary hack to support extending
1078
+ // NON_STRICT_ARGUMENTS_ELEMENTS in SetFastElementsCapacityAndLength.
1079
+ // This case should be UNREACHABLE().
1080
+ FixedArray* parameter_map = FixedArray::cast(from);
1081
+ FixedArrayBase* arguments = FixedArrayBase::cast(parameter_map->get(1));
1082
+ ElementsKind from_kind = ElementsKindForArray(arguments);
1083
+ return CopyElementsImpl(arguments, from_start, to, from_kind,
1084
+ to_start, packed_size, copy_size);
1085
+ }
1086
+ case EXTERNAL_BYTE_ELEMENTS:
1087
+ case EXTERNAL_UNSIGNED_BYTE_ELEMENTS:
1088
+ case EXTERNAL_SHORT_ELEMENTS:
1089
+ case EXTERNAL_UNSIGNED_SHORT_ELEMENTS:
1090
+ case EXTERNAL_INT_ELEMENTS:
1091
+ case EXTERNAL_UNSIGNED_INT_ELEMENTS:
1092
+ case EXTERNAL_FLOAT_ELEMENTS:
1093
+ case EXTERNAL_DOUBLE_ELEMENTS:
1094
+ case EXTERNAL_PIXEL_ELEMENTS:
1095
+ UNREACHABLE();
863
1096
  }
864
- return to->GetHeap()->undefined_value();
1097
+ return NULL;
865
1098
  }
866
1099
 
867
1100
 
@@ -950,24 +1183,40 @@ class FastDoubleElementsAccessor
950
1183
  static MaybeObject* CopyElementsImpl(FixedArrayBase* from,
951
1184
  uint32_t from_start,
952
1185
  FixedArrayBase* to,
953
- ElementsKind to_kind,
1186
+ ElementsKind from_kind,
954
1187
  uint32_t to_start,
1188
+ int packed_size,
955
1189
  int copy_size) {
956
- switch (to_kind) {
1190
+ switch (from_kind) {
957
1191
  case FAST_SMI_ELEMENTS:
958
- case FAST_ELEMENTS:
1192
+ CopyPackedSmiToDoubleElements(
1193
+ from, from_start, to, to_start, packed_size, copy_size);
1194
+ break;
959
1195
  case FAST_HOLEY_SMI_ELEMENTS:
960
- case FAST_HOLEY_ELEMENTS:
961
- return CopyDoubleToObjectElements(
962
- FixedDoubleArray::cast(from), from_start, FixedArray::cast(to),
963
- to_kind, to_start, copy_size);
1196
+ CopySmiToDoubleElements(from, from_start, to, to_start, copy_size);
1197
+ break;
964
1198
  case FAST_DOUBLE_ELEMENTS:
965
1199
  case FAST_HOLEY_DOUBLE_ELEMENTS:
966
- CopyDoubleToDoubleElements(FixedDoubleArray::cast(from), from_start,
967
- FixedDoubleArray::cast(to),
968
- to_start, copy_size);
969
- return from;
970
- default:
1200
+ CopyDoubleToDoubleElements(from, from_start, to, to_start, copy_size);
1201
+ break;
1202
+ case FAST_ELEMENTS:
1203
+ case FAST_HOLEY_ELEMENTS:
1204
+ CopyObjectToDoubleElements(from, from_start, to, to_start, copy_size);
1205
+ break;
1206
+ case DICTIONARY_ELEMENTS:
1207
+ CopyDictionaryToDoubleElements(
1208
+ from, from_start, to, to_start, copy_size);
1209
+ break;
1210
+ case NON_STRICT_ARGUMENTS_ELEMENTS:
1211
+ case EXTERNAL_BYTE_ELEMENTS:
1212
+ case EXTERNAL_UNSIGNED_BYTE_ELEMENTS:
1213
+ case EXTERNAL_SHORT_ELEMENTS:
1214
+ case EXTERNAL_UNSIGNED_SHORT_ELEMENTS:
1215
+ case EXTERNAL_INT_ELEMENTS:
1216
+ case EXTERNAL_UNSIGNED_INT_ELEMENTS:
1217
+ case EXTERNAL_FLOAT_ELEMENTS:
1218
+ case EXTERNAL_DOUBLE_ELEMENTS:
1219
+ case EXTERNAL_PIXEL_ELEMENTS:
971
1220
  UNREACHABLE();
972
1221
  }
973
1222
  return to->GetHeap()->undefined_value();
@@ -1024,17 +1273,37 @@ class ExternalElementsAccessor
1024
1273
  MUST_USE_RESULT static MaybeObject* GetImpl(Object* receiver,
1025
1274
  JSObject* obj,
1026
1275
  uint32_t key,
1027
- BackingStore* backing_store) {
1276
+ FixedArrayBase* backing_store) {
1028
1277
  return
1029
1278
  key < ExternalElementsAccessorSubclass::GetCapacityImpl(backing_store)
1030
- ? backing_store->get(key)
1279
+ ? BackingStore::cast(backing_store)->get(key)
1031
1280
  : backing_store->GetHeap()->undefined_value();
1032
1281
  }
1033
1282
 
1283
+ MUST_USE_RESULT static PropertyAttributes GetAttributesImpl(
1284
+ Object* receiver,
1285
+ JSObject* obj,
1286
+ uint32_t key,
1287
+ FixedArrayBase* backing_store) {
1288
+ return
1289
+ key < ExternalElementsAccessorSubclass::GetCapacityImpl(backing_store)
1290
+ ? NONE : ABSENT;
1291
+ }
1292
+
1293
+ MUST_USE_RESULT static PropertyType GetTypeImpl(
1294
+ Object* receiver,
1295
+ JSObject* obj,
1296
+ uint32_t key,
1297
+ FixedArrayBase* backing_store) {
1298
+ return
1299
+ key < ExternalElementsAccessorSubclass::GetCapacityImpl(backing_store)
1300
+ ? FIELD : NONEXISTENT;
1301
+ }
1302
+
1034
1303
  MUST_USE_RESULT static MaybeObject* SetLengthImpl(
1035
1304
  JSObject* obj,
1036
1305
  Object* length,
1037
- BackingStore* backing_store) {
1306
+ FixedArrayBase* backing_store) {
1038
1307
  // External arrays do not support changing their length.
1039
1308
  UNREACHABLE();
1040
1309
  return obj;
@@ -1050,7 +1319,7 @@ class ExternalElementsAccessor
1050
1319
  static bool HasElementImpl(Object* receiver,
1051
1320
  JSObject* holder,
1052
1321
  uint32_t key,
1053
- BackingStore* backing_store) {
1322
+ FixedArrayBase* backing_store) {
1054
1323
  uint32_t capacity =
1055
1324
  ExternalElementsAccessorSubclass::GetCapacityImpl(backing_store);
1056
1325
  return key < capacity;
@@ -1159,11 +1428,35 @@ class DictionaryElementsAccessor
1159
1428
  // Adjusts the length of the dictionary backing store and returns the new
1160
1429
  // length according to ES5 section 15.4.5.2 behavior.
1161
1430
  MUST_USE_RESULT static MaybeObject* SetLengthWithoutNormalize(
1162
- SeededNumberDictionary* dict,
1431
+ FixedArrayBase* store,
1163
1432
  JSArray* array,
1164
1433
  Object* length_object,
1165
1434
  uint32_t length) {
1166
- if (length == 0) {
1435
+ SeededNumberDictionary* dict = SeededNumberDictionary::cast(store);
1436
+ Heap* heap = array->GetHeap();
1437
+ int capacity = dict->Capacity();
1438
+ uint32_t new_length = length;
1439
+ uint32_t old_length = static_cast<uint32_t>(array->length()->Number());
1440
+ if (new_length < old_length) {
1441
+ // Find last non-deletable element in range of elements to be
1442
+ // deleted and adjust range accordingly.
1443
+ for (int i = 0; i < capacity; i++) {
1444
+ Object* key = dict->KeyAt(i);
1445
+ if (key->IsNumber()) {
1446
+ uint32_t number = static_cast<uint32_t>(key->Number());
1447
+ if (new_length <= number && number < old_length) {
1448
+ PropertyDetails details = dict->DetailsAt(i);
1449
+ if (details.IsDontDelete()) new_length = number + 1;
1450
+ }
1451
+ }
1452
+ }
1453
+ if (new_length != length) {
1454
+ MaybeObject* maybe_object = heap->NumberFromUint32(new_length);
1455
+ if (!maybe_object->To(&length_object)) return maybe_object;
1456
+ }
1457
+ }
1458
+
1459
+ if (new_length == 0) {
1167
1460
  // If the length of a slow array is reset to zero, we clear
1168
1461
  // the array and flush backing storage. This has the added
1169
1462
  // benefit that the array returns to fast mode.
@@ -1171,45 +1464,22 @@ class DictionaryElementsAccessor
1171
1464
  MaybeObject* maybe_obj = array->ResetElements();
1172
1465
  if (!maybe_obj->ToObject(&obj)) return maybe_obj;
1173
1466
  } else {
1174
- uint32_t new_length = length;
1175
- uint32_t old_length = static_cast<uint32_t>(array->length()->Number());
1176
- if (new_length < old_length) {
1177
- // Find last non-deletable element in range of elements to be
1178
- // deleted and adjust range accordingly.
1179
- Heap* heap = array->GetHeap();
1180
- int capacity = dict->Capacity();
1181
- for (int i = 0; i < capacity; i++) {
1182
- Object* key = dict->KeyAt(i);
1183
- if (key->IsNumber()) {
1184
- uint32_t number = static_cast<uint32_t>(key->Number());
1185
- if (new_length <= number && number < old_length) {
1186
- PropertyDetails details = dict->DetailsAt(i);
1187
- if (details.IsDontDelete()) new_length = number + 1;
1188
- }
1467
+ // Remove elements that should be deleted.
1468
+ int removed_entries = 0;
1469
+ Object* the_hole_value = heap->the_hole_value();
1470
+ for (int i = 0; i < capacity; i++) {
1471
+ Object* key = dict->KeyAt(i);
1472
+ if (key->IsNumber()) {
1473
+ uint32_t number = static_cast<uint32_t>(key->Number());
1474
+ if (new_length <= number && number < old_length) {
1475
+ dict->SetEntry(i, the_hole_value, the_hole_value);
1476
+ removed_entries++;
1189
1477
  }
1190
1478
  }
1191
- if (new_length != length) {
1192
- MaybeObject* maybe_object = heap->NumberFromUint32(new_length);
1193
- if (!maybe_object->To(&length_object)) return maybe_object;
1194
- }
1195
-
1196
- // Remove elements that should be deleted.
1197
- int removed_entries = 0;
1198
- Object* the_hole_value = heap->the_hole_value();
1199
- for (int i = 0; i < capacity; i++) {
1200
- Object* key = dict->KeyAt(i);
1201
- if (key->IsNumber()) {
1202
- uint32_t number = static_cast<uint32_t>(key->Number());
1203
- if (new_length <= number && number < old_length) {
1204
- dict->SetEntry(i, the_hole_value, the_hole_value);
1205
- removed_entries++;
1206
- }
1207
- }
1208
- }
1209
-
1210
- // Update the number of elements.
1211
- dict->ElementsRemoved(removed_entries);
1212
1479
  }
1480
+
1481
+ // Update the number of elements.
1482
+ dict->ElementsRemoved(removed_entries);
1213
1483
  }
1214
1484
  return length_object;
1215
1485
  }
@@ -1231,30 +1501,29 @@ class DictionaryElementsAccessor
1231
1501
  int entry = dictionary->FindEntry(key);
1232
1502
  if (entry != SeededNumberDictionary::kNotFound) {
1233
1503
  Object* result = dictionary->DeleteProperty(entry, mode);
1234
- if (result == heap->true_value()) {
1235
- MaybeObject* maybe_elements = dictionary->Shrink(key);
1236
- FixedArray* new_elements = NULL;
1237
- if (!maybe_elements->To(&new_elements)) {
1238
- return maybe_elements;
1239
- }
1240
- if (is_arguments) {
1241
- FixedArray::cast(obj->elements())->set(1, new_elements);
1242
- } else {
1243
- obj->set_elements(new_elements);
1504
+ if (result == heap->false_value()) {
1505
+ if (mode == JSObject::STRICT_DELETION) {
1506
+ // Deleting a non-configurable property in strict mode.
1507
+ HandleScope scope(isolate);
1508
+ Handle<Object> holder(obj);
1509
+ Handle<Object> name = isolate->factory()->NewNumberFromUint(key);
1510
+ Handle<Object> args[2] = { name, holder };
1511
+ Handle<Object> error =
1512
+ isolate->factory()->NewTypeError("strict_delete_property",
1513
+ HandleVector(args, 2));
1514
+ return isolate->Throw(*error);
1244
1515
  }
1516
+ return heap->false_value();
1245
1517
  }
1246
- if (mode == JSObject::STRICT_DELETION &&
1247
- result == heap->false_value()) {
1248
- // In strict mode, attempting to delete a non-configurable property
1249
- // throws an exception.
1250
- HandleScope scope(isolate);
1251
- Handle<Object> holder(obj);
1252
- Handle<Object> name = isolate->factory()->NewNumberFromUint(key);
1253
- Handle<Object> args[2] = { name, holder };
1254
- Handle<Object> error =
1255
- isolate->factory()->NewTypeError("strict_delete_property",
1256
- HandleVector(args, 2));
1257
- return isolate->Throw(*error);
1518
+ MaybeObject* maybe_elements = dictionary->Shrink(key);
1519
+ FixedArray* new_elements = NULL;
1520
+ if (!maybe_elements->To(&new_elements)) {
1521
+ return maybe_elements;
1522
+ }
1523
+ if (is_arguments) {
1524
+ FixedArray::cast(obj->elements())->set(1, new_elements);
1525
+ } else {
1526
+ obj->set_elements(new_elements);
1258
1527
  }
1259
1528
  }
1260
1529
  return heap->true_value();
@@ -1263,28 +1532,12 @@ class DictionaryElementsAccessor
1263
1532
  MUST_USE_RESULT static MaybeObject* CopyElementsImpl(FixedArrayBase* from,
1264
1533
  uint32_t from_start,
1265
1534
  FixedArrayBase* to,
1266
- ElementsKind to_kind,
1535
+ ElementsKind from_kind,
1267
1536
  uint32_t to_start,
1537
+ int packed_size,
1268
1538
  int copy_size) {
1269
- switch (to_kind) {
1270
- case FAST_SMI_ELEMENTS:
1271
- case FAST_ELEMENTS:
1272
- case FAST_HOLEY_SMI_ELEMENTS:
1273
- case FAST_HOLEY_ELEMENTS:
1274
- CopyDictionaryToObjectElements(
1275
- SeededNumberDictionary::cast(from), from_start,
1276
- FixedArray::cast(to), to_kind, to_start, copy_size);
1277
- return from;
1278
- case FAST_DOUBLE_ELEMENTS:
1279
- case FAST_HOLEY_DOUBLE_ELEMENTS:
1280
- CopyDictionaryToDoubleElements(
1281
- SeededNumberDictionary::cast(from), from_start,
1282
- FixedDoubleArray::cast(to), to_start, copy_size);
1283
- return from;
1284
- default:
1285
- UNREACHABLE();
1286
- }
1287
- return to->GetHeap()->undefined_value();
1539
+ UNREACHABLE();
1540
+ return NULL;
1288
1541
  }
1289
1542
 
1290
1543
 
@@ -1302,7 +1555,8 @@ class DictionaryElementsAccessor
1302
1555
  Object* receiver,
1303
1556
  JSObject* obj,
1304
1557
  uint32_t key,
1305
- SeededNumberDictionary* backing_store) {
1558
+ FixedArrayBase* store) {
1559
+ SeededNumberDictionary* backing_store = SeededNumberDictionary::cast(store);
1306
1560
  int entry = backing_store->FindEntry(key);
1307
1561
  if (entry != SeededNumberDictionary::kNotFound) {
1308
1562
  Object* element = backing_store->ValueAt(entry);
@@ -1319,16 +1573,59 @@ class DictionaryElementsAccessor
1319
1573
  return obj->GetHeap()->the_hole_value();
1320
1574
  }
1321
1575
 
1576
+ MUST_USE_RESULT static PropertyAttributes GetAttributesImpl(
1577
+ Object* receiver,
1578
+ JSObject* obj,
1579
+ uint32_t key,
1580
+ FixedArrayBase* backing_store) {
1581
+ SeededNumberDictionary* dictionary =
1582
+ SeededNumberDictionary::cast(backing_store);
1583
+ int entry = dictionary->FindEntry(key);
1584
+ if (entry != SeededNumberDictionary::kNotFound) {
1585
+ return dictionary->DetailsAt(entry).attributes();
1586
+ }
1587
+ return ABSENT;
1588
+ }
1589
+
1590
+ MUST_USE_RESULT static PropertyType GetTypeImpl(
1591
+ Object* receiver,
1592
+ JSObject* obj,
1593
+ uint32_t key,
1594
+ FixedArrayBase* store) {
1595
+ SeededNumberDictionary* backing_store = SeededNumberDictionary::cast(store);
1596
+ int entry = backing_store->FindEntry(key);
1597
+ if (entry != SeededNumberDictionary::kNotFound) {
1598
+ return backing_store->DetailsAt(entry).type();
1599
+ }
1600
+ return NONEXISTENT;
1601
+ }
1602
+
1603
+ MUST_USE_RESULT static AccessorPair* GetAccessorPairImpl(
1604
+ Object* receiver,
1605
+ JSObject* obj,
1606
+ uint32_t key,
1607
+ FixedArrayBase* store) {
1608
+ SeededNumberDictionary* backing_store = SeededNumberDictionary::cast(store);
1609
+ int entry = backing_store->FindEntry(key);
1610
+ if (entry != SeededNumberDictionary::kNotFound &&
1611
+ backing_store->DetailsAt(entry).type() == CALLBACKS &&
1612
+ backing_store->ValueAt(entry)->IsAccessorPair()) {
1613
+ return AccessorPair::cast(backing_store->ValueAt(entry));
1614
+ }
1615
+ return NULL;
1616
+ }
1617
+
1322
1618
  static bool HasElementImpl(Object* receiver,
1323
1619
  JSObject* holder,
1324
1620
  uint32_t key,
1325
- SeededNumberDictionary* backing_store) {
1326
- return backing_store->FindEntry(key) !=
1621
+ FixedArrayBase* backing_store) {
1622
+ return SeededNumberDictionary::cast(backing_store)->FindEntry(key) !=
1327
1623
  SeededNumberDictionary::kNotFound;
1328
1624
  }
1329
1625
 
1330
- static uint32_t GetKeyForIndexImpl(SeededNumberDictionary* dict,
1626
+ static uint32_t GetKeyForIndexImpl(FixedArrayBase* store,
1331
1627
  uint32_t index) {
1628
+ SeededNumberDictionary* dict = SeededNumberDictionary::cast(store);
1332
1629
  Object* key = dict->KeyAt(index);
1333
1630
  return Smi::cast(key)->value();
1334
1631
  }
@@ -1351,7 +1648,8 @@ class NonStrictArgumentsElementsAccessor : public ElementsAccessorBase<
1351
1648
  MUST_USE_RESULT static MaybeObject* GetImpl(Object* receiver,
1352
1649
  JSObject* obj,
1353
1650
  uint32_t key,
1354
- FixedArray* parameter_map) {
1651
+ FixedArrayBase* parameters) {
1652
+ FixedArray* parameter_map = FixedArray::cast(parameters);
1355
1653
  Object* probe = GetParameterMapArg(obj, parameter_map, key);
1356
1654
  if (!probe->IsTheHole()) {
1357
1655
  Context* context = Context::cast(parameter_map->get(0));
@@ -1378,10 +1676,61 @@ class NonStrictArgumentsElementsAccessor : public ElementsAccessorBase<
1378
1676
  }
1379
1677
  }
1380
1678
 
1679
+ MUST_USE_RESULT static PropertyAttributes GetAttributesImpl(
1680
+ Object* receiver,
1681
+ JSObject* obj,
1682
+ uint32_t key,
1683
+ FixedArrayBase* backing_store) {
1684
+ FixedArray* parameter_map = FixedArray::cast(backing_store);
1685
+ Object* probe = GetParameterMapArg(obj, parameter_map, key);
1686
+ if (!probe->IsTheHole()) {
1687
+ return NONE;
1688
+ } else {
1689
+ // If not aliased, check the arguments.
1690
+ FixedArray* arguments = FixedArray::cast(parameter_map->get(1));
1691
+ return ElementsAccessor::ForArray(arguments)->GetAttributes(
1692
+ receiver, obj, key, arguments);
1693
+ }
1694
+ }
1695
+
1696
+ MUST_USE_RESULT static PropertyType GetTypeImpl(
1697
+ Object* receiver,
1698
+ JSObject* obj,
1699
+ uint32_t key,
1700
+ FixedArrayBase* parameters) {
1701
+ FixedArray* parameter_map = FixedArray::cast(parameters);
1702
+ Object* probe = GetParameterMapArg(obj, parameter_map, key);
1703
+ if (!probe->IsTheHole()) {
1704
+ return FIELD;
1705
+ } else {
1706
+ // If not aliased, check the arguments.
1707
+ FixedArray* arguments = FixedArray::cast(parameter_map->get(1));
1708
+ return ElementsAccessor::ForArray(arguments)->GetType(
1709
+ receiver, obj, key, arguments);
1710
+ }
1711
+ }
1712
+
1713
+ MUST_USE_RESULT static AccessorPair* GetAccessorPairImpl(
1714
+ Object* receiver,
1715
+ JSObject* obj,
1716
+ uint32_t key,
1717
+ FixedArrayBase* parameters) {
1718
+ FixedArray* parameter_map = FixedArray::cast(parameters);
1719
+ Object* probe = GetParameterMapArg(obj, parameter_map, key);
1720
+ if (!probe->IsTheHole()) {
1721
+ return NULL;
1722
+ } else {
1723
+ // If not aliased, check the arguments.
1724
+ FixedArray* arguments = FixedArray::cast(parameter_map->get(1));
1725
+ return ElementsAccessor::ForArray(arguments)->GetAccessorPair(
1726
+ receiver, obj, key, arguments);
1727
+ }
1728
+ }
1729
+
1381
1730
  MUST_USE_RESULT static MaybeObject* SetLengthImpl(
1382
1731
  JSObject* obj,
1383
1732
  Object* length,
1384
- FixedArray* parameter_map) {
1733
+ FixedArrayBase* parameter_map) {
1385
1734
  // TODO(mstarzinger): This was never implemented but will be used once we
1386
1735
  // correctly implement [[DefineOwnProperty]] on arrays.
1387
1736
  UNIMPLEMENTED();
@@ -1415,23 +1764,22 @@ class NonStrictArgumentsElementsAccessor : public ElementsAccessorBase<
1415
1764
  MUST_USE_RESULT static MaybeObject* CopyElementsImpl(FixedArrayBase* from,
1416
1765
  uint32_t from_start,
1417
1766
  FixedArrayBase* to,
1418
- ElementsKind to_kind,
1767
+ ElementsKind from_kind,
1419
1768
  uint32_t to_start,
1769
+ int packed_size,
1420
1770
  int copy_size) {
1421
- FixedArray* parameter_map = FixedArray::cast(from);
1422
- FixedArray* arguments = FixedArray::cast(parameter_map->get(1));
1423
- ElementsAccessor* accessor = ElementsAccessor::ForArray(arguments);
1424
- return accessor->CopyElements(NULL, from_start, to, to_kind,
1425
- to_start, copy_size, arguments);
1771
+ UNREACHABLE();
1772
+ return NULL;
1426
1773
  }
1427
1774
 
1428
- static uint32_t GetCapacityImpl(FixedArray* parameter_map) {
1775
+ static uint32_t GetCapacityImpl(FixedArrayBase* backing_store) {
1776
+ FixedArray* parameter_map = FixedArray::cast(backing_store);
1429
1777
  FixedArrayBase* arguments = FixedArrayBase::cast(parameter_map->get(1));
1430
1778
  return Max(static_cast<uint32_t>(parameter_map->length() - 2),
1431
1779
  ForArray(arguments)->GetCapacity(arguments));
1432
1780
  }
1433
1781
 
1434
- static uint32_t GetKeyForIndexImpl(FixedArray* dict,
1782
+ static uint32_t GetKeyForIndexImpl(FixedArrayBase* dict,
1435
1783
  uint32_t index) {
1436
1784
  return index;
1437
1785
  }
@@ -1439,12 +1787,14 @@ class NonStrictArgumentsElementsAccessor : public ElementsAccessorBase<
1439
1787
  static bool HasElementImpl(Object* receiver,
1440
1788
  JSObject* holder,
1441
1789
  uint32_t key,
1442
- FixedArray* parameter_map) {
1790
+ FixedArrayBase* parameters) {
1791
+ FixedArray* parameter_map = FixedArray::cast(parameters);
1443
1792
  Object* probe = GetParameterMapArg(holder, parameter_map, key);
1444
1793
  if (!probe->IsTheHole()) {
1445
1794
  return true;
1446
1795
  } else {
1447
- FixedArrayBase* arguments = FixedArrayBase::cast(parameter_map->get(1));
1796
+ FixedArrayBase* arguments =
1797
+ FixedArrayBase::cast(FixedArray::cast(parameter_map)->get(1));
1448
1798
  ElementsAccessor* accessor = ElementsAccessor::ForArray(arguments);
1449
1799
  return !accessor->Get(receiver, holder, key, arguments)->IsTheHole();
1450
1800
  }
@@ -1457,7 +1807,7 @@ class NonStrictArgumentsElementsAccessor : public ElementsAccessorBase<
1457
1807
  uint32_t length = holder->IsJSArray()
1458
1808
  ? Smi::cast(JSArray::cast(holder)->length())->value()
1459
1809
  : parameter_map->length();
1460
- return key < (length - 2 )
1810
+ return key < (length - 2)
1461
1811
  ? parameter_map->get(key + 2)
1462
1812
  : parameter_map->GetHeap()->the_hole_value();
1463
1813
  }
@@ -1465,35 +1815,7 @@ class NonStrictArgumentsElementsAccessor : public ElementsAccessorBase<
1465
1815
 
1466
1816
 
1467
1817
  ElementsAccessor* ElementsAccessor::ForArray(FixedArrayBase* array) {
1468
- switch (array->map()->instance_type()) {
1469
- case FIXED_ARRAY_TYPE:
1470
- if (array->IsDictionary()) {
1471
- return elements_accessors_[DICTIONARY_ELEMENTS];
1472
- } else {
1473
- return elements_accessors_[FAST_HOLEY_ELEMENTS];
1474
- }
1475
- case EXTERNAL_BYTE_ARRAY_TYPE:
1476
- return elements_accessors_[EXTERNAL_BYTE_ELEMENTS];
1477
- case EXTERNAL_UNSIGNED_BYTE_ARRAY_TYPE:
1478
- return elements_accessors_[EXTERNAL_UNSIGNED_BYTE_ELEMENTS];
1479
- case EXTERNAL_SHORT_ARRAY_TYPE:
1480
- return elements_accessors_[EXTERNAL_SHORT_ELEMENTS];
1481
- case EXTERNAL_UNSIGNED_SHORT_ARRAY_TYPE:
1482
- return elements_accessors_[EXTERNAL_UNSIGNED_SHORT_ELEMENTS];
1483
- case EXTERNAL_INT_ARRAY_TYPE:
1484
- return elements_accessors_[EXTERNAL_INT_ELEMENTS];
1485
- case EXTERNAL_UNSIGNED_INT_ARRAY_TYPE:
1486
- return elements_accessors_[EXTERNAL_UNSIGNED_INT_ELEMENTS];
1487
- case EXTERNAL_FLOAT_ARRAY_TYPE:
1488
- return elements_accessors_[EXTERNAL_FLOAT_ELEMENTS];
1489
- case EXTERNAL_DOUBLE_ARRAY_TYPE:
1490
- return elements_accessors_[EXTERNAL_DOUBLE_ELEMENTS];
1491
- case EXTERNAL_PIXEL_ARRAY_TYPE:
1492
- return elements_accessors_[EXTERNAL_PIXEL_ELEMENTS];
1493
- default:
1494
- UNREACHABLE();
1495
- return NULL;
1496
- }
1818
+ return elements_accessors_[ElementsKindForArray(array)];
1497
1819
  }
1498
1820
 
1499
1821
 
@@ -1524,7 +1846,7 @@ MUST_USE_RESULT MaybeObject* ElementsAccessorBase<ElementsAccessorSubclass,
1524
1846
  ElementsKindTraits>::
1525
1847
  SetLengthImpl(JSObject* obj,
1526
1848
  Object* length,
1527
- typename ElementsKindTraits::BackingStore* backing_store) {
1849
+ FixedArrayBase* backing_store) {
1528
1850
  JSArray* array = JSArray::cast(obj);
1529
1851
 
1530
1852
  // Fast case: The new length fits into a Smi.