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
@@ -124,7 +124,7 @@ static void SendAndReceive(int port, char *data, int len) {
124
124
  TEST(Socket) {
125
125
  // Make sure this port is not used by other tests to allow tests to run in
126
126
  // parallel.
127
- static const int kPort = 5859;
127
+ static const int kPort = 5859 + FlagDependentPortOffset();
128
128
 
129
129
  bool ok;
130
130
 
@@ -121,9 +121,148 @@ class TestMemoryAllocatorScope {
121
121
  DISALLOW_COPY_AND_ASSIGN(TestMemoryAllocatorScope);
122
122
  };
123
123
 
124
+
125
+ // Temporarily sets a given code range in an isolate.
126
+ class TestCodeRangeScope {
127
+ public:
128
+ TestCodeRangeScope(Isolate* isolate, CodeRange* code_range)
129
+ : isolate_(isolate),
130
+ old_code_range_(isolate->code_range_) {
131
+ isolate->code_range_ = code_range;
132
+ }
133
+
134
+ ~TestCodeRangeScope() {
135
+ isolate_->code_range_ = old_code_range_;
136
+ }
137
+
138
+ private:
139
+ Isolate* isolate_;
140
+ CodeRange* old_code_range_;
141
+
142
+ DISALLOW_COPY_AND_ASSIGN(TestCodeRangeScope);
143
+ };
144
+
124
145
  } } // namespace v8::internal
125
146
 
126
147
 
148
+ static void VerifyMemoryChunk(Isolate* isolate,
149
+ Heap* heap,
150
+ CodeRange* code_range,
151
+ size_t reserve_area_size,
152
+ size_t commit_area_size,
153
+ size_t second_commit_area_size,
154
+ Executability executable) {
155
+ MemoryAllocator* memory_allocator = new MemoryAllocator(isolate);
156
+ CHECK(memory_allocator->SetUp(heap->MaxReserved(),
157
+ heap->MaxExecutableSize()));
158
+ TestMemoryAllocatorScope test_allocator_scope(isolate, memory_allocator);
159
+ TestCodeRangeScope test_code_range_scope(isolate, code_range);
160
+
161
+ size_t header_size = (executable == EXECUTABLE)
162
+ ? MemoryAllocator::CodePageGuardStartOffset()
163
+ : MemoryChunk::kObjectStartOffset;
164
+ size_t guard_size = (executable == EXECUTABLE)
165
+ ? MemoryAllocator::CodePageGuardSize()
166
+ : 0;
167
+
168
+ MemoryChunk* memory_chunk = memory_allocator->AllocateChunk(reserve_area_size,
169
+ commit_area_size,
170
+ executable,
171
+ NULL);
172
+ size_t alignment = code_range->exists() ?
173
+ MemoryChunk::kAlignment : OS::CommitPageSize();
174
+ size_t reserved_size = ((executable == EXECUTABLE))
175
+ ? RoundUp(header_size + guard_size + reserve_area_size + guard_size,
176
+ alignment)
177
+ : RoundUp(header_size + reserve_area_size, OS::CommitPageSize());
178
+ CHECK(memory_chunk->size() == reserved_size);
179
+ CHECK(memory_chunk->area_start() < memory_chunk->address() +
180
+ memory_chunk->size());
181
+ CHECK(memory_chunk->area_end() <= memory_chunk->address() +
182
+ memory_chunk->size());
183
+ CHECK(static_cast<size_t>(memory_chunk->area_size()) == commit_area_size);
184
+
185
+ Address area_start = memory_chunk->area_start();
186
+
187
+ memory_chunk->CommitArea(second_commit_area_size);
188
+ CHECK(area_start == memory_chunk->area_start());
189
+ CHECK(memory_chunk->area_start() < memory_chunk->address() +
190
+ memory_chunk->size());
191
+ CHECK(memory_chunk->area_end() <= memory_chunk->address() +
192
+ memory_chunk->size());
193
+ CHECK(static_cast<size_t>(memory_chunk->area_size()) ==
194
+ second_commit_area_size);
195
+
196
+ memory_allocator->Free(memory_chunk);
197
+ memory_allocator->TearDown();
198
+ delete memory_allocator;
199
+ }
200
+
201
+
202
+ static unsigned int Pseudorandom() {
203
+ static uint32_t lo = 2345;
204
+ lo = 18273 * (lo & 0xFFFFF) + (lo >> 16);
205
+ return lo & 0xFFFFF;
206
+ }
207
+
208
+
209
+ TEST(MemoryChunk) {
210
+ OS::SetUp();
211
+ Isolate* isolate = Isolate::Current();
212
+ isolate->InitializeLoggingAndCounters();
213
+ Heap* heap = isolate->heap();
214
+ CHECK(heap->ConfigureHeapDefault());
215
+
216
+ size_t reserve_area_size = 1 * MB;
217
+ size_t initial_commit_area_size, second_commit_area_size;
218
+
219
+ for (int i = 0; i < 100; i++) {
220
+ initial_commit_area_size = Pseudorandom();
221
+ second_commit_area_size = Pseudorandom();
222
+
223
+ // With CodeRange.
224
+ CodeRange* code_range = new CodeRange(isolate);
225
+ const int code_range_size = 32 * MB;
226
+ if (!code_range->SetUp(code_range_size)) return;
227
+
228
+ VerifyMemoryChunk(isolate,
229
+ heap,
230
+ code_range,
231
+ reserve_area_size,
232
+ initial_commit_area_size,
233
+ second_commit_area_size,
234
+ EXECUTABLE);
235
+
236
+ VerifyMemoryChunk(isolate,
237
+ heap,
238
+ code_range,
239
+ reserve_area_size,
240
+ initial_commit_area_size,
241
+ second_commit_area_size,
242
+ NOT_EXECUTABLE);
243
+ delete code_range;
244
+
245
+ // Without CodeRange.
246
+ code_range = NULL;
247
+ VerifyMemoryChunk(isolate,
248
+ heap,
249
+ code_range,
250
+ reserve_area_size,
251
+ initial_commit_area_size,
252
+ second_commit_area_size,
253
+ EXECUTABLE);
254
+
255
+ VerifyMemoryChunk(isolate,
256
+ heap,
257
+ code_range,
258
+ reserve_area_size,
259
+ initial_commit_area_size,
260
+ second_commit_area_size,
261
+ NOT_EXECUTABLE);
262
+ }
263
+ }
264
+
265
+
127
266
  TEST(MemoryAllocator) {
128
267
  OS::SetUp();
129
268
  Isolate* isolate = Isolate::Current();
@@ -1,7 +1,7 @@
1
- // Copyright 2011 the V8 project authors. All rights reserved.
1
+ // Copyright 2012 the V8 project authors. All rights reserved.
2
2
 
3
3
  // Check that we can traverse very deep stacks of ConsStrings using
4
- // StringInputBuffer. Check that Get(int) works on very deep stacks
4
+ // StringCharacterStram. Check that Get(int) works on very deep stacks
5
5
  // of ConsStrings. These operations may not be very fast, but they
6
6
  // should be possible without getting errors due to too deep recursion.
7
7
 
@@ -11,19 +11,61 @@
11
11
 
12
12
  #include "api.h"
13
13
  #include "factory.h"
14
+ #include "objects.h"
14
15
  #include "cctest.h"
15
16
  #include "zone-inl.h"
16
17
 
17
- unsigned int seed = 123;
18
+ // Adapted from http://en.wikipedia.org/wiki/Multiply-with-carry
19
+ class RandomNumberGenerator {
20
+ public:
21
+ RandomNumberGenerator() {
22
+ init();
23
+ }
18
24
 
19
- static uint32_t gen() {
20
- uint64_t z;
21
- z = seed;
22
- z *= 279470273;
23
- z %= 4294967291U;
24
- seed = static_cast<unsigned int>(z);
25
- return static_cast<uint32_t>(seed >> 16);
26
- }
25
+ void init(uint32_t seed = 0x5688c73e) {
26
+ static const uint32_t phi = 0x9e3779b9;
27
+ c = 362436;
28
+ i = kQSize-1;
29
+ Q[0] = seed;
30
+ Q[1] = seed + phi;
31
+ Q[2] = seed + phi + phi;
32
+ for (unsigned j = 3; j < kQSize; j++) {
33
+ Q[j] = Q[j - 3] ^ Q[j - 2] ^ phi ^ j;
34
+ }
35
+ }
36
+
37
+ uint32_t next() {
38
+ uint64_t a = 18782;
39
+ uint32_t r = 0xfffffffe;
40
+ i = (i + 1) & (kQSize-1);
41
+ uint64_t t = a * Q[i] + c;
42
+ c = (t >> 32);
43
+ uint32_t x = static_cast<uint32_t>(t + c);
44
+ if (x < c) {
45
+ x++;
46
+ c++;
47
+ }
48
+ return (Q[i] = r - x);
49
+ }
50
+
51
+ uint32_t next(int max) {
52
+ return next() % max;
53
+ }
54
+
55
+ bool next(double threshold) {
56
+ ASSERT(threshold >= 0.0 && threshold <= 1.0);
57
+ if (threshold == 1.0) return true;
58
+ if (threshold == 0.0) return false;
59
+ uint32_t value = next() % 100000;
60
+ return threshold > static_cast<double>(value)/100000.0;
61
+ }
62
+
63
+ private:
64
+ static const uint32_t kQSize = 4096;
65
+ uint32_t Q[kQSize];
66
+ uint32_t c;
67
+ uint32_t i;
68
+ };
27
69
 
28
70
 
29
71
  using namespace v8::internal;
@@ -43,7 +85,6 @@ static void InitializeVM() {
43
85
  }
44
86
 
45
87
 
46
- static const int NUMBER_OF_BUILDING_BLOCKS = 128;
47
88
  static const int DEEP_DEPTH = 8 * 1024;
48
89
  static const int SUPER_DEEP_DEPTH = 80 * 1024;
49
90
 
@@ -78,20 +119,42 @@ class AsciiResource: public v8::String::ExternalAsciiStringResource,
78
119
  };
79
120
 
80
121
 
81
- static void InitializeBuildingBlocks(
82
- Handle<String> building_blocks[NUMBER_OF_BUILDING_BLOCKS]) {
122
+ static void InitializeBuildingBlocks(Handle<String>* building_blocks,
123
+ int bb_length,
124
+ bool long_blocks,
125
+ RandomNumberGenerator* rng) {
83
126
  // A list of pointers that we don't have any interest in cleaning up.
84
127
  // If they are reachable from a root then leak detection won't complain.
85
- for (int i = 0; i < NUMBER_OF_BUILDING_BLOCKS; i++) {
86
- int len = gen() % 16;
87
- if (len > 14) {
128
+ Zone* zone = Isolate::Current()->runtime_zone();
129
+ for (int i = 0; i < bb_length; i++) {
130
+ int len = rng->next(16);
131
+ int slice_head_chars = 0;
132
+ int slice_tail_chars = 0;
133
+ int slice_depth = 0;
134
+ for (int j = 0; j < 3; j++) {
135
+ if (rng->next(0.35)) slice_depth++;
136
+ }
137
+ // Must truncate something for a slice string. Loop until
138
+ // at least one end will be sliced.
139
+ while (slice_head_chars == 0 && slice_tail_chars == 0) {
140
+ slice_head_chars = rng->next(15);
141
+ slice_tail_chars = rng->next(12);
142
+ }
143
+ if (long_blocks) {
144
+ // Generate building blocks which will never be merged
145
+ len += ConsString::kMinLength + 1;
146
+ } else if (len > 14) {
88
147
  len += 1234;
89
148
  }
90
- switch (gen() % 4) {
149
+ // Don't slice 0 length strings.
150
+ if (len == 0) slice_depth = 0;
151
+ int slice_length = slice_depth*(slice_head_chars + slice_tail_chars);
152
+ len += slice_length;
153
+ switch (rng->next(4)) {
91
154
  case 0: {
92
155
  uc16 buf[2000];
93
156
  for (int j = 0; j < len; j++) {
94
- buf[j] = gen() % 65536;
157
+ buf[j] = rng->next(0x10000);
95
158
  }
96
159
  building_blocks[i] =
97
160
  FACTORY->NewStringFromTwoByte(Vector<const uc16>(buf, len));
@@ -103,7 +166,7 @@ static void InitializeBuildingBlocks(
103
166
  case 1: {
104
167
  char buf[2000];
105
168
  for (int j = 0; j < len; j++) {
106
- buf[j] = gen() % 128;
169
+ buf[j] = rng->next(0x80);
107
170
  }
108
171
  building_blocks[i] =
109
172
  FACTORY->NewStringFromAscii(Vector<const char>(buf, len));
@@ -113,11 +176,11 @@ static void InitializeBuildingBlocks(
113
176
  break;
114
177
  }
115
178
  case 2: {
116
- uc16* buf = ZONE->NewArray<uc16>(len);
179
+ uc16* buf = zone->NewArray<uc16>(len);
117
180
  for (int j = 0; j < len; j++) {
118
- buf[j] = gen() % 65536;
181
+ buf[j] = rng->next(0x10000);
119
182
  }
120
- Resource* resource = new Resource(Vector<const uc16>(buf, len));
183
+ Resource* resource = new(zone) Resource(Vector<const uc16>(buf, len));
121
184
  building_blocks[i] = FACTORY->NewExternalStringFromTwoByte(resource);
122
185
  for (int j = 0; j < len; j++) {
123
186
  CHECK_EQ(buf[j], building_blocks[i]->Get(j));
@@ -125,89 +188,347 @@ static void InitializeBuildingBlocks(
125
188
  break;
126
189
  }
127
190
  case 3: {
128
- char* buf = NewArray<char>(len);
191
+ char* buf = zone->NewArray<char>(len);
129
192
  for (int j = 0; j < len; j++) {
130
- buf[j] = gen() % 128;
193
+ buf[j] = rng->next(0x80);
131
194
  }
132
- building_blocks[i] =
133
- FACTORY->NewStringFromAscii(Vector<const char>(buf, len));
195
+ AsciiResource* resource =
196
+ new(zone) AsciiResource(Vector<const char>(buf, len));
197
+ building_blocks[i] = FACTORY->NewExternalStringFromAscii(resource);
134
198
  for (int j = 0; j < len; j++) {
135
199
  CHECK_EQ(buf[j], building_blocks[i]->Get(j));
136
200
  }
137
- DeleteArray<char>(buf);
138
201
  break;
139
202
  }
140
203
  }
204
+ for (int j = slice_depth; j > 0; j--) {
205
+ building_blocks[i] = FACTORY->NewSubString(
206
+ building_blocks[i],
207
+ slice_head_chars,
208
+ building_blocks[i]->length() - slice_tail_chars);
209
+ }
210
+ CHECK(len == building_blocks[i]->length() + slice_length);
211
+ }
212
+ }
213
+
214
+
215
+ class ConsStringStats {
216
+ public:
217
+ ConsStringStats() {
218
+ Reset();
219
+ }
220
+ void Reset();
221
+ void VerifyEqual(const ConsStringStats& that) const;
222
+ unsigned leaves_;
223
+ unsigned empty_leaves_;
224
+ unsigned chars_;
225
+ unsigned left_traversals_;
226
+ unsigned right_traversals_;
227
+ private:
228
+ DISALLOW_COPY_AND_ASSIGN(ConsStringStats);
229
+ };
230
+
231
+
232
+ void ConsStringStats::Reset() {
233
+ leaves_ = 0;
234
+ empty_leaves_ = 0;
235
+ chars_ = 0;
236
+ left_traversals_ = 0;
237
+ right_traversals_ = 0;
238
+ }
239
+
240
+
241
+ void ConsStringStats::VerifyEqual(const ConsStringStats& that) const {
242
+ CHECK(this->leaves_ == that.leaves_);
243
+ CHECK(this->empty_leaves_ == that.empty_leaves_);
244
+ CHECK(this->chars_ == that.chars_);
245
+ CHECK(this->left_traversals_ == that.left_traversals_);
246
+ CHECK(this->right_traversals_ == that.right_traversals_);
247
+ }
248
+
249
+
250
+ class ConsStringGenerationData {
251
+ public:
252
+ static const int kNumberOfBuildingBlocks = 256;
253
+ explicit ConsStringGenerationData(bool long_blocks);
254
+ void Reset();
255
+ inline Handle<String> block(int offset);
256
+ inline Handle<String> block(uint32_t offset);
257
+ // Input variables.
258
+ double early_termination_threshold_;
259
+ double leftness_;
260
+ double rightness_;
261
+ double empty_leaf_threshold_;
262
+ unsigned max_leaves_;
263
+ // Cached data.
264
+ Handle<String> building_blocks_[kNumberOfBuildingBlocks];
265
+ String* empty_string_;
266
+ RandomNumberGenerator rng_;
267
+ // Stats.
268
+ ConsStringStats stats_;
269
+ unsigned early_terminations_;
270
+ private:
271
+ DISALLOW_COPY_AND_ASSIGN(ConsStringGenerationData);
272
+ };
273
+
274
+
275
+ ConsStringGenerationData::ConsStringGenerationData(bool long_blocks) {
276
+ rng_.init();
277
+ InitializeBuildingBlocks(
278
+ building_blocks_, kNumberOfBuildingBlocks, long_blocks, &rng_);
279
+ empty_string_ = Isolate::Current()->heap()->empty_string();
280
+ Reset();
281
+ }
282
+
283
+
284
+ Handle<String> ConsStringGenerationData::block(uint32_t offset) {
285
+ return building_blocks_[offset % kNumberOfBuildingBlocks ];
286
+ }
287
+
288
+
289
+ Handle<String> ConsStringGenerationData::block(int offset) {
290
+ CHECK_GE(offset, 0);
291
+ return building_blocks_[offset % kNumberOfBuildingBlocks];
292
+ }
293
+
294
+
295
+ void ConsStringGenerationData::Reset() {
296
+ early_termination_threshold_ = 0.01;
297
+ leftness_ = 0.75;
298
+ rightness_ = 0.75;
299
+ empty_leaf_threshold_ = 0.02;
300
+ max_leaves_ = 1000;
301
+ stats_.Reset();
302
+ early_terminations_ = 0;
303
+ rng_.init();
304
+ }
305
+
306
+
307
+ void AccumulateStats(ConsString* cons_string, ConsStringStats* stats) {
308
+ int left_length = cons_string->first()->length();
309
+ int right_length = cons_string->second()->length();
310
+ CHECK(cons_string->length() == left_length + right_length);
311
+ // Check left side.
312
+ bool left_is_cons = cons_string->first()->IsConsString();
313
+ if (left_is_cons) {
314
+ stats->left_traversals_++;
315
+ AccumulateStats(ConsString::cast(cons_string->first()), stats);
316
+ } else {
317
+ CHECK_NE(left_length, 0);
318
+ stats->leaves_++;
319
+ stats->chars_ += left_length;
320
+ }
321
+ // Check right side.
322
+ if (cons_string->second()->IsConsString()) {
323
+ stats->right_traversals_++;
324
+ AccumulateStats(ConsString::cast(cons_string->second()), stats);
325
+ } else {
326
+ if (right_length == 0) {
327
+ stats->empty_leaves_++;
328
+ CHECK(!left_is_cons);
329
+ }
330
+ stats->leaves_++;
331
+ stats->chars_ += right_length;
332
+ }
333
+ }
334
+
335
+
336
+ void AccumulateStats(Handle<String> cons_string, ConsStringStats* stats) {
337
+ AssertNoAllocation no_alloc;
338
+ if (cons_string->IsConsString()) {
339
+ return AccumulateStats(ConsString::cast(*cons_string), stats);
340
+ }
341
+ // This string got flattened by gc.
342
+ stats->chars_ += cons_string->length();
343
+ }
344
+
345
+
346
+ void AccumulateStatsWithOperator(
347
+ ConsString* cons_string, ConsStringStats* stats) {
348
+ unsigned offset = 0;
349
+ int32_t type = cons_string->map()->instance_type();
350
+ unsigned length = static_cast<unsigned>(cons_string->length());
351
+ ConsStringIteratorOp op;
352
+ String* string = op.Operate(cons_string, &offset, &type, &length);
353
+ CHECK(string != NULL);
354
+ while (true) {
355
+ ASSERT(!string->IsConsString());
356
+ // Accumulate stats.
357
+ stats->leaves_++;
358
+ stats->chars_ += string->length();
359
+ // Check for completion.
360
+ bool keep_going_fast_check = op.HasMore();
361
+ string = op.ContinueOperation(&type, &length);
362
+ if (string == NULL) return;
363
+ // Verify no false positives for fast check.
364
+ CHECK(keep_going_fast_check);
365
+ }
366
+ }
367
+
368
+
369
+ void VerifyConsString(Handle<String> root, ConsStringGenerationData* data) {
370
+ // Verify basic data.
371
+ CHECK(root->IsConsString());
372
+ CHECK(static_cast<unsigned>(root->length()) == data->stats_.chars_);
373
+ // Recursive verify.
374
+ ConsStringStats stats;
375
+ AccumulateStats(ConsString::cast(*root), &stats);
376
+ stats.VerifyEqual(data->stats_);
377
+ // Iteratively verify.
378
+ stats.Reset();
379
+ AccumulateStatsWithOperator(ConsString::cast(*root), &stats);
380
+ // Don't see these. Must copy over.
381
+ stats.empty_leaves_ = data->stats_.empty_leaves_;
382
+ stats.left_traversals_ = data->stats_.left_traversals_;
383
+ stats.right_traversals_ = data->stats_.right_traversals_;
384
+ // Adjust total leaves to compensate.
385
+ stats.leaves_ += stats.empty_leaves_;
386
+ stats.VerifyEqual(data->stats_);
387
+ }
388
+
389
+
390
+ static Handle<String> ConstructRandomString(ConsStringGenerationData* data,
391
+ unsigned max_recursion) {
392
+ // Compute termination characteristics.
393
+ bool terminate = false;
394
+ bool flat = data->rng_.next(data->empty_leaf_threshold_);
395
+ bool terminate_early = data->rng_.next(data->early_termination_threshold_);
396
+ if (terminate_early) data->early_terminations_++;
397
+ // The obvious condition.
398
+ terminate |= max_recursion == 0;
399
+ // Flat cons string terminate by definition.
400
+ terminate |= flat;
401
+ // Cap for max leaves.
402
+ terminate |= data->stats_.leaves_ >= data->max_leaves_;
403
+ // Roll the dice.
404
+ terminate |= terminate_early;
405
+ // Compute termination characteristics for each side.
406
+ bool terminate_left = terminate || !data->rng_.next(data->leftness_);
407
+ bool terminate_right = terminate || !data->rng_.next(data->rightness_);
408
+ // Generate left string.
409
+ Handle<String> left;
410
+ if (terminate_left) {
411
+ left = data->block(data->rng_.next());
412
+ data->stats_.leaves_++;
413
+ data->stats_.chars_ += left->length();
414
+ } else {
415
+ data->stats_.left_traversals_++;
416
+ }
417
+ // Generate right string.
418
+ Handle<String> right;
419
+ if (terminate_right) {
420
+ right = data->block(data->rng_.next());
421
+ data->stats_.leaves_++;
422
+ data->stats_.chars_ += right->length();
423
+ } else {
424
+ data->stats_.right_traversals_++;
425
+ }
426
+ // Generate the necessary sub-nodes recursively.
427
+ if (!terminate_right) {
428
+ // Need to balance generation fairly.
429
+ if (!terminate_left && data->rng_.next(0.5)) {
430
+ left = ConstructRandomString(data, max_recursion - 1);
431
+ }
432
+ right = ConstructRandomString(data, max_recursion - 1);
433
+ }
434
+ if (!terminate_left && left.is_null()) {
435
+ left = ConstructRandomString(data, max_recursion - 1);
141
436
  }
437
+ // Build the cons string.
438
+ Handle<String> root = FACTORY->NewConsString(left, right);
439
+ CHECK(root->IsConsString() && !root->IsFlat());
440
+ // Special work needed for flat string.
441
+ if (flat) {
442
+ data->stats_.empty_leaves_++;
443
+ FlattenString(root);
444
+ CHECK(root->IsConsString() && root->IsFlat());
445
+ }
446
+ return root;
142
447
  }
143
448
 
144
449
 
145
450
  static Handle<String> ConstructLeft(
146
- Handle<String> building_blocks[NUMBER_OF_BUILDING_BLOCKS],
451
+ ConsStringGenerationData* data,
147
452
  int depth) {
148
453
  Handle<String> answer = FACTORY->NewStringFromAscii(CStrVector(""));
454
+ data->stats_.leaves_++;
149
455
  for (int i = 0; i < depth; i++) {
150
- answer = FACTORY->NewConsString(
151
- answer,
152
- building_blocks[i % NUMBER_OF_BUILDING_BLOCKS]);
456
+ Handle<String> block = data->block(i);
457
+ Handle<String> next = FACTORY->NewConsString(answer, block);
458
+ if (next->IsConsString()) data->stats_.leaves_++;
459
+ data->stats_.chars_ += block->length();
460
+ answer = next;
153
461
  }
462
+ data->stats_.left_traversals_ = data->stats_.leaves_ - 2;
154
463
  return answer;
155
464
  }
156
465
 
157
466
 
158
467
  static Handle<String> ConstructRight(
159
- Handle<String> building_blocks[NUMBER_OF_BUILDING_BLOCKS],
468
+ ConsStringGenerationData* data,
160
469
  int depth) {
161
470
  Handle<String> answer = FACTORY->NewStringFromAscii(CStrVector(""));
471
+ data->stats_.leaves_++;
162
472
  for (int i = depth - 1; i >= 0; i--) {
163
- answer = FACTORY->NewConsString(
164
- building_blocks[i % NUMBER_OF_BUILDING_BLOCKS],
165
- answer);
473
+ Handle<String> block = data->block(i);
474
+ Handle<String> next = FACTORY->NewConsString(block, answer);
475
+ if (next->IsConsString()) data->stats_.leaves_++;
476
+ data->stats_.chars_ += block->length();
477
+ answer = next;
166
478
  }
479
+ data->stats_.right_traversals_ = data->stats_.leaves_ - 2;
167
480
  return answer;
168
481
  }
169
482
 
170
483
 
171
484
  static Handle<String> ConstructBalancedHelper(
172
- Handle<String> building_blocks[NUMBER_OF_BUILDING_BLOCKS],
485
+ ConsStringGenerationData* data,
173
486
  int from,
174
487
  int to) {
175
488
  CHECK(to > from);
176
489
  if (to - from == 1) {
177
- return building_blocks[from % NUMBER_OF_BUILDING_BLOCKS];
490
+ data->stats_.chars_ += data->block(from)->length();
491
+ return data->block(from);
178
492
  }
179
493
  if (to - from == 2) {
180
- return FACTORY->NewConsString(
181
- building_blocks[from % NUMBER_OF_BUILDING_BLOCKS],
182
- building_blocks[(from+1) % NUMBER_OF_BUILDING_BLOCKS]);
494
+ data->stats_.chars_ += data->block(from)->length();
495
+ data->stats_.chars_ += data->block(from+1)->length();
496
+ return FACTORY->NewConsString(data->block(from), data->block(from+1));
183
497
  }
184
498
  Handle<String> part1 =
185
- ConstructBalancedHelper(building_blocks, from, from + ((to - from) / 2));
499
+ ConstructBalancedHelper(data, from, from + ((to - from) / 2));
186
500
  Handle<String> part2 =
187
- ConstructBalancedHelper(building_blocks, from + ((to - from) / 2), to);
501
+ ConstructBalancedHelper(data, from + ((to - from) / 2), to);
502
+ if (part1->IsConsString()) data->stats_.left_traversals_++;
503
+ if (part2->IsConsString()) data->stats_.right_traversals_++;
188
504
  return FACTORY->NewConsString(part1, part2);
189
505
  }
190
506
 
191
507
 
192
508
  static Handle<String> ConstructBalanced(
193
- Handle<String> building_blocks[NUMBER_OF_BUILDING_BLOCKS]) {
194
- return ConstructBalancedHelper(building_blocks, 0, DEEP_DEPTH);
509
+ ConsStringGenerationData* data, int depth = DEEP_DEPTH) {
510
+ Handle<String> string = ConstructBalancedHelper(data, 0, depth);
511
+ data->stats_.leaves_ =
512
+ data->stats_.left_traversals_ + data->stats_.right_traversals_ + 2;
513
+ return string;
195
514
  }
196
515
 
197
516
 
198
- static StringInputBuffer buffer;
199
-
517
+ static ConsStringIteratorOp cons_string_iterator_op_1;
518
+ static ConsStringIteratorOp cons_string_iterator_op_2;
200
519
 
201
520
  static void Traverse(Handle<String> s1, Handle<String> s2) {
202
521
  int i = 0;
203
- buffer.Reset(*s1);
204
- StringInputBuffer buffer2(*s2);
205
- while (buffer.has_more()) {
206
- CHECK(buffer2.has_more());
207
- uint16_t c = buffer.GetNext();
208
- CHECK_EQ(c, buffer2.GetNext());
522
+ StringCharacterStream character_stream_1(*s1, &cons_string_iterator_op_1);
523
+ StringCharacterStream character_stream_2(*s2, &cons_string_iterator_op_2);
524
+ while (character_stream_1.HasMore()) {
525
+ CHECK(character_stream_2.HasMore());
526
+ uint16_t c = character_stream_1.GetNext();
527
+ CHECK_EQ(c, character_stream_2.GetNext());
209
528
  i++;
210
529
  }
530
+ CHECK(!character_stream_1.HasMore());
531
+ CHECK(!character_stream_2.HasMore());
211
532
  CHECK_EQ(s1->length(), i);
212
533
  CHECK_EQ(s2->length(), i);
213
534
  }
@@ -215,12 +536,12 @@ static void Traverse(Handle<String> s1, Handle<String> s2) {
215
536
 
216
537
  static void TraverseFirst(Handle<String> s1, Handle<String> s2, int chars) {
217
538
  int i = 0;
218
- buffer.Reset(*s1);
219
- StringInputBuffer buffer2(*s2);
220
- while (buffer.has_more() && i < chars) {
221
- CHECK(buffer2.has_more());
222
- uint16_t c = buffer.GetNext();
223
- CHECK_EQ(c, buffer2.GetNext());
539
+ StringCharacterStream character_stream_1(*s1, &cons_string_iterator_op_1);
540
+ StringCharacterStream character_stream_2(*s2, &cons_string_iterator_op_2);
541
+ while (character_stream_1.HasMore() && i < chars) {
542
+ CHECK(character_stream_2.HasMore());
543
+ uint16_t c = character_stream_1.GetNext();
544
+ CHECK_EQ(c, character_stream_2.GetNext());
224
545
  i++;
225
546
  }
226
547
  s1->Get(s1->length() - 1);
@@ -232,14 +553,13 @@ TEST(Traverse) {
232
553
  printf("TestTraverse\n");
233
554
  InitializeVM();
234
555
  v8::HandleScope scope;
235
- Handle<String> building_blocks[NUMBER_OF_BUILDING_BLOCKS];
236
- ZoneScope zone(Isolate::Current(), DELETE_ON_EXIT);
237
- InitializeBuildingBlocks(building_blocks);
238
- Handle<String> flat = ConstructBalanced(building_blocks);
556
+ ZoneScope zone(Isolate::Current()->runtime_zone(), DELETE_ON_EXIT);
557
+ ConsStringGenerationData data(false);
558
+ Handle<String> flat = ConstructBalanced(&data);
239
559
  FlattenString(flat);
240
- Handle<String> left_asymmetric = ConstructLeft(building_blocks, DEEP_DEPTH);
241
- Handle<String> right_asymmetric = ConstructRight(building_blocks, DEEP_DEPTH);
242
- Handle<String> symmetric = ConstructBalanced(building_blocks);
560
+ Handle<String> left_asymmetric = ConstructLeft(&data, DEEP_DEPTH);
561
+ Handle<String> right_asymmetric = ConstructRight(&data, DEEP_DEPTH);
562
+ Handle<String> symmetric = ConstructBalanced(&data);
243
563
  printf("1\n");
244
564
  Traverse(flat, symmetric);
245
565
  printf("2\n");
@@ -248,9 +568,9 @@ TEST(Traverse) {
248
568
  Traverse(flat, right_asymmetric);
249
569
  printf("4\n");
250
570
  Handle<String> left_deep_asymmetric =
251
- ConstructLeft(building_blocks, SUPER_DEEP_DEPTH);
571
+ ConstructLeft(&data, SUPER_DEEP_DEPTH);
252
572
  Handle<String> right_deep_asymmetric =
253
- ConstructRight(building_blocks, SUPER_DEEP_DEPTH);
573
+ ConstructRight(&data, SUPER_DEEP_DEPTH);
254
574
  printf("5\n");
255
575
  TraverseFirst(left_asymmetric, left_deep_asymmetric, 1050);
256
576
  printf("6\n");
@@ -273,6 +593,248 @@ TEST(Traverse) {
273
593
  }
274
594
 
275
595
 
596
+ static void VerifyCharacterStream(
597
+ String* flat_string, String* cons_string) {
598
+ // Do not want to test ConString traversal on flat string.
599
+ CHECK(flat_string->IsFlat() && !flat_string->IsConsString());
600
+ CHECK(cons_string->IsConsString());
601
+ // TODO(dcarney) Test stream reset as well.
602
+ int length = flat_string->length();
603
+ // Iterate start search in multiple places in the string.
604
+ int outer_iterations = length > 20 ? 20 : length;
605
+ for (int j = 0; j <= outer_iterations; j++) {
606
+ int offset = length * j / outer_iterations;
607
+ if (offset < 0) offset = 0;
608
+ // Want to test the offset == length case.
609
+ if (offset > length) offset = length;
610
+ StringCharacterStream flat_stream(
611
+ flat_string, &cons_string_iterator_op_1, static_cast<unsigned>(offset));
612
+ StringCharacterStream cons_stream(
613
+ cons_string, &cons_string_iterator_op_2, static_cast<unsigned>(offset));
614
+ for (int i = offset; i < length; i++) {
615
+ uint16_t c = flat_string->Get(i);
616
+ CHECK(flat_stream.HasMore());
617
+ CHECK(cons_stream.HasMore());
618
+ CHECK_EQ(c, flat_stream.GetNext());
619
+ CHECK_EQ(c, cons_stream.GetNext());
620
+ }
621
+ CHECK(!flat_stream.HasMore());
622
+ CHECK(!cons_stream.HasMore());
623
+ }
624
+ }
625
+
626
+
627
+ static inline void PrintStats(const ConsStringGenerationData& data) {
628
+ #ifdef DEBUG
629
+ printf(
630
+ "%s: [%d], %s: [%d], %s: [%d], %s: [%d], %s: [%d], %s: [%d]\n",
631
+ "leaves", data.stats_.leaves_,
632
+ "empty", data.stats_.empty_leaves_,
633
+ "chars", data.stats_.chars_,
634
+ "lefts", data.stats_.left_traversals_,
635
+ "rights", data.stats_.right_traversals_,
636
+ "early_terminations", data.early_terminations_);
637
+ #endif
638
+ }
639
+
640
+
641
+ template<typename BuildString>
642
+ void TestStringCharacterStream(BuildString build, int test_cases) {
643
+ InitializeVM();
644
+ Isolate* isolate = Isolate::Current();
645
+ HandleScope outer_scope(isolate);
646
+ ZoneScope zone(Isolate::Current()->runtime_zone(), DELETE_ON_EXIT);
647
+ ConsStringGenerationData data(true);
648
+ for (int i = 0; i < test_cases; i++) {
649
+ printf("%d\n", i);
650
+ HandleScope inner_scope(isolate);
651
+ AlwaysAllocateScope always_allocate;
652
+ // Build flat version of cons string.
653
+ Handle<String> flat_string = build(i, &data);
654
+ ConsStringStats flat_string_stats;
655
+ AccumulateStats(flat_string, &flat_string_stats);
656
+ // Flatten string.
657
+ FlattenString(flat_string);
658
+ // Build unflattened version of cons string to test.
659
+ Handle<String> cons_string = build(i, &data);
660
+ ConsStringStats cons_string_stats;
661
+ AccumulateStats(cons_string, &cons_string_stats);
662
+ AssertNoAllocation no_alloc;
663
+ PrintStats(data);
664
+ // Full verify of cons string.
665
+ cons_string_stats.VerifyEqual(flat_string_stats);
666
+ cons_string_stats.VerifyEqual(data.stats_);
667
+ VerifyConsString(cons_string, &data);
668
+ String* flat_string_ptr =
669
+ flat_string->IsConsString() ?
670
+ ConsString::cast(*flat_string)->first() :
671
+ *flat_string;
672
+ VerifyCharacterStream(flat_string_ptr, *cons_string);
673
+ }
674
+ }
675
+
676
+
677
+ static const int kCharacterStreamNonRandomCases = 8;
678
+
679
+
680
+ static Handle<String> BuildEdgeCaseConsString(
681
+ int test_case, ConsStringGenerationData* data) {
682
+ data->Reset();
683
+ switch (test_case) {
684
+ case 0:
685
+ return ConstructBalanced(data, 71);
686
+ case 1:
687
+ return ConstructLeft(data, 71);
688
+ case 2:
689
+ return ConstructRight(data, 71);
690
+ case 3:
691
+ return ConstructLeft(data, 10);
692
+ case 4:
693
+ return ConstructRight(data, 10);
694
+ case 5:
695
+ // 2 element balanced tree.
696
+ data->stats_.chars_ += data->block(0)->length();
697
+ data->stats_.chars_ += data->block(1)->length();
698
+ data->stats_.leaves_ += 2;
699
+ return FACTORY->NewConsString(data->block(0), data->block(1));
700
+ case 6:
701
+ // Simple flattened tree.
702
+ data->stats_.chars_ += data->block(0)->length();
703
+ data->stats_.chars_ += data->block(1)->length();
704
+ data->stats_.leaves_ += 2;
705
+ data->stats_.empty_leaves_ += 1;
706
+ {
707
+ Handle<String> string =
708
+ FACTORY->NewConsString(data->block(0), data->block(1));
709
+ FlattenString(string);
710
+ return string;
711
+ }
712
+ case 7:
713
+ // Left node flattened.
714
+ data->stats_.chars_ += data->block(0)->length();
715
+ data->stats_.chars_ += data->block(1)->length();
716
+ data->stats_.chars_ += data->block(2)->length();
717
+ data->stats_.leaves_ += 3;
718
+ data->stats_.empty_leaves_ += 1;
719
+ data->stats_.left_traversals_ += 1;
720
+ {
721
+ Handle<String> left =
722
+ FACTORY->NewConsString(data->block(0), data->block(1));
723
+ FlattenString(left);
724
+ return FACTORY->NewConsString(left, data->block(2));
725
+ }
726
+ case 8:
727
+ // Left node and right node flattened.
728
+ data->stats_.chars_ += data->block(0)->length();
729
+ data->stats_.chars_ += data->block(1)->length();
730
+ data->stats_.chars_ += data->block(2)->length();
731
+ data->stats_.chars_ += data->block(3)->length();
732
+ data->stats_.leaves_ += 4;
733
+ data->stats_.empty_leaves_ += 2;
734
+ data->stats_.left_traversals_ += 1;
735
+ data->stats_.right_traversals_ += 1;
736
+ {
737
+ Handle<String> left =
738
+ FACTORY->NewConsString(data->block(0), data->block(1));
739
+ FlattenString(left);
740
+ Handle<String> right =
741
+ FACTORY->NewConsString(data->block(2), data->block(2));
742
+ FlattenString(right);
743
+ return FACTORY->NewConsString(left, right);
744
+ }
745
+ }
746
+ UNREACHABLE();
747
+ return Handle<String>();
748
+ }
749
+
750
+
751
+ TEST(StringCharacterStreamEdgeCases) {
752
+ printf("TestStringCharacterStreamEdgeCases\n");
753
+ TestStringCharacterStream(
754
+ BuildEdgeCaseConsString, kCharacterStreamNonRandomCases);
755
+ }
756
+
757
+
758
+ static const int kBalances = 3;
759
+ static const int kTreeLengths = 4;
760
+ static const int kEmptyLeaves = 4;
761
+ static const int kUniqueRandomParameters =
762
+ kBalances*kTreeLengths*kEmptyLeaves;
763
+
764
+
765
+ static void InitializeGenerationData(
766
+ int test_case, ConsStringGenerationData* data) {
767
+ // Clear the settings and reinit the rng.
768
+ data->Reset();
769
+ // Spin up the rng to a known location that is unique per test.
770
+ static const int kPerTestJump = 501;
771
+ for (int j = 0; j < test_case*kPerTestJump; j++) {
772
+ data->rng_.next();
773
+ }
774
+ // Choose balanced, left or right heavy trees.
775
+ switch (test_case % kBalances) {
776
+ case 0:
777
+ // Nothing to do. Already balanced.
778
+ break;
779
+ case 1:
780
+ // Left balanced.
781
+ data->leftness_ = 0.90;
782
+ data->rightness_ = 0.15;
783
+ break;
784
+ case 2:
785
+ // Right balanced.
786
+ data->leftness_ = 0.15;
787
+ data->rightness_ = 0.90;
788
+ break;
789
+ default:
790
+ UNREACHABLE();
791
+ break;
792
+ }
793
+ // Must remove the influence of the above decision.
794
+ test_case /= kBalances;
795
+ // Choose tree length.
796
+ switch (test_case % kTreeLengths) {
797
+ case 0:
798
+ data->max_leaves_ = 16;
799
+ data->early_termination_threshold_ = 0.2;
800
+ break;
801
+ case 1:
802
+ data->max_leaves_ = 50;
803
+ data->early_termination_threshold_ = 0.05;
804
+ break;
805
+ case 2:
806
+ data->max_leaves_ = 500;
807
+ data->early_termination_threshold_ = 0.03;
808
+ break;
809
+ case 3:
810
+ data->max_leaves_ = 5000;
811
+ data->early_termination_threshold_ = 0.001;
812
+ break;
813
+ default:
814
+ UNREACHABLE();
815
+ break;
816
+ }
817
+ // Must remove the influence of the above decision.
818
+ test_case /= kTreeLengths;
819
+ // Choose how much we allow empty nodes, including not at all.
820
+ data->empty_leaf_threshold_ =
821
+ 0.03 * static_cast<double>(test_case % kEmptyLeaves);
822
+ }
823
+
824
+
825
+ static Handle<String> BuildRandomConsString(
826
+ int test_case, ConsStringGenerationData* data) {
827
+ InitializeGenerationData(test_case, data);
828
+ return ConstructRandomString(data, 200);
829
+ }
830
+
831
+
832
+ TEST(StringCharacterStreamRandom) {
833
+ printf("StringCharacterStreamRandom\n");
834
+ TestStringCharacterStream(BuildRandomConsString, kUniqueRandomParameters*7);
835
+ }
836
+
837
+
276
838
  static const int DEEP_ASCII_DEPTH = 100000;
277
839
 
278
840
 
@@ -348,10 +910,11 @@ TEST(Utf8Conversion) {
348
910
 
349
911
 
350
912
  TEST(ExternalShortStringAdd) {
351
- ZoneScope zone(Isolate::Current(), DELETE_ON_EXIT);
913
+ ZoneScope zonescope(Isolate::Current()->runtime_zone(), DELETE_ON_EXIT);
352
914
 
353
915
  InitializeVM();
354
916
  v8::HandleScope handle_scope;
917
+ Zone* zone = Isolate::Current()->runtime_zone();
355
918
 
356
919
  // Make sure we cover all always-flat lengths and at least one above.
357
920
  static const int kMaxLength = 20;
@@ -365,25 +928,25 @@ TEST(ExternalShortStringAdd) {
365
928
 
366
929
  // Generate short ascii and non-ascii external strings.
367
930
  for (int i = 0; i <= kMaxLength; i++) {
368
- char* ascii = ZONE->NewArray<char>(i + 1);
931
+ char* ascii = zone->NewArray<char>(i + 1);
369
932
  for (int j = 0; j < i; j++) {
370
933
  ascii[j] = 'a';
371
934
  }
372
935
  // Terminating '\0' is left out on purpose. It is not required for external
373
936
  // string data.
374
937
  AsciiResource* ascii_resource =
375
- new AsciiResource(Vector<const char>(ascii, i));
938
+ new(zone) AsciiResource(Vector<const char>(ascii, i));
376
939
  v8::Local<v8::String> ascii_external_string =
377
940
  v8::String::NewExternal(ascii_resource);
378
941
 
379
942
  ascii_external_strings->Set(v8::Integer::New(i), ascii_external_string);
380
- uc16* non_ascii = ZONE->NewArray<uc16>(i + 1);
943
+ uc16* non_ascii = zone->NewArray<uc16>(i + 1);
381
944
  for (int j = 0; j < i; j++) {
382
945
  non_ascii[j] = 0x1234;
383
946
  }
384
947
  // Terminating '\0' is left out on purpose. It is not required for external
385
948
  // string data.
386
- Resource* resource = new Resource(Vector<const uc16>(non_ascii, i));
949
+ Resource* resource = new(zone) Resource(Vector<const uc16>(non_ascii, i));
387
950
  v8::Local<v8::String> non_ascii_external_string =
388
951
  v8::String::NewExternal(resource);
389
952
  non_ascii_external_strings->Set(v8::Integer::New(i),
@@ -438,7 +1001,7 @@ TEST(CachedHashOverflow) {
438
1001
  // We incorrectly allowed strings to be tagged as array indices even if their
439
1002
  // values didn't fit in the hash field.
440
1003
  // See http://code.google.com/p/v8/issues/detail?id=728
441
- ZoneScope zone(Isolate::Current(), DELETE_ON_EXIT);
1004
+ ZoneScope zone(Isolate::Current()->runtime_zone(), DELETE_ON_EXIT);
442
1005
 
443
1006
  InitializeVM();
444
1007
  v8::HandleScope handle_scope;
@@ -672,3 +1235,102 @@ TEST(RobustSubStringStub) {
672
1235
  CompileRun("var slice = long.slice(1, 15);");
673
1236
  CheckException("%_SubString(slice, 0, 17);");
674
1237
  }
1238
+
1239
+
1240
+ TEST(RegExpOverflow) {
1241
+ // Result string has the length 2^32, causing a 32-bit integer overflow.
1242
+ InitializeVM();
1243
+ HandleScope scope;
1244
+ LocalContext context;
1245
+ v8::V8::IgnoreOutOfMemoryException();
1246
+ v8::Local<v8::Value> result = CompileRun(
1247
+ "var a = 'a'; "
1248
+ "for (var i = 0; i < 16; i++) { "
1249
+ " a += a; "
1250
+ "} "
1251
+ "a.replace(/a/g, a); ");
1252
+ CHECK(result.IsEmpty());
1253
+ CHECK(context->HasOutOfMemoryException());
1254
+ }
1255
+
1256
+
1257
+ TEST(StringReplaceAtomTwoByteResult) {
1258
+ InitializeVM();
1259
+ HandleScope scope;
1260
+ LocalContext context;
1261
+ v8::Local<v8::Value> result = CompileRun(
1262
+ "var subject = 'ascii~only~string~'; "
1263
+ "var replace = '\x80'; "
1264
+ "subject.replace(/~/g, replace); ");
1265
+ CHECK(result->IsString());
1266
+ Handle<String> string = v8::Utils::OpenHandle(v8::String::Cast(*result));
1267
+ CHECK(string->IsSeqTwoByteString());
1268
+
1269
+ v8::Local<v8::String> expected = v8_str("ascii\x80only\x80string\x80");
1270
+ CHECK(expected->Equals(result));
1271
+ }
1272
+
1273
+
1274
+ TEST(IsAscii) {
1275
+ CHECK(String::IsAscii(static_cast<char*>(NULL), 0));
1276
+ CHECK(String::IsOneByte(static_cast<uc16*>(NULL), 0));
1277
+ }
1278
+
1279
+
1280
+
1281
+ #ifdef ENABLE_LATIN_1
1282
+ template<typename Op, bool return_first>
1283
+ static uint16_t ConvertLatin1(uint16_t c) {
1284
+ uint32_t result[Op::kMaxWidth];
1285
+ int chars;
1286
+ chars = Op::Convert(c, 0, result, NULL);
1287
+ if (chars == 0) return 0;
1288
+ CHECK_LE(chars, static_cast<int>(sizeof(result)));
1289
+ if (!return_first && chars > 1) {
1290
+ return 0;
1291
+ }
1292
+ return result[0];
1293
+ }
1294
+
1295
+
1296
+ static void CheckCanonicalEquivalence(uint16_t c, uint16_t test) {
1297
+ uint16_t expect = ConvertLatin1<unibrow::Ecma262UnCanonicalize, true>(c);
1298
+ if (expect > unibrow::Latin1::kMaxChar) expect = 0;
1299
+ CHECK_EQ(expect, test);
1300
+ }
1301
+
1302
+
1303
+ TEST(Latin1IgnoreCase) {
1304
+ if (true) return;
1305
+ using namespace unibrow;
1306
+ for (uint16_t c = Latin1::kMaxChar + 1; c != 0; c++) {
1307
+ uint16_t lower = ConvertLatin1<ToLowercase, false>(c);
1308
+ uint16_t upper = ConvertLatin1<ToUppercase, false>(c);
1309
+ uint16_t test = Latin1::ConvertNonLatin1ToLatin1(c);
1310
+ // Filter out all character whose upper is not their lower or vice versa.
1311
+ if (lower == 0 && upper == 0) {
1312
+ CheckCanonicalEquivalence(c, test);
1313
+ continue;
1314
+ }
1315
+ if (lower > Latin1::kMaxChar && upper > Latin1::kMaxChar) {
1316
+ CheckCanonicalEquivalence(c, test);
1317
+ continue;
1318
+ }
1319
+ if (lower == 0 && upper != 0) {
1320
+ lower = ConvertLatin1<ToLowercase, false>(upper);
1321
+ }
1322
+ if (upper == 0 && lower != c) {
1323
+ upper = ConvertLatin1<ToUppercase, false>(lower);
1324
+ }
1325
+ if (lower > Latin1::kMaxChar && upper > Latin1::kMaxChar) {
1326
+ CheckCanonicalEquivalence(c, test);
1327
+ continue;
1328
+ }
1329
+ if (upper != c && lower != c) {
1330
+ CheckCanonicalEquivalence(c, test);
1331
+ continue;
1332
+ }
1333
+ CHECK_EQ(Min(upper, lower), test);
1334
+ }
1335
+ }
1336
+ #endif // ENABLE_LATIN_1