therubyracer 0.4.6 → 0.4.7

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of therubyracer might be problematic. Click here for more details.

Files changed (1148) hide show
  1. data/Manifest.txt +1138 -0
  2. data/README.rdoc +7 -5
  3. data/Rakefile +12 -2
  4. data/ext/v8/Makefile +169 -0
  5. data/ext/v8/extconf.rb +20 -3
  6. data/ext/v8/upstream/2.0.6/.sconsign.dblite +0 -0
  7. data/ext/v8/upstream/2.0.6/AUTHORS +23 -0
  8. data/ext/v8/upstream/2.0.6/ChangeLog +1479 -0
  9. data/ext/v8/upstream/2.0.6/LICENSE +55 -0
  10. data/ext/v8/upstream/2.0.6/SConstruct +1028 -0
  11. data/ext/v8/upstream/2.0.6/benchmarks/README.txt +63 -0
  12. data/ext/v8/upstream/2.0.6/benchmarks/base.js +264 -0
  13. data/ext/v8/upstream/2.0.6/benchmarks/crypto.js +1698 -0
  14. data/ext/v8/upstream/2.0.6/benchmarks/deltablue.js +880 -0
  15. data/ext/v8/upstream/2.0.6/benchmarks/earley-boyer.js +4684 -0
  16. data/ext/v8/upstream/2.0.6/benchmarks/raytrace.js +935 -0
  17. data/ext/v8/upstream/2.0.6/benchmarks/regexp.js +1614 -0
  18. data/ext/v8/upstream/2.0.6/benchmarks/revisions.html +86 -0
  19. data/ext/v8/upstream/2.0.6/benchmarks/richards.js +539 -0
  20. data/ext/v8/upstream/2.0.6/benchmarks/run.html +141 -0
  21. data/ext/v8/upstream/2.0.6/benchmarks/run.js +61 -0
  22. data/ext/v8/upstream/2.0.6/benchmarks/splay.js +378 -0
  23. data/ext/v8/upstream/2.0.6/benchmarks/style.css +77 -0
  24. data/ext/v8/upstream/2.0.6/benchmarks/v8-logo.png +0 -0
  25. data/ext/v8/upstream/2.0.6/include/v8-debug.h +275 -0
  26. data/ext/v8/upstream/2.0.6/include/v8.h +3236 -0
  27. data/ext/v8/upstream/2.0.6/samples/SConscript +38 -0
  28. data/ext/v8/upstream/2.0.6/samples/count-hosts.js +42 -0
  29. data/ext/v8/upstream/2.0.6/samples/process.cc +622 -0
  30. data/ext/v8/upstream/2.0.6/samples/shell.cc +303 -0
  31. data/ext/v8/upstream/2.0.6/src/SConscript +283 -0
  32. data/ext/v8/upstream/2.0.6/src/accessors.cc +695 -0
  33. data/ext/v8/upstream/2.0.6/src/accessors.h +114 -0
  34. data/ext/v8/upstream/2.0.6/src/allocation.cc +198 -0
  35. data/ext/v8/upstream/2.0.6/src/allocation.h +169 -0
  36. data/ext/v8/upstream/2.0.6/src/api.cc +3831 -0
  37. data/ext/v8/upstream/2.0.6/src/api.h +479 -0
  38. data/ext/v8/upstream/2.0.6/src/apinatives.js +110 -0
  39. data/ext/v8/upstream/2.0.6/src/apiutils.h +69 -0
  40. data/ext/v8/upstream/2.0.6/src/arguments.h +97 -0
  41. data/ext/v8/upstream/2.0.6/src/arm/assembler-arm-inl.h +277 -0
  42. data/ext/v8/upstream/2.0.6/src/arm/assembler-arm.cc +1821 -0
  43. data/ext/v8/upstream/2.0.6/src/arm/assembler-arm.h +1027 -0
  44. data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2-inl.h +267 -0
  45. data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2.cc +1821 -0
  46. data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2.h +1027 -0
  47. data/ext/v8/upstream/2.0.6/src/arm/builtins-arm.cc +1271 -0
  48. data/ext/v8/upstream/2.0.6/src/arm/codegen-arm-inl.h +74 -0
  49. data/ext/v8/upstream/2.0.6/src/arm/codegen-arm.cc +6682 -0
  50. data/ext/v8/upstream/2.0.6/src/arm/codegen-arm.h +535 -0
  51. data/ext/v8/upstream/2.0.6/src/arm/constants-arm.cc +112 -0
  52. data/ext/v8/upstream/2.0.6/src/arm/constants-arm.h +347 -0
  53. data/ext/v8/upstream/2.0.6/src/arm/cpu-arm.cc +132 -0
  54. data/ext/v8/upstream/2.0.6/src/arm/debug-arm.cc +213 -0
  55. data/ext/v8/upstream/2.0.6/src/arm/disasm-arm.cc +1166 -0
  56. data/ext/v8/upstream/2.0.6/src/arm/fast-codegen-arm.cc +1698 -0
  57. data/ext/v8/upstream/2.0.6/src/arm/frames-arm.cc +123 -0
  58. data/ext/v8/upstream/2.0.6/src/arm/frames-arm.h +162 -0
  59. data/ext/v8/upstream/2.0.6/src/arm/ic-arm.cc +849 -0
  60. data/ext/v8/upstream/2.0.6/src/arm/jump-target-arm.cc +238 -0
  61. data/ext/v8/upstream/2.0.6/src/arm/macro-assembler-arm.cc +1259 -0
  62. data/ext/v8/upstream/2.0.6/src/arm/macro-assembler-arm.h +423 -0
  63. data/ext/v8/upstream/2.0.6/src/arm/regexp-macro-assembler-arm.cc +1266 -0
  64. data/ext/v8/upstream/2.0.6/src/arm/regexp-macro-assembler-arm.h +282 -0
  65. data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm-inl.h +103 -0
  66. data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm.cc +59 -0
  67. data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm.h +43 -0
  68. data/ext/v8/upstream/2.0.6/src/arm/simulator-arm.cc +2264 -0
  69. data/ext/v8/upstream/2.0.6/src/arm/simulator-arm.h +306 -0
  70. data/ext/v8/upstream/2.0.6/src/arm/stub-cache-arm.cc +1516 -0
  71. data/ext/v8/upstream/2.0.6/src/arm/virtual-frame-arm.cc +412 -0
  72. data/ext/v8/upstream/2.0.6/src/arm/virtual-frame-arm.h +532 -0
  73. data/ext/v8/upstream/2.0.6/src/array.js +1154 -0
  74. data/ext/v8/upstream/2.0.6/src/assembler.cc +772 -0
  75. data/ext/v8/upstream/2.0.6/src/assembler.h +525 -0
  76. data/ext/v8/upstream/2.0.6/src/ast.cc +512 -0
  77. data/ext/v8/upstream/2.0.6/src/ast.h +1820 -0
  78. data/ext/v8/upstream/2.0.6/src/bootstrapper.cc +1680 -0
  79. data/ext/v8/upstream/2.0.6/src/bootstrapper.h +103 -0
  80. data/ext/v8/upstream/2.0.6/src/builtins.cc +851 -0
  81. data/ext/v8/upstream/2.0.6/src/builtins.h +245 -0
  82. data/ext/v8/upstream/2.0.6/src/bytecodes-irregexp.h +104 -0
  83. data/ext/v8/upstream/2.0.6/src/char-predicates-inl.h +86 -0
  84. data/ext/v8/upstream/2.0.6/src/char-predicates.h +65 -0
  85. data/ext/v8/upstream/2.0.6/src/checks.cc +100 -0
  86. data/ext/v8/upstream/2.0.6/src/checks.h +284 -0
  87. data/ext/v8/upstream/2.0.6/src/code-stubs.cc +164 -0
  88. data/ext/v8/upstream/2.0.6/src/code-stubs.h +164 -0
  89. data/ext/v8/upstream/2.0.6/src/code.h +68 -0
  90. data/ext/v8/upstream/2.0.6/src/codegen-inl.h +88 -0
  91. data/ext/v8/upstream/2.0.6/src/codegen.cc +504 -0
  92. data/ext/v8/upstream/2.0.6/src/codegen.h +522 -0
  93. data/ext/v8/upstream/2.0.6/src/compilation-cache.cc +490 -0
  94. data/ext/v8/upstream/2.0.6/src/compilation-cache.h +98 -0
  95. data/ext/v8/upstream/2.0.6/src/compiler.cc +1132 -0
  96. data/ext/v8/upstream/2.0.6/src/compiler.h +107 -0
  97. data/ext/v8/upstream/2.0.6/src/contexts.cc +256 -0
  98. data/ext/v8/upstream/2.0.6/src/contexts.h +345 -0
  99. data/ext/v8/upstream/2.0.6/src/conversions-inl.h +95 -0
  100. data/ext/v8/upstream/2.0.6/src/conversions.cc +709 -0
  101. data/ext/v8/upstream/2.0.6/src/conversions.h +118 -0
  102. data/ext/v8/upstream/2.0.6/src/counters.cc +78 -0
  103. data/ext/v8/upstream/2.0.6/src/counters.h +239 -0
  104. data/ext/v8/upstream/2.0.6/src/cpu.h +65 -0
  105. data/ext/v8/upstream/2.0.6/src/d8-debug.cc +345 -0
  106. data/ext/v8/upstream/2.0.6/src/d8-debug.h +155 -0
  107. data/ext/v8/upstream/2.0.6/src/d8-posix.cc +675 -0
  108. data/ext/v8/upstream/2.0.6/src/d8-readline.cc +128 -0
  109. data/ext/v8/upstream/2.0.6/src/d8-windows.cc +42 -0
  110. data/ext/v8/upstream/2.0.6/src/d8.cc +776 -0
  111. data/ext/v8/upstream/2.0.6/src/d8.h +225 -0
  112. data/ext/v8/upstream/2.0.6/src/d8.js +1625 -0
  113. data/ext/v8/upstream/2.0.6/src/date-delay.js +1138 -0
  114. data/ext/v8/upstream/2.0.6/src/dateparser-inl.h +114 -0
  115. data/ext/v8/upstream/2.0.6/src/dateparser.cc +186 -0
  116. data/ext/v8/upstream/2.0.6/src/dateparser.h +240 -0
  117. data/ext/v8/upstream/2.0.6/src/debug-agent.cc +425 -0
  118. data/ext/v8/upstream/2.0.6/src/debug-agent.h +129 -0
  119. data/ext/v8/upstream/2.0.6/src/debug-delay.js +2073 -0
  120. data/ext/v8/upstream/2.0.6/src/debug.cc +2751 -0
  121. data/ext/v8/upstream/2.0.6/src/debug.h +866 -0
  122. data/ext/v8/upstream/2.0.6/src/disasm.h +77 -0
  123. data/ext/v8/upstream/2.0.6/src/disassembler.cc +318 -0
  124. data/ext/v8/upstream/2.0.6/src/disassembler.h +56 -0
  125. data/ext/v8/upstream/2.0.6/src/dtoa-config.c +91 -0
  126. data/ext/v8/upstream/2.0.6/src/execution.cc +701 -0
  127. data/ext/v8/upstream/2.0.6/src/execution.h +312 -0
  128. data/ext/v8/upstream/2.0.6/src/factory.cc +957 -0
  129. data/ext/v8/upstream/2.0.6/src/factory.h +393 -0
  130. data/ext/v8/upstream/2.0.6/src/fast-codegen.cc +725 -0
  131. data/ext/v8/upstream/2.0.6/src/fast-codegen.h +371 -0
  132. data/ext/v8/upstream/2.0.6/src/flag-definitions.h +426 -0
  133. data/ext/v8/upstream/2.0.6/src/flags.cc +555 -0
  134. data/ext/v8/upstream/2.0.6/src/flags.h +81 -0
  135. data/ext/v8/upstream/2.0.6/src/frame-element.cc +45 -0
  136. data/ext/v8/upstream/2.0.6/src/frame-element.h +235 -0
  137. data/ext/v8/upstream/2.0.6/src/frames-inl.h +215 -0
  138. data/ext/v8/upstream/2.0.6/src/frames.cc +749 -0
  139. data/ext/v8/upstream/2.0.6/src/frames.h +659 -0
  140. data/ext/v8/upstream/2.0.6/src/func-name-inferrer.cc +76 -0
  141. data/ext/v8/upstream/2.0.6/src/func-name-inferrer.h +135 -0
  142. data/ext/v8/upstream/2.0.6/src/global-handles.cc +516 -0
  143. data/ext/v8/upstream/2.0.6/src/global-handles.h +180 -0
  144. data/ext/v8/upstream/2.0.6/src/globals.h +608 -0
  145. data/ext/v8/upstream/2.0.6/src/handles-inl.h +76 -0
  146. data/ext/v8/upstream/2.0.6/src/handles.cc +811 -0
  147. data/ext/v8/upstream/2.0.6/src/handles.h +367 -0
  148. data/ext/v8/upstream/2.0.6/src/hashmap.cc +226 -0
  149. data/ext/v8/upstream/2.0.6/src/hashmap.h +120 -0
  150. data/ext/v8/upstream/2.0.6/src/heap-inl.h +407 -0
  151. data/ext/v8/upstream/2.0.6/src/heap-profiler.cc +695 -0
  152. data/ext/v8/upstream/2.0.6/src/heap-profiler.h +277 -0
  153. data/ext/v8/upstream/2.0.6/src/heap.cc +4204 -0
  154. data/ext/v8/upstream/2.0.6/src/heap.h +1704 -0
  155. data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32-inl.h +325 -0
  156. data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32.cc +2375 -0
  157. data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32.h +914 -0
  158. data/ext/v8/upstream/2.0.6/src/ia32/builtins-ia32.cc +1222 -0
  159. data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32-inl.h +46 -0
  160. data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32.cc +9770 -0
  161. data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32.h +834 -0
  162. data/ext/v8/upstream/2.0.6/src/ia32/cpu-ia32.cc +79 -0
  163. data/ext/v8/upstream/2.0.6/src/ia32/debug-ia32.cc +208 -0
  164. data/ext/v8/upstream/2.0.6/src/ia32/disasm-ia32.cc +1357 -0
  165. data/ext/v8/upstream/2.0.6/src/ia32/fast-codegen-ia32.cc +1813 -0
  166. data/ext/v8/upstream/2.0.6/src/ia32/frames-ia32.cc +111 -0
  167. data/ext/v8/upstream/2.0.6/src/ia32/frames-ia32.h +135 -0
  168. data/ext/v8/upstream/2.0.6/src/ia32/ic-ia32.cc +1490 -0
  169. data/ext/v8/upstream/2.0.6/src/ia32/jump-target-ia32.cc +432 -0
  170. data/ext/v8/upstream/2.0.6/src/ia32/macro-assembler-ia32.cc +1517 -0
  171. data/ext/v8/upstream/2.0.6/src/ia32/macro-assembler-ia32.h +528 -0
  172. data/ext/v8/upstream/2.0.6/src/ia32/regexp-macro-assembler-ia32.cc +1219 -0
  173. data/ext/v8/upstream/2.0.6/src/ia32/regexp-macro-assembler-ia32.h +230 -0
  174. data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32-inl.h +82 -0
  175. data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32.cc +99 -0
  176. data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32.h +43 -0
  177. data/ext/v8/upstream/2.0.6/src/ia32/simulator-ia32.cc +30 -0
  178. data/ext/v8/upstream/2.0.6/src/ia32/simulator-ia32.h +62 -0
  179. data/ext/v8/upstream/2.0.6/src/ia32/stub-cache-ia32.cc +1961 -0
  180. data/ext/v8/upstream/2.0.6/src/ia32/virtual-frame-ia32.cc +1105 -0
  181. data/ext/v8/upstream/2.0.6/src/ia32/virtual-frame-ia32.h +580 -0
  182. data/ext/v8/upstream/2.0.6/src/ic-inl.h +93 -0
  183. data/ext/v8/upstream/2.0.6/src/ic.cc +1426 -0
  184. data/ext/v8/upstream/2.0.6/src/ic.h +443 -0
  185. data/ext/v8/upstream/2.0.6/src/interpreter-irregexp.cc +646 -0
  186. data/ext/v8/upstream/2.0.6/src/interpreter-irregexp.h +48 -0
  187. data/ext/v8/upstream/2.0.6/src/json-delay.js +254 -0
  188. data/ext/v8/upstream/2.0.6/src/jsregexp.cc +5234 -0
  189. data/ext/v8/upstream/2.0.6/src/jsregexp.h +1439 -0
  190. data/ext/v8/upstream/2.0.6/src/jump-target-inl.h +49 -0
  191. data/ext/v8/upstream/2.0.6/src/jump-target.cc +383 -0
  192. data/ext/v8/upstream/2.0.6/src/jump-target.h +280 -0
  193. data/ext/v8/upstream/2.0.6/src/list-inl.h +166 -0
  194. data/ext/v8/upstream/2.0.6/src/list.h +158 -0
  195. data/ext/v8/upstream/2.0.6/src/log-inl.h +126 -0
  196. data/ext/v8/upstream/2.0.6/src/log-utils.cc +503 -0
  197. data/ext/v8/upstream/2.0.6/src/log-utils.h +292 -0
  198. data/ext/v8/upstream/2.0.6/src/log.cc +1457 -0
  199. data/ext/v8/upstream/2.0.6/src/log.h +371 -0
  200. data/ext/v8/upstream/2.0.6/src/macro-assembler.h +93 -0
  201. data/ext/v8/upstream/2.0.6/src/macros.py +137 -0
  202. data/ext/v8/upstream/2.0.6/src/mark-compact.cc +2007 -0
  203. data/ext/v8/upstream/2.0.6/src/mark-compact.h +442 -0
  204. data/ext/v8/upstream/2.0.6/src/math.js +263 -0
  205. data/ext/v8/upstream/2.0.6/src/memory.h +74 -0
  206. data/ext/v8/upstream/2.0.6/src/messages.cc +177 -0
  207. data/ext/v8/upstream/2.0.6/src/messages.h +112 -0
  208. data/ext/v8/upstream/2.0.6/src/messages.js +937 -0
  209. data/ext/v8/upstream/2.0.6/src/mirror-delay.js +2332 -0
  210. data/ext/v8/upstream/2.0.6/src/mksnapshot.cc +169 -0
  211. data/ext/v8/upstream/2.0.6/src/natives.h +63 -0
  212. data/ext/v8/upstream/2.0.6/src/objects-debug.cc +1317 -0
  213. data/ext/v8/upstream/2.0.6/src/objects-inl.h +3044 -0
  214. data/ext/v8/upstream/2.0.6/src/objects.cc +8306 -0
  215. data/ext/v8/upstream/2.0.6/src/objects.h +4960 -0
  216. data/ext/v8/upstream/2.0.6/src/oprofile-agent.cc +116 -0
  217. data/ext/v8/upstream/2.0.6/src/oprofile-agent.h +69 -0
  218. data/ext/v8/upstream/2.0.6/src/parser.cc +4810 -0
  219. data/ext/v8/upstream/2.0.6/src/parser.h +195 -0
  220. data/ext/v8/upstream/2.0.6/src/platform-freebsd.cc +645 -0
  221. data/ext/v8/upstream/2.0.6/src/platform-linux.cc +808 -0
  222. data/ext/v8/upstream/2.0.6/src/platform-macos.cc +643 -0
  223. data/ext/v8/upstream/2.0.6/src/platform-nullos.cc +454 -0
  224. data/ext/v8/upstream/2.0.6/src/platform-openbsd.cc +597 -0
  225. data/ext/v8/upstream/2.0.6/src/platform-posix.cc +380 -0
  226. data/ext/v8/upstream/2.0.6/src/platform-win32.cc +1908 -0
  227. data/ext/v8/upstream/2.0.6/src/platform.h +556 -0
  228. data/ext/v8/upstream/2.0.6/src/prettyprinter.cc +1511 -0
  229. data/ext/v8/upstream/2.0.6/src/prettyprinter.h +219 -0
  230. data/ext/v8/upstream/2.0.6/src/property.cc +96 -0
  231. data/ext/v8/upstream/2.0.6/src/property.h +327 -0
  232. data/ext/v8/upstream/2.0.6/src/regexp-delay.js +406 -0
  233. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp-inl.h +78 -0
  234. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp.cc +464 -0
  235. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp.h +141 -0
  236. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-tracer.cc +356 -0
  237. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-tracer.h +103 -0
  238. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler.cc +240 -0
  239. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler.h +220 -0
  240. data/ext/v8/upstream/2.0.6/src/regexp-stack.cc +103 -0
  241. data/ext/v8/upstream/2.0.6/src/regexp-stack.h +123 -0
  242. data/ext/v8/upstream/2.0.6/src/register-allocator-inl.h +74 -0
  243. data/ext/v8/upstream/2.0.6/src/register-allocator.cc +100 -0
  244. data/ext/v8/upstream/2.0.6/src/register-allocator.h +295 -0
  245. data/ext/v8/upstream/2.0.6/src/rewriter.cc +855 -0
  246. data/ext/v8/upstream/2.0.6/src/rewriter.h +54 -0
  247. data/ext/v8/upstream/2.0.6/src/runtime.cc +8163 -0
  248. data/ext/v8/upstream/2.0.6/src/runtime.h +432 -0
  249. data/ext/v8/upstream/2.0.6/src/runtime.js +626 -0
  250. data/ext/v8/upstream/2.0.6/src/scanner.cc +1098 -0
  251. data/ext/v8/upstream/2.0.6/src/scanner.h +425 -0
  252. data/ext/v8/upstream/2.0.6/src/scopeinfo.cc +649 -0
  253. data/ext/v8/upstream/2.0.6/src/scopeinfo.h +236 -0
  254. data/ext/v8/upstream/2.0.6/src/scopes.cc +963 -0
  255. data/ext/v8/upstream/2.0.6/src/scopes.h +401 -0
  256. data/ext/v8/upstream/2.0.6/src/serialize.cc +1260 -0
  257. data/ext/v8/upstream/2.0.6/src/serialize.h +404 -0
  258. data/ext/v8/upstream/2.0.6/src/shell.h +55 -0
  259. data/ext/v8/upstream/2.0.6/src/simulator.h +41 -0
  260. data/ext/v8/upstream/2.0.6/src/smart-pointer.h +109 -0
  261. data/ext/v8/upstream/2.0.6/src/snapshot-common.cc +97 -0
  262. data/ext/v8/upstream/2.0.6/src/snapshot-empty.cc +40 -0
  263. data/ext/v8/upstream/2.0.6/src/snapshot.h +59 -0
  264. data/ext/v8/upstream/2.0.6/src/spaces-inl.h +372 -0
  265. data/ext/v8/upstream/2.0.6/src/spaces.cc +2864 -0
  266. data/ext/v8/upstream/2.0.6/src/spaces.h +2072 -0
  267. data/ext/v8/upstream/2.0.6/src/string-stream.cc +584 -0
  268. data/ext/v8/upstream/2.0.6/src/string-stream.h +189 -0
  269. data/ext/v8/upstream/2.0.6/src/string.js +901 -0
  270. data/ext/v8/upstream/2.0.6/src/stub-cache.cc +1108 -0
  271. data/ext/v8/upstream/2.0.6/src/stub-cache.h +578 -0
  272. data/ext/v8/upstream/2.0.6/src/third_party/dtoa/COPYING +15 -0
  273. data/ext/v8/upstream/2.0.6/src/third_party/dtoa/dtoa.c +3330 -0
  274. data/ext/v8/upstream/2.0.6/src/third_party/valgrind/valgrind.h +3925 -0
  275. data/ext/v8/upstream/2.0.6/src/token.cc +56 -0
  276. data/ext/v8/upstream/2.0.6/src/token.h +270 -0
  277. data/ext/v8/upstream/2.0.6/src/top.cc +991 -0
  278. data/ext/v8/upstream/2.0.6/src/top.h +459 -0
  279. data/ext/v8/upstream/2.0.6/src/unicode-inl.h +238 -0
  280. data/ext/v8/upstream/2.0.6/src/unicode.cc +749 -0
  281. data/ext/v8/upstream/2.0.6/src/unicode.h +279 -0
  282. data/ext/v8/upstream/2.0.6/src/uri.js +415 -0
  283. data/ext/v8/upstream/2.0.6/src/usage-analyzer.cc +426 -0
  284. data/ext/v8/upstream/2.0.6/src/usage-analyzer.h +40 -0
  285. data/ext/v8/upstream/2.0.6/src/utils.cc +322 -0
  286. data/ext/v8/upstream/2.0.6/src/utils.h +592 -0
  287. data/ext/v8/upstream/2.0.6/src/v8-counters.cc +55 -0
  288. data/ext/v8/upstream/2.0.6/src/v8-counters.h +198 -0
  289. data/ext/v8/upstream/2.0.6/src/v8.cc +193 -0
  290. data/ext/v8/upstream/2.0.6/src/v8.h +119 -0
  291. data/ext/v8/upstream/2.0.6/src/v8natives.js +846 -0
  292. data/ext/v8/upstream/2.0.6/src/v8threads.cc +450 -0
  293. data/ext/v8/upstream/2.0.6/src/v8threads.h +144 -0
  294. data/ext/v8/upstream/2.0.6/src/variables.cc +163 -0
  295. data/ext/v8/upstream/2.0.6/src/variables.h +235 -0
  296. data/ext/v8/upstream/2.0.6/src/version.cc +88 -0
  297. data/ext/v8/upstream/2.0.6/src/version.h +64 -0
  298. data/ext/v8/upstream/2.0.6/src/virtual-frame.cc +381 -0
  299. data/ext/v8/upstream/2.0.6/src/virtual-frame.h +44 -0
  300. data/ext/v8/upstream/2.0.6/src/x64/assembler-x64-inl.h +352 -0
  301. data/ext/v8/upstream/2.0.6/src/x64/assembler-x64.cc +2539 -0
  302. data/ext/v8/upstream/2.0.6/src/x64/assembler-x64.h +1399 -0
  303. data/ext/v8/upstream/2.0.6/src/x64/builtins-x64.cc +1255 -0
  304. data/ext/v8/upstream/2.0.6/src/x64/codegen-x64-inl.h +46 -0
  305. data/ext/v8/upstream/2.0.6/src/x64/codegen-x64.cc +8223 -0
  306. data/ext/v8/upstream/2.0.6/src/x64/codegen-x64.h +785 -0
  307. data/ext/v8/upstream/2.0.6/src/x64/cpu-x64.cc +79 -0
  308. data/ext/v8/upstream/2.0.6/src/x64/debug-x64.cc +202 -0
  309. data/ext/v8/upstream/2.0.6/src/x64/disasm-x64.cc +1596 -0
  310. data/ext/v8/upstream/2.0.6/src/x64/fast-codegen-x64.cc +1820 -0
  311. data/ext/v8/upstream/2.0.6/src/x64/frames-x64.cc +109 -0
  312. data/ext/v8/upstream/2.0.6/src/x64/frames-x64.h +121 -0
  313. data/ext/v8/upstream/2.0.6/src/x64/ic-x64.cc +1392 -0
  314. data/ext/v8/upstream/2.0.6/src/x64/jump-target-x64.cc +432 -0
  315. data/ext/v8/upstream/2.0.6/src/x64/macro-assembler-x64.cc +2409 -0
  316. data/ext/v8/upstream/2.0.6/src/x64/macro-assembler-x64.h +765 -0
  317. data/ext/v8/upstream/2.0.6/src/x64/regexp-macro-assembler-x64.cc +1337 -0
  318. data/ext/v8/upstream/2.0.6/src/x64/regexp-macro-assembler-x64.h +295 -0
  319. data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64-inl.h +86 -0
  320. data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64.cc +84 -0
  321. data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64.h +43 -0
  322. data/ext/v8/upstream/2.0.6/src/x64/simulator-x64.cc +27 -0
  323. data/ext/v8/upstream/2.0.6/src/x64/simulator-x64.h +63 -0
  324. data/ext/v8/upstream/2.0.6/src/x64/stub-cache-x64.cc +1884 -0
  325. data/ext/v8/upstream/2.0.6/src/x64/virtual-frame-x64.cc +1089 -0
  326. data/ext/v8/upstream/2.0.6/src/x64/virtual-frame-x64.h +560 -0
  327. data/ext/v8/upstream/2.0.6/src/zone-inl.h +297 -0
  328. data/ext/v8/upstream/2.0.6/src/zone.cc +193 -0
  329. data/ext/v8/upstream/2.0.6/src/zone.h +305 -0
  330. data/ext/v8/upstream/2.0.6/test/cctest/SConscript +95 -0
  331. data/ext/v8/upstream/2.0.6/test/cctest/cctest.cc +126 -0
  332. data/ext/v8/upstream/2.0.6/test/cctest/cctest.h +211 -0
  333. data/ext/v8/upstream/2.0.6/test/cctest/cctest.status +54 -0
  334. data/ext/v8/upstream/2.0.6/test/cctest/test-accessors.cc +450 -0
  335. data/ext/v8/upstream/2.0.6/test/cctest/test-alloc.cc +215 -0
  336. data/ext/v8/upstream/2.0.6/test/cctest/test-api.cc +8699 -0
  337. data/ext/v8/upstream/2.0.6/test/cctest/test-assembler-arm.cc +227 -0
  338. data/ext/v8/upstream/2.0.6/test/cctest/test-assembler-ia32.cc +395 -0
  339. data/ext/v8/upstream/2.0.6/test/cctest/test-assembler-x64.cc +292 -0
  340. data/ext/v8/upstream/2.0.6/test/cctest/test-ast.cc +97 -0
  341. data/ext/v8/upstream/2.0.6/test/cctest/test-compiler.cc +318 -0
  342. data/ext/v8/upstream/2.0.6/test/cctest/test-conversions.cc +130 -0
  343. data/ext/v8/upstream/2.0.6/test/cctest/test-debug.cc +5788 -0
  344. data/ext/v8/upstream/2.0.6/test/cctest/test-decls.cc +593 -0
  345. data/ext/v8/upstream/2.0.6/test/cctest/test-disasm-arm.cc +281 -0
  346. data/ext/v8/upstream/2.0.6/test/cctest/test-disasm-ia32.cc +418 -0
  347. data/ext/v8/upstream/2.0.6/test/cctest/test-flags.cc +234 -0
  348. data/ext/v8/upstream/2.0.6/test/cctest/test-func-name-inference.cc +267 -0
  349. data/ext/v8/upstream/2.0.6/test/cctest/test-hashmap.cc +176 -0
  350. data/ext/v8/upstream/2.0.6/test/cctest/test-heap-profiler.cc +396 -0
  351. data/ext/v8/upstream/2.0.6/test/cctest/test-heap.cc +796 -0
  352. data/ext/v8/upstream/2.0.6/test/cctest/test-list.cc +101 -0
  353. data/ext/v8/upstream/2.0.6/test/cctest/test-lock.cc +63 -0
  354. data/ext/v8/upstream/2.0.6/test/cctest/test-log-stack-tracer.cc +372 -0
  355. data/ext/v8/upstream/2.0.6/test/cctest/test-log-utils.cc +310 -0
  356. data/ext/v8/upstream/2.0.6/test/cctest/test-log.cc +1081 -0
  357. data/ext/v8/upstream/2.0.6/test/cctest/test-macro-assembler-x64.cc +2104 -0
  358. data/ext/v8/upstream/2.0.6/test/cctest/test-mark-compact.cc +341 -0
  359. data/ext/v8/upstream/2.0.6/test/cctest/test-parsing.cc +129 -0
  360. data/ext/v8/upstream/2.0.6/test/cctest/test-platform-linux.cc +80 -0
  361. data/ext/v8/upstream/2.0.6/test/cctest/test-platform-macos.cc +10 -0
  362. data/ext/v8/upstream/2.0.6/test/cctest/test-platform-nullos.cc +80 -0
  363. data/ext/v8/upstream/2.0.6/test/cctest/test-platform-win32.cc +26 -0
  364. data/ext/v8/upstream/2.0.6/test/cctest/test-regexp.cc +1815 -0
  365. data/ext/v8/upstream/2.0.6/test/cctest/test-serialize.cc +438 -0
  366. data/ext/v8/upstream/2.0.6/test/cctest/test-sockets.cc +162 -0
  367. data/ext/v8/upstream/2.0.6/test/cctest/test-spaces.cc +248 -0
  368. data/ext/v8/upstream/2.0.6/test/cctest/test-strings.cc +432 -0
  369. data/ext/v8/upstream/2.0.6/test/cctest/test-thread-termination.cc +290 -0
  370. data/ext/v8/upstream/2.0.6/test/cctest/test-threads.cc +52 -0
  371. data/ext/v8/upstream/2.0.6/test/cctest/test-utils.cc +186 -0
  372. data/ext/v8/upstream/2.0.6/test/cctest/test-version.cc +89 -0
  373. data/ext/v8/upstream/2.0.6/test/cctest/testcfg.py +108 -0
  374. data/ext/v8/upstream/2.0.6/test/es5conform/README +14 -0
  375. data/ext/v8/upstream/2.0.6/test/es5conform/es5conform.status +226 -0
  376. data/ext/v8/upstream/2.0.6/test/es5conform/harness-adapt.js +74 -0
  377. data/ext/v8/upstream/2.0.6/test/es5conform/testcfg.py +108 -0
  378. data/ext/v8/upstream/2.0.6/test/message/message.status +31 -0
  379. data/ext/v8/upstream/2.0.6/test/message/overwritten-builtins.js +31 -0
  380. data/ext/v8/upstream/2.0.6/test/message/overwritten-builtins.out +30 -0
  381. data/ext/v8/upstream/2.0.6/test/message/regress/regress-73.js +33 -0
  382. data/ext/v8/upstream/2.0.6/test/message/regress/regress-73.out +30 -0
  383. data/ext/v8/upstream/2.0.6/test/message/regress/regress-75.js +32 -0
  384. data/ext/v8/upstream/2.0.6/test/message/regress/regress-75.out +30 -0
  385. data/ext/v8/upstream/2.0.6/test/message/simple-throw.js +28 -0
  386. data/ext/v8/upstream/2.0.6/test/message/simple-throw.out +30 -0
  387. data/ext/v8/upstream/2.0.6/test/message/testcfg.py +135 -0
  388. data/ext/v8/upstream/2.0.6/test/message/try-catch-finally-no-message.js +51 -0
  389. data/ext/v8/upstream/2.0.6/test/message/try-catch-finally-no-message.out +26 -0
  390. data/ext/v8/upstream/2.0.6/test/message/try-catch-finally-return-in-finally.js +39 -0
  391. data/ext/v8/upstream/2.0.6/test/message/try-catch-finally-return-in-finally.out +28 -0
  392. data/ext/v8/upstream/2.0.6/test/message/try-catch-finally-throw-in-catch-and-finally.js +34 -0
  393. data/ext/v8/upstream/2.0.6/test/message/try-catch-finally-throw-in-catch-and-finally.out +30 -0
  394. data/ext/v8/upstream/2.0.6/test/message/try-catch-finally-throw-in-catch.js +34 -0
  395. data/ext/v8/upstream/2.0.6/test/message/try-catch-finally-throw-in-catch.out +30 -0
  396. data/ext/v8/upstream/2.0.6/test/message/try-catch-finally-throw-in-finally.js +34 -0
  397. data/ext/v8/upstream/2.0.6/test/message/try-catch-finally-throw-in-finally.out +30 -0
  398. data/ext/v8/upstream/2.0.6/test/message/try-finally-return-in-finally.js +37 -0
  399. data/ext/v8/upstream/2.0.6/test/message/try-finally-return-in-finally.out +28 -0
  400. data/ext/v8/upstream/2.0.6/test/message/try-finally-throw-in-finally.js +32 -0
  401. data/ext/v8/upstream/2.0.6/test/message/try-finally-throw-in-finally.out +30 -0
  402. data/ext/v8/upstream/2.0.6/test/message/try-finally-throw-in-try-and-finally.js +32 -0
  403. data/ext/v8/upstream/2.0.6/test/message/try-finally-throw-in-try-and-finally.out +30 -0
  404. data/ext/v8/upstream/2.0.6/test/message/try-finally-throw-in-try.js +32 -0
  405. data/ext/v8/upstream/2.0.6/test/message/try-finally-throw-in-try.out +30 -0
  406. data/ext/v8/upstream/2.0.6/test/mjsunit/api-call-after-bypassed-exception.js +39 -0
  407. data/ext/v8/upstream/2.0.6/test/mjsunit/apply.js +196 -0
  408. data/ext/v8/upstream/2.0.6/test/mjsunit/arguments-apply.js +134 -0
  409. data/ext/v8/upstream/2.0.6/test/mjsunit/arguments-call-apply.js +41 -0
  410. data/ext/v8/upstream/2.0.6/test/mjsunit/arguments-enum.js +52 -0
  411. data/ext/v8/upstream/2.0.6/test/mjsunit/arguments-indirect.js +47 -0
  412. data/ext/v8/upstream/2.0.6/test/mjsunit/arguments-lazy.js +47 -0
  413. data/ext/v8/upstream/2.0.6/test/mjsunit/arguments-opt.js +130 -0
  414. data/ext/v8/upstream/2.0.6/test/mjsunit/arguments-read-and-assignment.js +164 -0
  415. data/ext/v8/upstream/2.0.6/test/mjsunit/arguments.js +97 -0
  416. data/ext/v8/upstream/2.0.6/test/mjsunit/array-concat.js +120 -0
  417. data/ext/v8/upstream/2.0.6/test/mjsunit/array-constructor.js +119 -0
  418. data/ext/v8/upstream/2.0.6/test/mjsunit/array-functions-prototype.js +159 -0
  419. data/ext/v8/upstream/2.0.6/test/mjsunit/array-indexing.js +66 -0
  420. data/ext/v8/upstream/2.0.6/test/mjsunit/array-iteration.js +228 -0
  421. data/ext/v8/upstream/2.0.6/test/mjsunit/array-join.js +45 -0
  422. data/ext/v8/upstream/2.0.6/test/mjsunit/array-length-number-conversion.js +53 -0
  423. data/ext/v8/upstream/2.0.6/test/mjsunit/array-length.js +111 -0
  424. data/ext/v8/upstream/2.0.6/test/mjsunit/array-reduce.js +514 -0
  425. data/ext/v8/upstream/2.0.6/test/mjsunit/array-sort.js +362 -0
  426. data/ext/v8/upstream/2.0.6/test/mjsunit/array-splice.js +314 -0
  427. data/ext/v8/upstream/2.0.6/test/mjsunit/ascii-regexp-subject.js +49 -0
  428. data/ext/v8/upstream/2.0.6/test/mjsunit/big-array-literal.js +111 -0
  429. data/ext/v8/upstream/2.0.6/test/mjsunit/big-object-literal.js +114 -0
  430. data/ext/v8/upstream/2.0.6/test/mjsunit/binary-operation-overwrite.js +36 -0
  431. data/ext/v8/upstream/2.0.6/test/mjsunit/bit-not.js +75 -0
  432. data/ext/v8/upstream/2.0.6/test/mjsunit/bitwise-operations-undefined.js +49 -0
  433. data/ext/v8/upstream/2.0.6/test/mjsunit/body-not-visible.js +39 -0
  434. data/ext/v8/upstream/2.0.6/test/mjsunit/bugs/bug-1344252.js +79 -0
  435. data/ext/v8/upstream/2.0.6/test/mjsunit/bugs/bug-222.js +42 -0
  436. data/ext/v8/upstream/2.0.6/test/mjsunit/bugs/bug-223.js +39 -0
  437. data/ext/v8/upstream/2.0.6/test/mjsunit/bugs/bug-900066.js +38 -0
  438. data/ext/v8/upstream/2.0.6/test/mjsunit/bugs/bug-941049.js +100 -0
  439. data/ext/v8/upstream/2.0.6/test/mjsunit/call-non-function-call.js +38 -0
  440. data/ext/v8/upstream/2.0.6/test/mjsunit/call-non-function.js +63 -0
  441. data/ext/v8/upstream/2.0.6/test/mjsunit/call.js +87 -0
  442. data/ext/v8/upstream/2.0.6/test/mjsunit/char-escape.js +53 -0
  443. data/ext/v8/upstream/2.0.6/test/mjsunit/class-of-builtins.js +50 -0
  444. data/ext/v8/upstream/2.0.6/test/mjsunit/closure.js +37 -0
  445. data/ext/v8/upstream/2.0.6/test/mjsunit/codegen-coverage.js +91 -0
  446. data/ext/v8/upstream/2.0.6/test/mjsunit/compare-character.js +50 -0
  447. data/ext/v8/upstream/2.0.6/test/mjsunit/compare-nan.js +66 -0
  448. data/ext/v8/upstream/2.0.6/test/mjsunit/compiler/countoperation.js +111 -0
  449. data/ext/v8/upstream/2.0.6/test/mjsunit/compiler/function-call.js +52 -0
  450. data/ext/v8/upstream/2.0.6/test/mjsunit/compiler/globals.js +65 -0
  451. data/ext/v8/upstream/2.0.6/test/mjsunit/compiler/jsnatives.js +33 -0
  452. data/ext/v8/upstream/2.0.6/test/mjsunit/compiler/literals-assignment.js +104 -0
  453. data/ext/v8/upstream/2.0.6/test/mjsunit/compiler/literals.js +52 -0
  454. data/ext/v8/upstream/2.0.6/test/mjsunit/compiler/loops.js +35 -0
  455. data/ext/v8/upstream/2.0.6/test/mjsunit/compiler/objectliterals.js +57 -0
  456. data/ext/v8/upstream/2.0.6/test/mjsunit/compiler/property-simple.js +39 -0
  457. data/ext/v8/upstream/2.0.6/test/mjsunit/compiler/short-circuit.js +102 -0
  458. data/ext/v8/upstream/2.0.6/test/mjsunit/compiler/thisfunction.js +35 -0
  459. data/ext/v8/upstream/2.0.6/test/mjsunit/const-declaration.js +172 -0
  460. data/ext/v8/upstream/2.0.6/test/mjsunit/const-eval-init.js +111 -0
  461. data/ext/v8/upstream/2.0.6/test/mjsunit/const-redecl.js +220 -0
  462. data/ext/v8/upstream/2.0.6/test/mjsunit/const.js +70 -0
  463. data/ext/v8/upstream/2.0.6/test/mjsunit/constant-folding.js +232 -0
  464. data/ext/v8/upstream/2.0.6/test/mjsunit/context-variable-assignments.js +37 -0
  465. data/ext/v8/upstream/2.0.6/test/mjsunit/cyclic-array-to-string.js +65 -0
  466. data/ext/v8/upstream/2.0.6/test/mjsunit/cyrillic.js +199 -0
  467. data/ext/v8/upstream/2.0.6/test/mjsunit/d8-os.js +180 -0
  468. data/ext/v8/upstream/2.0.6/test/mjsunit/date-parse.js +268 -0
  469. data/ext/v8/upstream/2.0.6/test/mjsunit/date.js +149 -0
  470. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-backtrace-text.js +122 -0
  471. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-backtrace.js +272 -0
  472. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-breakpoints.js +120 -0
  473. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-changebreakpoint.js +108 -0
  474. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-clearbreakpoint.js +101 -0
  475. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-clearbreakpointgroup.js +117 -0
  476. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-compile-event.js +126 -0
  477. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-conditional-breakpoints.js +171 -0
  478. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-constructed-by.js +60 -0
  479. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-constructor.js +78 -0
  480. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-continue.js +114 -0
  481. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-enable-disable-breakpoints.js +90 -0
  482. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-evaluate-arguments.js +93 -0
  483. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-evaluate-bool-constructor.js +80 -0
  484. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-evaluate-locals.js +132 -0
  485. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-evaluate-recursive.js +167 -0
  486. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-evaluate-with.js +77 -0
  487. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-evaluate.js +118 -0
  488. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-event-listener.js +73 -0
  489. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-handle.js +252 -0
  490. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-ignore-breakpoints.js +89 -0
  491. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-mirror-cache.js +85 -0
  492. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-multiple-breakpoints.js +105 -0
  493. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-referenced-by.js +112 -0
  494. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-references.js +118 -0
  495. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-scopes.js +761 -0
  496. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-script-breakpoints.js +112 -0
  497. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-script.js +92 -0
  498. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-scripts-request.js +108 -0
  499. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-setbreakpoint.js +165 -0
  500. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-sourceinfo.js +352 -0
  501. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-sourceslice.js +74 -0
  502. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-step-stub-callfunction.js +87 -0
  503. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-step.js +82 -0
  504. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-stepin-accessor.js +248 -0
  505. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-stepin-builtin.js +78 -0
  506. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-stepin-call-function-stub.js +115 -0
  507. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-stepin-constructor.js +78 -0
  508. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-stepin-function-call.js +149 -0
  509. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-stepnext-do-while.js +79 -0
  510. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-stepout-recursive-function.js +106 -0
  511. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-stepout-to-builtin.js +84 -0
  512. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-suspend.js +96 -0
  513. data/ext/v8/upstream/2.0.6/test/mjsunit/debug-version.js +90 -0
  514. data/ext/v8/upstream/2.0.6/test/mjsunit/declare-locally.js +43 -0
  515. data/ext/v8/upstream/2.0.6/test/mjsunit/deep-recursion.js +66 -0
  516. data/ext/v8/upstream/2.0.6/test/mjsunit/delay-syntax-error.js +41 -0
  517. data/ext/v8/upstream/2.0.6/test/mjsunit/delete-global-properties.js +37 -0
  518. data/ext/v8/upstream/2.0.6/test/mjsunit/delete-in-eval.js +32 -0
  519. data/ext/v8/upstream/2.0.6/test/mjsunit/delete-in-with.js +34 -0
  520. data/ext/v8/upstream/2.0.6/test/mjsunit/delete-vars-from-eval.js +40 -0
  521. data/ext/v8/upstream/2.0.6/test/mjsunit/delete.js +163 -0
  522. data/ext/v8/upstream/2.0.6/test/mjsunit/div-mod.js +157 -0
  523. data/ext/v8/upstream/2.0.6/test/mjsunit/do-not-strip-fc.js +31 -0
  524. data/ext/v8/upstream/2.0.6/test/mjsunit/dont-enum-array-holes.js +35 -0
  525. data/ext/v8/upstream/2.0.6/test/mjsunit/dont-reinit-global-var.js +47 -0
  526. data/ext/v8/upstream/2.0.6/test/mjsunit/double-equals.js +114 -0
  527. data/ext/v8/upstream/2.0.6/test/mjsunit/dtoa.js +32 -0
  528. data/ext/v8/upstream/2.0.6/test/mjsunit/enumeration-order.js +109 -0
  529. data/ext/v8/upstream/2.0.6/test/mjsunit/error-constructors.js +32 -0
  530. data/ext/v8/upstream/2.0.6/test/mjsunit/escape.js +118 -0
  531. data/ext/v8/upstream/2.0.6/test/mjsunit/eval-enclosing-function-name.js +76 -0
  532. data/ext/v8/upstream/2.0.6/test/mjsunit/eval-typeof-non-existing.js +35 -0
  533. data/ext/v8/upstream/2.0.6/test/mjsunit/eval.js +157 -0
  534. data/ext/v8/upstream/2.0.6/test/mjsunit/execScript-case-insensitive.js +34 -0
  535. data/ext/v8/upstream/2.0.6/test/mjsunit/extra-arguments.js +54 -0
  536. data/ext/v8/upstream/2.0.6/test/mjsunit/extra-commas.js +46 -0
  537. data/ext/v8/upstream/2.0.6/test/mjsunit/for-in-null-or-undefined.js +33 -0
  538. data/ext/v8/upstream/2.0.6/test/mjsunit/for-in-special-cases.js +64 -0
  539. data/ext/v8/upstream/2.0.6/test/mjsunit/for-in.js +86 -0
  540. data/ext/v8/upstream/2.0.6/test/mjsunit/fun-as-prototype.js +36 -0
  541. data/ext/v8/upstream/2.0.6/test/mjsunit/fun-name.js +34 -0
  542. data/ext/v8/upstream/2.0.6/test/mjsunit/function-arguments-null.js +30 -0
  543. data/ext/v8/upstream/2.0.6/test/mjsunit/function-caller.js +48 -0
  544. data/ext/v8/upstream/2.0.6/test/mjsunit/function-names.js +133 -0
  545. data/ext/v8/upstream/2.0.6/test/mjsunit/function-property.js +29 -0
  546. data/ext/v8/upstream/2.0.6/test/mjsunit/function-prototype.js +98 -0
  547. data/ext/v8/upstream/2.0.6/test/mjsunit/function-source.js +49 -0
  548. data/ext/v8/upstream/2.0.6/test/mjsunit/function.js +83 -0
  549. data/ext/v8/upstream/2.0.6/test/mjsunit/fuzz-accessors.js +85 -0
  550. data/ext/v8/upstream/2.0.6/test/mjsunit/fuzz-natives.js +159 -0
  551. data/ext/v8/upstream/2.0.6/test/mjsunit/get-own-property-descriptor.js +51 -0
  552. data/ext/v8/upstream/2.0.6/test/mjsunit/get-prototype-of.js +68 -0
  553. data/ext/v8/upstream/2.0.6/test/mjsunit/getter-in-prototype.js +50 -0
  554. data/ext/v8/upstream/2.0.6/test/mjsunit/getter-in-value-prototype.js +35 -0
  555. data/ext/v8/upstream/2.0.6/test/mjsunit/global-const-var-conflicts.js +57 -0
  556. data/ext/v8/upstream/2.0.6/test/mjsunit/global-deleted-property-ic.js +45 -0
  557. data/ext/v8/upstream/2.0.6/test/mjsunit/global-deleted-property-keyed.js +38 -0
  558. data/ext/v8/upstream/2.0.6/test/mjsunit/global-ic.js +48 -0
  559. data/ext/v8/upstream/2.0.6/test/mjsunit/global-load-from-eval-in-with.js +59 -0
  560. data/ext/v8/upstream/2.0.6/test/mjsunit/global-load-from-eval.js +85 -0
  561. data/ext/v8/upstream/2.0.6/test/mjsunit/global-load-from-nested-eval.js +66 -0
  562. data/ext/v8/upstream/2.0.6/test/mjsunit/global-vars-eval.js +34 -0
  563. data/ext/v8/upstream/2.0.6/test/mjsunit/global-vars-with.js +43 -0
  564. data/ext/v8/upstream/2.0.6/test/mjsunit/greedy.js +60 -0
  565. data/ext/v8/upstream/2.0.6/test/mjsunit/has-own-property.js +38 -0
  566. data/ext/v8/upstream/2.0.6/test/mjsunit/html-comments.js +57 -0
  567. data/ext/v8/upstream/2.0.6/test/mjsunit/html-string-funcs.js +47 -0
  568. data/ext/v8/upstream/2.0.6/test/mjsunit/if-in-undefined.js +36 -0
  569. data/ext/v8/upstream/2.0.6/test/mjsunit/in.js +159 -0
  570. data/ext/v8/upstream/2.0.6/test/mjsunit/indexed-accessors.js +120 -0
  571. data/ext/v8/upstream/2.0.6/test/mjsunit/instanceof.js +93 -0
  572. data/ext/v8/upstream/2.0.6/test/mjsunit/integer-to-string.js +35 -0
  573. data/ext/v8/upstream/2.0.6/test/mjsunit/invalid-lhs.js +65 -0
  574. data/ext/v8/upstream/2.0.6/test/mjsunit/invalid-source-element.js +31 -0
  575. data/ext/v8/upstream/2.0.6/test/mjsunit/json.js +207 -0
  576. data/ext/v8/upstream/2.0.6/test/mjsunit/keyed-ic.js +236 -0
  577. data/ext/v8/upstream/2.0.6/test/mjsunit/keyed-storage-extend.js +55 -0
  578. data/ext/v8/upstream/2.0.6/test/mjsunit/large-object-allocation.js +300 -0
  579. data/ext/v8/upstream/2.0.6/test/mjsunit/large-object-literal.js +56 -0
  580. data/ext/v8/upstream/2.0.6/test/mjsunit/lazy-load.js +34 -0
  581. data/ext/v8/upstream/2.0.6/test/mjsunit/leakcheck.js +53 -0
  582. data/ext/v8/upstream/2.0.6/test/mjsunit/length.js +78 -0
  583. data/ext/v8/upstream/2.0.6/test/mjsunit/local-load-from-eval.js +39 -0
  584. data/ext/v8/upstream/2.0.6/test/mjsunit/math-min-max.js +105 -0
  585. data/ext/v8/upstream/2.0.6/test/mjsunit/megamorphic-callbacks.js +70 -0
  586. data/ext/v8/upstream/2.0.6/test/mjsunit/mirror-array.js +138 -0
  587. data/ext/v8/upstream/2.0.6/test/mjsunit/mirror-boolean.js +59 -0
  588. data/ext/v8/upstream/2.0.6/test/mjsunit/mirror-date.js +77 -0
  589. data/ext/v8/upstream/2.0.6/test/mjsunit/mirror-error.js +94 -0
  590. data/ext/v8/upstream/2.0.6/test/mjsunit/mirror-function.js +90 -0
  591. data/ext/v8/upstream/2.0.6/test/mjsunit/mirror-null.js +50 -0
  592. data/ext/v8/upstream/2.0.6/test/mjsunit/mirror-number.js +77 -0
  593. data/ext/v8/upstream/2.0.6/test/mjsunit/mirror-object.js +227 -0
  594. data/ext/v8/upstream/2.0.6/test/mjsunit/mirror-regexp.js +110 -0
  595. data/ext/v8/upstream/2.0.6/test/mjsunit/mirror-script.js +100 -0
  596. data/ext/v8/upstream/2.0.6/test/mjsunit/mirror-string.js +89 -0
  597. data/ext/v8/upstream/2.0.6/test/mjsunit/mirror-undefined.js +50 -0
  598. data/ext/v8/upstream/2.0.6/test/mjsunit/mirror-unresolved-function.js +81 -0
  599. data/ext/v8/upstream/2.0.6/test/mjsunit/mjsunit.js +203 -0
  600. data/ext/v8/upstream/2.0.6/test/mjsunit/mjsunit.status +66 -0
  601. data/ext/v8/upstream/2.0.6/test/mjsunit/mul-exhaustive.js +4511 -0
  602. data/ext/v8/upstream/2.0.6/test/mjsunit/multiple-return.js +62 -0
  603. data/ext/v8/upstream/2.0.6/test/mjsunit/negate-zero.js +42 -0
  604. data/ext/v8/upstream/2.0.6/test/mjsunit/negate.js +59 -0
  605. data/ext/v8/upstream/2.0.6/test/mjsunit/new.js +56 -0
  606. data/ext/v8/upstream/2.0.6/test/mjsunit/newline-in-string.js +46 -0
  607. data/ext/v8/upstream/2.0.6/test/mjsunit/no-branch-elimination.js +36 -0
  608. data/ext/v8/upstream/2.0.6/test/mjsunit/no-octal-constants-above-256.js +32 -0
  609. data/ext/v8/upstream/2.0.6/test/mjsunit/no-semicolon.js +45 -0
  610. data/ext/v8/upstream/2.0.6/test/mjsunit/non-ascii-replace.js +30 -0
  611. data/ext/v8/upstream/2.0.6/test/mjsunit/nul-characters.js +38 -0
  612. data/ext/v8/upstream/2.0.6/test/mjsunit/number-limits.js +47 -0
  613. data/ext/v8/upstream/2.0.6/test/mjsunit/number-string-index-call.js +32 -0
  614. data/ext/v8/upstream/2.0.6/test/mjsunit/number-tostring-small.js +395 -0
  615. data/ext/v8/upstream/2.0.6/test/mjsunit/number-tostring.js +338 -0
  616. data/ext/v8/upstream/2.0.6/test/mjsunit/obj-construct.js +46 -0
  617. data/ext/v8/upstream/2.0.6/test/mjsunit/object-create.js +250 -0
  618. data/ext/v8/upstream/2.0.6/test/mjsunit/object-literal-gc.js +66 -0
  619. data/ext/v8/upstream/2.0.6/test/mjsunit/object-literal.js +105 -0
  620. data/ext/v8/upstream/2.0.6/test/mjsunit/override-read-only-property.js +64 -0
  621. data/ext/v8/upstream/2.0.6/test/mjsunit/parse-int-float.js +85 -0
  622. data/ext/v8/upstream/2.0.6/test/mjsunit/property-load-across-eval.js +85 -0
  623. data/ext/v8/upstream/2.0.6/test/mjsunit/property-object-key.js +36 -0
  624. data/ext/v8/upstream/2.0.6/test/mjsunit/proto.js +33 -0
  625. data/ext/v8/upstream/2.0.6/test/mjsunit/prototype.js +93 -0
  626. data/ext/v8/upstream/2.0.6/test/mjsunit/receiver-in-with-calls.js +47 -0
  627. data/ext/v8/upstream/2.0.6/test/mjsunit/regexp-UC16.js +47 -0
  628. data/ext/v8/upstream/2.0.6/test/mjsunit/regexp-call-as-function.js +36 -0
  629. data/ext/v8/upstream/2.0.6/test/mjsunit/regexp-capture.js +57 -0
  630. data/ext/v8/upstream/2.0.6/test/mjsunit/regexp-captures.js +31 -0
  631. data/ext/v8/upstream/2.0.6/test/mjsunit/regexp-indexof.js +77 -0
  632. data/ext/v8/upstream/2.0.6/test/mjsunit/regexp-lookahead.js +166 -0
  633. data/ext/v8/upstream/2.0.6/test/mjsunit/regexp-loop-capture.js +29 -0
  634. data/ext/v8/upstream/2.0.6/test/mjsunit/regexp-multiline-stack-trace.js +116 -0
  635. data/ext/v8/upstream/2.0.6/test/mjsunit/regexp-multiline.js +112 -0
  636. data/ext/v8/upstream/2.0.6/test/mjsunit/regexp-standalones.js +78 -0
  637. data/ext/v8/upstream/2.0.6/test/mjsunit/regexp-static.js +167 -0
  638. data/ext/v8/upstream/2.0.6/test/mjsunit/regexp-string-methods.js +51 -0
  639. data/ext/v8/upstream/2.0.6/test/mjsunit/regexp.js +390 -0
  640. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1030466.js +45 -0
  641. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1036894.js +38 -0
  642. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1039610.js +29 -0
  643. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1050043.js +51 -0
  644. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1062422.js +30 -0
  645. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1066899.js +37 -0
  646. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1081309.js +110 -0
  647. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1102760.js +35 -0
  648. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1110164.js +46 -0
  649. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1112051.js +33 -0
  650. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1114040.js +58 -0
  651. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1134697.js +31 -0
  652. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-114.js +43 -0
  653. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-116.js +40 -0
  654. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1170187.js +80 -0
  655. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1173979.js +48 -0
  656. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1175390.js +30 -0
  657. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1177518.js +39 -0
  658. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1177809.js +31 -0
  659. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1178598.js +90 -0
  660. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1182832.js +38 -0
  661. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1187524.js +34 -0
  662. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1199401.js +75 -0
  663. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1199637.js +78 -0
  664. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1200351.js +2032 -0
  665. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1201933.js +40 -0
  666. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1203459.js +29 -0
  667. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1207276.js +36 -0
  668. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1213516.js +40 -0
  669. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1213575.js +41 -0
  670. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1215653.js +365 -0
  671. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-124.js +57 -0
  672. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1254366.js +38 -0
  673. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1327557.js +36 -0
  674. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1341167.js +33 -0
  675. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1346700.js +29 -0
  676. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-137.js +46 -0
  677. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1439135.js +40 -0
  678. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-149.js +28 -0
  679. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1493017.js +52 -0
  680. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-155924.js +46 -0
  681. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-171.js +41 -0
  682. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-176.js +50 -0
  683. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-186.js +72 -0
  684. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-187.js +30 -0
  685. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-189.js +36 -0
  686. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-191.js +42 -0
  687. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-1919169.js +40 -0
  688. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-192.js +38 -0
  689. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-193.js +44 -0
  690. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-20070207.js +42 -0
  691. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-201.js +37 -0
  692. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-219.js +176 -0
  693. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-220.js +31 -0
  694. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-221.js +34 -0
  695. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-2249423.js +40 -0
  696. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-225.js +32 -0
  697. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-227.js +33 -0
  698. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-231.js +92 -0
  699. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-233.js +39 -0
  700. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-244.js +67 -0
  701. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-246.js +31 -0
  702. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-253.js +31 -0
  703. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-254.js +58 -0
  704. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-259.js +33 -0
  705. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-260.js +33 -0
  706. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-263.js +38 -0
  707. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-265.js +64 -0
  708. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-267.js +35 -0
  709. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-269.js +49 -0
  710. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-279.js +62 -0
  711. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-284.js +50 -0
  712. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-286.js +36 -0
  713. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-294.js +43 -0
  714. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-312.js +31 -0
  715. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-317.js +31 -0
  716. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-318.js +35 -0
  717. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-326.js +40 -0
  718. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-334.js +90 -0
  719. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-341.js +36 -0
  720. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-345.js +51 -0
  721. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-349.js +32 -0
  722. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-35.js +33 -0
  723. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-351.js +31 -0
  724. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-386.js +47 -0
  725. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-392.js +34 -0
  726. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-394.js +47 -0
  727. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-396.js +39 -0
  728. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-397.js +34 -0
  729. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-399.js +32 -0
  730. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-406.js +69 -0
  731. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-416.js +38 -0
  732. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-475.js +28 -0
  733. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-483.js +35 -0
  734. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-485.js +64 -0
  735. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-486.js +30 -0
  736. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-490.js +48 -0
  737. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-491.js +47 -0
  738. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-492.js +52 -0
  739. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-496.js +39 -0
  740. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-502.js +38 -0
  741. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-503.js +63 -0
  742. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-515.js +40 -0
  743. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-524.js +32 -0
  744. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-526.js +32 -0
  745. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-540.js +47 -0
  746. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-545.js +47 -0
  747. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-57.js +32 -0
  748. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-580.js +55 -0
  749. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-588599.js +31 -0
  750. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-6-9-regexp.js +30 -0
  751. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-662254.js +40 -0
  752. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-666721.js +53 -0
  753. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-667061.js +90 -0
  754. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-670147.js +34 -0
  755. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-674753.js +87 -0
  756. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-676025.js +31 -0
  757. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-678525.js +59 -0
  758. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-682649.js +30 -0
  759. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-69.js +43 -0
  760. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-734862.js +37 -0
  761. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-737588.js +34 -0
  762. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-74.js +41 -0
  763. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-780423.js +39 -0
  764. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-799761.js +92 -0
  765. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-806473.js +60 -0
  766. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-842017.js +60 -0
  767. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-86.js +46 -0
  768. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-87.js +58 -0
  769. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-874178.js +32 -0
  770. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-875031.js +37 -0
  771. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-877615.js +37 -0
  772. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-892742.js +50 -0
  773. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-900055.js +42 -0
  774. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-900966.js +38 -0
  775. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-91.js +38 -0
  776. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-925537.js +42 -0
  777. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-937896.js +50 -0
  778. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-990205.js +35 -0
  779. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-992733.js +35 -0
  780. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-996542.js +40 -0
  781. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-998565.js +51 -0
  782. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-crbug-18639.js +34 -0
  783. data/ext/v8/upstream/2.0.6/test/mjsunit/regress/regress-r3391.js +77 -0
  784. data/ext/v8/upstream/2.0.6/test/mjsunit/scanner.js +30 -0
  785. data/ext/v8/upstream/2.0.6/test/mjsunit/short-circuit-boolean.js +46 -0
  786. data/ext/v8/upstream/2.0.6/test/mjsunit/simple-constructor.js +140 -0
  787. data/ext/v8/upstream/2.0.6/test/mjsunit/sin-cos.js +45 -0
  788. data/ext/v8/upstream/2.0.6/test/mjsunit/smi-negative-zero.js +100 -0
  789. data/ext/v8/upstream/2.0.6/test/mjsunit/smi-ops.js +671 -0
  790. data/ext/v8/upstream/2.0.6/test/mjsunit/sparse-array-reverse.js +131 -0
  791. data/ext/v8/upstream/2.0.6/test/mjsunit/sparse-array.js +41 -0
  792. data/ext/v8/upstream/2.0.6/test/mjsunit/stack-traces.js +204 -0
  793. data/ext/v8/upstream/2.0.6/test/mjsunit/str-to-num.js +158 -0
  794. data/ext/v8/upstream/2.0.6/test/mjsunit/stress-array-push.js +34 -0
  795. data/ext/v8/upstream/2.0.6/test/mjsunit/strict-equals.js +90 -0
  796. data/ext/v8/upstream/2.0.6/test/mjsunit/string-add.js +195 -0
  797. data/ext/v8/upstream/2.0.6/test/mjsunit/string-case.js +28 -0
  798. data/ext/v8/upstream/2.0.6/test/mjsunit/string-charat.js +53 -0
  799. data/ext/v8/upstream/2.0.6/test/mjsunit/string-charcodeat.js +192 -0
  800. data/ext/v8/upstream/2.0.6/test/mjsunit/string-compare-alignment.js +47 -0
  801. data/ext/v8/upstream/2.0.6/test/mjsunit/string-flatten.js +37 -0
  802. data/ext/v8/upstream/2.0.6/test/mjsunit/string-index.js +154 -0
  803. data/ext/v8/upstream/2.0.6/test/mjsunit/string-indexof-1.js +99 -0
  804. data/ext/v8/upstream/2.0.6/test/mjsunit/string-indexof-2.js +68 -0
  805. data/ext/v8/upstream/2.0.6/test/mjsunit/string-lastindexof.js +88 -0
  806. data/ext/v8/upstream/2.0.6/test/mjsunit/string-localecompare.js +40 -0
  807. data/ext/v8/upstream/2.0.6/test/mjsunit/string-match.js +149 -0
  808. data/ext/v8/upstream/2.0.6/test/mjsunit/string-replace-gc.js +57 -0
  809. data/ext/v8/upstream/2.0.6/test/mjsunit/string-replace.js +182 -0
  810. data/ext/v8/upstream/2.0.6/test/mjsunit/string-search.js +30 -0
  811. data/ext/v8/upstream/2.0.6/test/mjsunit/string-split.js +126 -0
  812. data/ext/v8/upstream/2.0.6/test/mjsunit/substr.js +65 -0
  813. data/ext/v8/upstream/2.0.6/test/mjsunit/switch.js +289 -0
  814. data/ext/v8/upstream/2.0.6/test/mjsunit/testcfg.py +137 -0
  815. data/ext/v8/upstream/2.0.6/test/mjsunit/third_party/array-isarray.js +48 -0
  816. data/ext/v8/upstream/2.0.6/test/mjsunit/third_party/array-splice-webkit.js +62 -0
  817. data/ext/v8/upstream/2.0.6/test/mjsunit/third_party/object-keys.js +68 -0
  818. data/ext/v8/upstream/2.0.6/test/mjsunit/third_party/regexp-pcre.js +6603 -0
  819. data/ext/v8/upstream/2.0.6/test/mjsunit/third_party/string-trim.js +107 -0
  820. data/ext/v8/upstream/2.0.6/test/mjsunit/this-in-callbacks.js +47 -0
  821. data/ext/v8/upstream/2.0.6/test/mjsunit/this.js +46 -0
  822. data/ext/v8/upstream/2.0.6/test/mjsunit/throw-and-catch-function.js +50 -0
  823. data/ext/v8/upstream/2.0.6/test/mjsunit/throw-exception-for-null-access.js +37 -0
  824. data/ext/v8/upstream/2.0.6/test/mjsunit/to-precision.js +82 -0
  825. data/ext/v8/upstream/2.0.6/test/mjsunit/to_number_order.js +129 -0
  826. data/ext/v8/upstream/2.0.6/test/mjsunit/tobool.js +36 -0
  827. data/ext/v8/upstream/2.0.6/test/mjsunit/toint32.js +129 -0
  828. data/ext/v8/upstream/2.0.6/test/mjsunit/tools/codemap.js +180 -0
  829. data/ext/v8/upstream/2.0.6/test/mjsunit/tools/consarray.js +60 -0
  830. data/ext/v8/upstream/2.0.6/test/mjsunit/tools/csvparser.js +79 -0
  831. data/ext/v8/upstream/2.0.6/test/mjsunit/tools/logreader.js +98 -0
  832. data/ext/v8/upstream/2.0.6/test/mjsunit/tools/profile.js +348 -0
  833. data/ext/v8/upstream/2.0.6/test/mjsunit/tools/profile_view.js +95 -0
  834. data/ext/v8/upstream/2.0.6/test/mjsunit/tools/splaytree.js +166 -0
  835. data/ext/v8/upstream/2.0.6/test/mjsunit/tools/tickprocessor-test.default +55 -0
  836. data/ext/v8/upstream/2.0.6/test/mjsunit/tools/tickprocessor-test.gc-state +21 -0
  837. data/ext/v8/upstream/2.0.6/test/mjsunit/tools/tickprocessor-test.ignore-unknown +51 -0
  838. data/ext/v8/upstream/2.0.6/test/mjsunit/tools/tickprocessor-test.separate-ic +61 -0
  839. data/ext/v8/upstream/2.0.6/test/mjsunit/tools/tickprocessor.js +409 -0
  840. data/ext/v8/upstream/2.0.6/test/mjsunit/top-level-assignments.js +107 -0
  841. data/ext/v8/upstream/2.0.6/test/mjsunit/touint32.js +72 -0
  842. data/ext/v8/upstream/2.0.6/test/mjsunit/transcendentals.js +49 -0
  843. data/ext/v8/upstream/2.0.6/test/mjsunit/try-catch-extension-object.js +58 -0
  844. data/ext/v8/upstream/2.0.6/test/mjsunit/try-catch-scopes.js +42 -0
  845. data/ext/v8/upstream/2.0.6/test/mjsunit/try-finally-nested.js +46 -0
  846. data/ext/v8/upstream/2.0.6/test/mjsunit/try.js +394 -0
  847. data/ext/v8/upstream/2.0.6/test/mjsunit/typeof.js +40 -0
  848. data/ext/v8/upstream/2.0.6/test/mjsunit/undeletable-functions.js +181 -0
  849. data/ext/v8/upstream/2.0.6/test/mjsunit/unicode-case-overoptimization.js +35 -0
  850. data/ext/v8/upstream/2.0.6/test/mjsunit/unicode-string-to-number.js +46 -0
  851. data/ext/v8/upstream/2.0.6/test/mjsunit/unicode-test.js +9169 -0
  852. data/ext/v8/upstream/2.0.6/test/mjsunit/unusual-constructor.js +38 -0
  853. data/ext/v8/upstream/2.0.6/test/mjsunit/uri.js +78 -0
  854. data/ext/v8/upstream/2.0.6/test/mjsunit/value-callic-prototype-change.js +94 -0
  855. data/ext/v8/upstream/2.0.6/test/mjsunit/var.js +37 -0
  856. data/ext/v8/upstream/2.0.6/test/mjsunit/with-function-expression.js +36 -0
  857. data/ext/v8/upstream/2.0.6/test/mjsunit/with-leave.js +61 -0
  858. data/ext/v8/upstream/2.0.6/test/mjsunit/with-parameter-access.js +47 -0
  859. data/ext/v8/upstream/2.0.6/test/mjsunit/with-prototype.js +44 -0
  860. data/ext/v8/upstream/2.0.6/test/mjsunit/with-value.js +38 -0
  861. data/ext/v8/upstream/2.0.6/test/mozilla/mozilla-shell-emulation.js +37 -0
  862. data/ext/v8/upstream/2.0.6/test/mozilla/mozilla.status +815 -0
  863. data/ext/v8/upstream/2.0.6/test/mozilla/testcfg.py +138 -0
  864. data/ext/v8/upstream/2.0.6/test/sputnik/README +6 -0
  865. data/ext/v8/upstream/2.0.6/test/sputnik/sputnik.status +318 -0
  866. data/ext/v8/upstream/2.0.6/test/sputnik/testcfg.py +112 -0
  867. data/ext/v8/upstream/2.0.6/tools/codemap.js +258 -0
  868. data/ext/v8/upstream/2.0.6/tools/consarray.js +93 -0
  869. data/ext/v8/upstream/2.0.6/tools/csvparser.js +98 -0
  870. data/ext/v8/upstream/2.0.6/tools/gyp/v8.gyp +620 -0
  871. data/ext/v8/upstream/2.0.6/tools/js2c.py +376 -0
  872. data/ext/v8/upstream/2.0.6/tools/js2c.pyc +0 -0
  873. data/ext/v8/upstream/2.0.6/tools/jsmin.py +280 -0
  874. data/ext/v8/upstream/2.0.6/tools/jsmin.pyc +0 -0
  875. data/ext/v8/upstream/2.0.6/tools/linux-tick-processor +24 -0
  876. data/ext/v8/upstream/2.0.6/tools/linux-tick-processor.py +78 -0
  877. data/ext/v8/upstream/2.0.6/tools/logreader.js +320 -0
  878. data/ext/v8/upstream/2.0.6/tools/mac-nm +18 -0
  879. data/ext/v8/upstream/2.0.6/tools/mac-tick-processor +6 -0
  880. data/ext/v8/upstream/2.0.6/tools/oprofile/annotate +7 -0
  881. data/ext/v8/upstream/2.0.6/tools/oprofile/common +19 -0
  882. data/ext/v8/upstream/2.0.6/tools/oprofile/dump +7 -0
  883. data/ext/v8/upstream/2.0.6/tools/oprofile/report +7 -0
  884. data/ext/v8/upstream/2.0.6/tools/oprofile/reset +7 -0
  885. data/ext/v8/upstream/2.0.6/tools/oprofile/run +14 -0
  886. data/ext/v8/upstream/2.0.6/tools/oprofile/shutdown +7 -0
  887. data/ext/v8/upstream/2.0.6/tools/oprofile/start +7 -0
  888. data/ext/v8/upstream/2.0.6/tools/presubmit.py +299 -0
  889. data/ext/v8/upstream/2.0.6/tools/process-heap-prof.py +120 -0
  890. data/ext/v8/upstream/2.0.6/tools/profile.js +621 -0
  891. data/ext/v8/upstream/2.0.6/tools/profile_view.js +224 -0
  892. data/ext/v8/upstream/2.0.6/tools/run-valgrind.py +77 -0
  893. data/ext/v8/upstream/2.0.6/tools/splaytree.js +322 -0
  894. data/ext/v8/upstream/2.0.6/tools/splaytree.py +226 -0
  895. data/ext/v8/upstream/2.0.6/tools/stats-viewer.py +456 -0
  896. data/ext/v8/upstream/2.0.6/tools/test.py +1370 -0
  897. data/ext/v8/upstream/2.0.6/tools/tickprocessor-driver.js +53 -0
  898. data/ext/v8/upstream/2.0.6/tools/tickprocessor.js +731 -0
  899. data/ext/v8/upstream/2.0.6/tools/tickprocessor.py +535 -0
  900. data/ext/v8/upstream/2.0.6/tools/utils.py +82 -0
  901. data/ext/v8/upstream/2.0.6/tools/utils.pyc +0 -0
  902. data/ext/v8/upstream/2.0.6/tools/visual_studio/README.txt +71 -0
  903. data/ext/v8/upstream/2.0.6/tools/visual_studio/arm.vsprops +14 -0
  904. data/ext/v8/upstream/2.0.6/tools/visual_studio/common.vsprops +35 -0
  905. data/ext/v8/upstream/2.0.6/tools/visual_studio/d8.vcproj +199 -0
  906. data/ext/v8/upstream/2.0.6/tools/visual_studio/d8_arm.vcproj +199 -0
  907. data/ext/v8/upstream/2.0.6/tools/visual_studio/d8_x64.vcproj +201 -0
  908. data/ext/v8/upstream/2.0.6/tools/visual_studio/d8js2c.cmd +6 -0
  909. data/ext/v8/upstream/2.0.6/tools/visual_studio/debug.vsprops +17 -0
  910. data/ext/v8/upstream/2.0.6/tools/visual_studio/ia32.vsprops +13 -0
  911. data/ext/v8/upstream/2.0.6/tools/visual_studio/js2c.cmd +6 -0
  912. data/ext/v8/upstream/2.0.6/tools/visual_studio/release.vsprops +24 -0
  913. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8.sln +101 -0
  914. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8.vcproj +223 -0
  915. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_arm.sln +74 -0
  916. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_arm.vcproj +223 -0
  917. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base.vcproj +971 -0
  918. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base_arm.vcproj +983 -0
  919. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base_x64.vcproj +959 -0
  920. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest.vcproj +255 -0
  921. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest_arm.vcproj +243 -0
  922. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest_x64.vcproj +257 -0
  923. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_mksnapshot.vcproj +151 -0
  924. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_mksnapshot_x64.vcproj +151 -0
  925. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample.vcproj +151 -0
  926. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample_arm.vcproj +151 -0
  927. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample_x64.vcproj +151 -0
  928. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample.vcproj +151 -0
  929. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample_arm.vcproj +151 -0
  930. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample_x64.vcproj +153 -0
  931. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot.vcproj +142 -0
  932. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_cc.vcproj +92 -0
  933. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_cc_x64.vcproj +92 -0
  934. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_x64.vcproj +142 -0
  935. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_x64.sln +101 -0
  936. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_x64.vcproj +223 -0
  937. data/ext/v8/upstream/2.0.6/tools/visual_studio/x64.vsprops +13 -0
  938. data/ext/v8/upstream/2.0.6/tools/windows-tick-processor.bat +5 -0
  939. data/ext/v8/upstream/2.0.6/tools/windows-tick-processor.py +137 -0
  940. data/ext/v8/upstream/scons/CHANGES.txt +5183 -0
  941. data/ext/v8/upstream/scons/LICENSE.txt +20 -0
  942. data/ext/v8/upstream/scons/MANIFEST +202 -0
  943. data/ext/v8/upstream/scons/PKG-INFO +13 -0
  944. data/ext/v8/upstream/scons/README.txt +273 -0
  945. data/ext/v8/upstream/scons/RELEASE.txt +1040 -0
  946. data/ext/v8/upstream/scons/engine/SCons/Action.py +1256 -0
  947. data/ext/v8/upstream/scons/engine/SCons/Builder.py +868 -0
  948. data/ext/v8/upstream/scons/engine/SCons/CacheDir.py +217 -0
  949. data/ext/v8/upstream/scons/engine/SCons/Conftest.py +794 -0
  950. data/ext/v8/upstream/scons/engine/SCons/Debug.py +237 -0
  951. data/ext/v8/upstream/scons/engine/SCons/Defaults.py +485 -0
  952. data/ext/v8/upstream/scons/engine/SCons/Environment.py +2327 -0
  953. data/ext/v8/upstream/scons/engine/SCons/Errors.py +207 -0
  954. data/ext/v8/upstream/scons/engine/SCons/Executor.py +636 -0
  955. data/ext/v8/upstream/scons/engine/SCons/Job.py +435 -0
  956. data/ext/v8/upstream/scons/engine/SCons/Memoize.py +292 -0
  957. data/ext/v8/upstream/scons/engine/SCons/Node/Alias.py +153 -0
  958. data/ext/v8/upstream/scons/engine/SCons/Node/FS.py +3220 -0
  959. data/ext/v8/upstream/scons/engine/SCons/Node/Python.py +128 -0
  960. data/ext/v8/upstream/scons/engine/SCons/Node/__init__.py +1341 -0
  961. data/ext/v8/upstream/scons/engine/SCons/Options/BoolOption.py +50 -0
  962. data/ext/v8/upstream/scons/engine/SCons/Options/EnumOption.py +50 -0
  963. data/ext/v8/upstream/scons/engine/SCons/Options/ListOption.py +50 -0
  964. data/ext/v8/upstream/scons/engine/SCons/Options/PackageOption.py +50 -0
  965. data/ext/v8/upstream/scons/engine/SCons/Options/PathOption.py +76 -0
  966. data/ext/v8/upstream/scons/engine/SCons/Options/__init__.py +74 -0
  967. data/ext/v8/upstream/scons/engine/SCons/PathList.py +232 -0
  968. data/ext/v8/upstream/scons/engine/SCons/Platform/__init__.py +236 -0
  969. data/ext/v8/upstream/scons/engine/SCons/Platform/aix.py +70 -0
  970. data/ext/v8/upstream/scons/engine/SCons/Platform/cygwin.py +55 -0
  971. data/ext/v8/upstream/scons/engine/SCons/Platform/darwin.py +46 -0
  972. data/ext/v8/upstream/scons/engine/SCons/Platform/hpux.py +46 -0
  973. data/ext/v8/upstream/scons/engine/SCons/Platform/irix.py +44 -0
  974. data/ext/v8/upstream/scons/engine/SCons/Platform/os2.py +58 -0
  975. data/ext/v8/upstream/scons/engine/SCons/Platform/posix.py +264 -0
  976. data/ext/v8/upstream/scons/engine/SCons/Platform/sunos.py +50 -0
  977. data/ext/v8/upstream/scons/engine/SCons/Platform/win32.py +386 -0
  978. data/ext/v8/upstream/scons/engine/SCons/SConf.py +1038 -0
  979. data/ext/v8/upstream/scons/engine/SCons/SConsign.py +381 -0
  980. data/ext/v8/upstream/scons/engine/SCons/Scanner/C.py +132 -0
  981. data/ext/v8/upstream/scons/engine/SCons/Scanner/D.py +74 -0
  982. data/ext/v8/upstream/scons/engine/SCons/Scanner/Dir.py +111 -0
  983. data/ext/v8/upstream/scons/engine/SCons/Scanner/Fortran.py +320 -0
  984. data/ext/v8/upstream/scons/engine/SCons/Scanner/IDL.py +48 -0
  985. data/ext/v8/upstream/scons/engine/SCons/Scanner/LaTeX.py +378 -0
  986. data/ext/v8/upstream/scons/engine/SCons/Scanner/Prog.py +103 -0
  987. data/ext/v8/upstream/scons/engine/SCons/Scanner/RC.py +55 -0
  988. data/ext/v8/upstream/scons/engine/SCons/Scanner/__init__.py +415 -0
  989. data/ext/v8/upstream/scons/engine/SCons/Script/Interactive.py +386 -0
  990. data/ext/v8/upstream/scons/engine/SCons/Script/Main.py +1360 -0
  991. data/ext/v8/upstream/scons/engine/SCons/Script/SConsOptions.py +944 -0
  992. data/ext/v8/upstream/scons/engine/SCons/Script/SConscript.py +642 -0
  993. data/ext/v8/upstream/scons/engine/SCons/Script/__init__.py +414 -0
  994. data/ext/v8/upstream/scons/engine/SCons/Sig.py +63 -0
  995. data/ext/v8/upstream/scons/engine/SCons/Subst.py +911 -0
  996. data/ext/v8/upstream/scons/engine/SCons/Taskmaster.py +1030 -0
  997. data/ext/v8/upstream/scons/engine/SCons/Tool/386asm.py +61 -0
  998. data/ext/v8/upstream/scons/engine/SCons/Tool/BitKeeper.py +65 -0
  999. data/ext/v8/upstream/scons/engine/SCons/Tool/CVS.py +73 -0
  1000. data/ext/v8/upstream/scons/engine/SCons/Tool/FortranCommon.py +247 -0
  1001. data/ext/v8/upstream/scons/engine/SCons/Tool/JavaCommon.py +324 -0
  1002. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/__init__.py +56 -0
  1003. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/arch.py +61 -0
  1004. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/common.py +210 -0
  1005. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/netframework.py +84 -0
  1006. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/sdk.py +321 -0
  1007. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/vc.py +367 -0
  1008. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/vs.py +497 -0
  1009. data/ext/v8/upstream/scons/engine/SCons/Tool/Perforce.py +104 -0
  1010. data/ext/v8/upstream/scons/engine/SCons/Tool/PharLapCommon.py +138 -0
  1011. data/ext/v8/upstream/scons/engine/SCons/Tool/RCS.py +64 -0
  1012. data/ext/v8/upstream/scons/engine/SCons/Tool/SCCS.py +64 -0
  1013. data/ext/v8/upstream/scons/engine/SCons/Tool/Subversion.py +71 -0
  1014. data/ext/v8/upstream/scons/engine/SCons/Tool/__init__.py +675 -0
  1015. data/ext/v8/upstream/scons/engine/SCons/Tool/aixc++.py +82 -0
  1016. data/ext/v8/upstream/scons/engine/SCons/Tool/aixcc.py +74 -0
  1017. data/ext/v8/upstream/scons/engine/SCons/Tool/aixf77.py +80 -0
  1018. data/ext/v8/upstream/scons/engine/SCons/Tool/aixlink.py +76 -0
  1019. data/ext/v8/upstream/scons/engine/SCons/Tool/applelink.py +71 -0
  1020. data/ext/v8/upstream/scons/engine/SCons/Tool/ar.py +63 -0
  1021. data/ext/v8/upstream/scons/engine/SCons/Tool/as.py +78 -0
  1022. data/ext/v8/upstream/scons/engine/SCons/Tool/bcc32.py +82 -0
  1023. data/ext/v8/upstream/scons/engine/SCons/Tool/c++.py +99 -0
  1024. data/ext/v8/upstream/scons/engine/SCons/Tool/cc.py +114 -0
  1025. data/ext/v8/upstream/scons/engine/SCons/Tool/cvf.py +58 -0
  1026. data/ext/v8/upstream/scons/engine/SCons/Tool/default.py +50 -0
  1027. data/ext/v8/upstream/scons/engine/SCons/Tool/dmd.py +224 -0
  1028. data/ext/v8/upstream/scons/engine/SCons/Tool/dvi.py +64 -0
  1029. data/ext/v8/upstream/scons/engine/SCons/Tool/dvipdf.py +125 -0
  1030. data/ext/v8/upstream/scons/engine/SCons/Tool/dvips.py +94 -0
  1031. data/ext/v8/upstream/scons/engine/SCons/Tool/f77.py +62 -0
  1032. data/ext/v8/upstream/scons/engine/SCons/Tool/f90.py +62 -0
  1033. data/ext/v8/upstream/scons/engine/SCons/Tool/f95.py +63 -0
  1034. data/ext/v8/upstream/scons/engine/SCons/Tool/filesystem.py +98 -0
  1035. data/ext/v8/upstream/scons/engine/SCons/Tool/fortran.py +63 -0
  1036. data/ext/v8/upstream/scons/engine/SCons/Tool/g++.py +90 -0
  1037. data/ext/v8/upstream/scons/engine/SCons/Tool/g77.py +73 -0
  1038. data/ext/v8/upstream/scons/engine/SCons/Tool/gas.py +53 -0
  1039. data/ext/v8/upstream/scons/engine/SCons/Tool/gcc.py +80 -0
  1040. data/ext/v8/upstream/scons/engine/SCons/Tool/gfortran.py +64 -0
  1041. data/ext/v8/upstream/scons/engine/SCons/Tool/gnulink.py +63 -0
  1042. data/ext/v8/upstream/scons/engine/SCons/Tool/gs.py +81 -0
  1043. data/ext/v8/upstream/scons/engine/SCons/Tool/hpc++.py +85 -0
  1044. data/ext/v8/upstream/scons/engine/SCons/Tool/hpcc.py +53 -0
  1045. data/ext/v8/upstream/scons/engine/SCons/Tool/hplink.py +77 -0
  1046. data/ext/v8/upstream/scons/engine/SCons/Tool/icc.py +59 -0
  1047. data/ext/v8/upstream/scons/engine/SCons/Tool/icl.py +52 -0
  1048. data/ext/v8/upstream/scons/engine/SCons/Tool/ifl.py +72 -0
  1049. data/ext/v8/upstream/scons/engine/SCons/Tool/ifort.py +90 -0
  1050. data/ext/v8/upstream/scons/engine/SCons/Tool/ilink.py +59 -0
  1051. data/ext/v8/upstream/scons/engine/SCons/Tool/ilink32.py +60 -0
  1052. data/ext/v8/upstream/scons/engine/SCons/Tool/install.py +229 -0
  1053. data/ext/v8/upstream/scons/engine/SCons/Tool/intelc.py +490 -0
  1054. data/ext/v8/upstream/scons/engine/SCons/Tool/ipkg.py +71 -0
  1055. data/ext/v8/upstream/scons/engine/SCons/Tool/jar.py +110 -0
  1056. data/ext/v8/upstream/scons/engine/SCons/Tool/javac.py +234 -0
  1057. data/ext/v8/upstream/scons/engine/SCons/Tool/javah.py +138 -0
  1058. data/ext/v8/upstream/scons/engine/SCons/Tool/latex.py +79 -0
  1059. data/ext/v8/upstream/scons/engine/SCons/Tool/lex.py +99 -0
  1060. data/ext/v8/upstream/scons/engine/SCons/Tool/link.py +121 -0
  1061. data/ext/v8/upstream/scons/engine/SCons/Tool/linkloc.py +112 -0
  1062. data/ext/v8/upstream/scons/engine/SCons/Tool/m4.py +63 -0
  1063. data/ext/v8/upstream/scons/engine/SCons/Tool/masm.py +77 -0
  1064. data/ext/v8/upstream/scons/engine/SCons/Tool/midl.py +90 -0
  1065. data/ext/v8/upstream/scons/engine/SCons/Tool/mingw.py +159 -0
  1066. data/ext/v8/upstream/scons/engine/SCons/Tool/mslib.py +64 -0
  1067. data/ext/v8/upstream/scons/engine/SCons/Tool/mslink.py +266 -0
  1068. data/ext/v8/upstream/scons/engine/SCons/Tool/mssdk.py +50 -0
  1069. data/ext/v8/upstream/scons/engine/SCons/Tool/msvc.py +269 -0
  1070. data/ext/v8/upstream/scons/engine/SCons/Tool/msvs.py +1439 -0
  1071. data/ext/v8/upstream/scons/engine/SCons/Tool/mwcc.py +208 -0
  1072. data/ext/v8/upstream/scons/engine/SCons/Tool/mwld.py +107 -0
  1073. data/ext/v8/upstream/scons/engine/SCons/Tool/nasm.py +72 -0
  1074. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/__init__.py +314 -0
  1075. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/ipk.py +185 -0
  1076. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/msi.py +526 -0
  1077. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/rpm.py +367 -0
  1078. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_tarbz2.py +43 -0
  1079. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_targz.py +43 -0
  1080. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_zip.py +43 -0
  1081. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/tarbz2.py +44 -0
  1082. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/targz.py +44 -0
  1083. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/zip.py +44 -0
  1084. data/ext/v8/upstream/scons/engine/SCons/Tool/pdf.py +78 -0
  1085. data/ext/v8/upstream/scons/engine/SCons/Tool/pdflatex.py +83 -0
  1086. data/ext/v8/upstream/scons/engine/SCons/Tool/pdftex.py +108 -0
  1087. data/ext/v8/upstream/scons/engine/SCons/Tool/qt.py +336 -0
  1088. data/ext/v8/upstream/scons/engine/SCons/Tool/rmic.py +121 -0
  1089. data/ext/v8/upstream/scons/engine/SCons/Tool/rpcgen.py +70 -0
  1090. data/ext/v8/upstream/scons/engine/SCons/Tool/rpm.py +132 -0
  1091. data/ext/v8/upstream/scons/engine/SCons/Tool/sgiar.py +68 -0
  1092. data/ext/v8/upstream/scons/engine/SCons/Tool/sgic++.py +58 -0
  1093. data/ext/v8/upstream/scons/engine/SCons/Tool/sgicc.py +53 -0
  1094. data/ext/v8/upstream/scons/engine/SCons/Tool/sgilink.py +63 -0
  1095. data/ext/v8/upstream/scons/engine/SCons/Tool/sunar.py +67 -0
  1096. data/ext/v8/upstream/scons/engine/SCons/Tool/sunc++.py +142 -0
  1097. data/ext/v8/upstream/scons/engine/SCons/Tool/suncc.py +58 -0
  1098. data/ext/v8/upstream/scons/engine/SCons/Tool/sunf77.py +63 -0
  1099. data/ext/v8/upstream/scons/engine/SCons/Tool/sunf90.py +64 -0
  1100. data/ext/v8/upstream/scons/engine/SCons/Tool/sunf95.py +64 -0
  1101. data/ext/v8/upstream/scons/engine/SCons/Tool/sunlink.py +77 -0
  1102. data/ext/v8/upstream/scons/engine/SCons/Tool/swig.py +186 -0
  1103. data/ext/v8/upstream/scons/engine/SCons/Tool/tar.py +73 -0
  1104. data/ext/v8/upstream/scons/engine/SCons/Tool/tex.py +805 -0
  1105. data/ext/v8/upstream/scons/engine/SCons/Tool/textfile.py +175 -0
  1106. data/ext/v8/upstream/scons/engine/SCons/Tool/tlib.py +53 -0
  1107. data/ext/v8/upstream/scons/engine/SCons/Tool/wix.py +100 -0
  1108. data/ext/v8/upstream/scons/engine/SCons/Tool/yacc.py +131 -0
  1109. data/ext/v8/upstream/scons/engine/SCons/Tool/zip.py +100 -0
  1110. data/ext/v8/upstream/scons/engine/SCons/Util.py +1645 -0
  1111. data/ext/v8/upstream/scons/engine/SCons/Variables/BoolVariable.py +91 -0
  1112. data/ext/v8/upstream/scons/engine/SCons/Variables/EnumVariable.py +107 -0
  1113. data/ext/v8/upstream/scons/engine/SCons/Variables/ListVariable.py +139 -0
  1114. data/ext/v8/upstream/scons/engine/SCons/Variables/PackageVariable.py +109 -0
  1115. data/ext/v8/upstream/scons/engine/SCons/Variables/PathVariable.py +147 -0
  1116. data/ext/v8/upstream/scons/engine/SCons/Variables/__init__.py +317 -0
  1117. data/ext/v8/upstream/scons/engine/SCons/Warnings.py +228 -0
  1118. data/ext/v8/upstream/scons/engine/SCons/__init__.py +49 -0
  1119. data/ext/v8/upstream/scons/engine/SCons/compat/__init__.py +302 -0
  1120. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_UserString.py +98 -0
  1121. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_hashlib.py +91 -0
  1122. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_itertools.py +124 -0
  1123. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_optparse.py +1725 -0
  1124. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_sets.py +583 -0
  1125. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_sets15.py +176 -0
  1126. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_shlex.py +325 -0
  1127. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_subprocess.py +1296 -0
  1128. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_textwrap.py +382 -0
  1129. data/ext/v8/upstream/scons/engine/SCons/compat/builtins.py +187 -0
  1130. data/ext/v8/upstream/scons/engine/SCons/cpp.py +598 -0
  1131. data/ext/v8/upstream/scons/engine/SCons/dblite.py +248 -0
  1132. data/ext/v8/upstream/scons/engine/SCons/exitfuncs.py +77 -0
  1133. data/ext/v8/upstream/scons/os_spawnv_fix.diff +83 -0
  1134. data/ext/v8/upstream/scons/scons-time.1 +1017 -0
  1135. data/ext/v8/upstream/scons/scons.1 +15179 -0
  1136. data/ext/v8/upstream/scons/sconsign.1 +208 -0
  1137. data/ext/v8/upstream/scons/script/scons +184 -0
  1138. data/ext/v8/upstream/scons/script/scons-time +1529 -0
  1139. data/ext/v8/upstream/scons/script/scons.bat +31 -0
  1140. data/ext/v8/upstream/scons/script/sconsign +508 -0
  1141. data/ext/v8/upstream/scons/setup.cfg +6 -0
  1142. data/ext/v8/upstream/scons/setup.py +427 -0
  1143. data/ext/v8/v8_cxt.cpp +3 -0
  1144. data/ext/v8/v8_cxt.h +9 -0
  1145. data/lib/v8.rb +1 -1
  1146. data/spec/redjs/jsapi_spec.rb +6 -0
  1147. data/therubyracer.gemspec +4 -4
  1148. metadata +1146 -2
@@ -0,0 +1,310 @@
1
+ // Copyright 2006-2009 the V8 project authors. All rights reserved.
2
+ //
3
+ // Tests of logging utilities from log-utils.h
4
+
5
+ #ifdef ENABLE_LOGGING_AND_PROFILING
6
+
7
+ #include "v8.h"
8
+
9
+ #include "log-utils.h"
10
+ #include "cctest.h"
11
+
12
+ using v8::internal::CStrVector;
13
+ using v8::internal::EmbeddedVector;
14
+ using v8::internal::LogDynamicBuffer;
15
+ using v8::internal::LogRecordCompressor;
16
+ using v8::internal::MutableCStrVector;
17
+ using v8::internal::ScopedVector;
18
+ using v8::internal::Vector;
19
+ using v8::internal::StrLength;
20
+
21
+ // Fills 'ref_buffer' with test data: a sequence of two-digit
22
+ // hex numbers: '0001020304...'. Then writes 'ref_buffer' contents to 'dynabuf'.
23
+ static void WriteData(LogDynamicBuffer* dynabuf, Vector<char>* ref_buffer) {
24
+ static const char kHex[] = "0123456789ABCDEF";
25
+ CHECK_GT(ref_buffer->length(), 0);
26
+ CHECK_GT(513, ref_buffer->length());
27
+ for (int i = 0, half_len = ref_buffer->length() >> 1; i < half_len; ++i) {
28
+ (*ref_buffer)[i << 1] = kHex[i >> 4];
29
+ (*ref_buffer)[(i << 1) + 1] = kHex[i & 15];
30
+ }
31
+ if (ref_buffer->length() & 1) {
32
+ ref_buffer->last() = kHex[ref_buffer->length() >> 5];
33
+ }
34
+ CHECK_EQ(ref_buffer->length(),
35
+ dynabuf->Write(ref_buffer->start(), ref_buffer->length()));
36
+ }
37
+
38
+
39
+ static int ReadData(
40
+ LogDynamicBuffer* dynabuf, int start_pos, i::Vector<char>* buffer) {
41
+ return dynabuf->Read(start_pos, buffer->start(), buffer->length());
42
+ }
43
+
44
+
45
+ // Helper function used by CHECK_EQ to compare Vectors. Templatized to
46
+ // accept both "char" and "const char" vector contents.
47
+ template <typename E, typename V>
48
+ static inline void CheckEqualsHelper(const char* file, int line,
49
+ const char* expected_source,
50
+ const Vector<E>& expected,
51
+ const char* value_source,
52
+ const Vector<V>& value) {
53
+ if (expected.length() != value.length()) {
54
+ V8_Fatal(file, line, "CHECK_EQ(%s, %s) failed\n"
55
+ "# Vectors lengths differ: %d expected, %d found\n"
56
+ "# Expected: %.*s\n"
57
+ "# Found: %.*s",
58
+ expected_source, value_source,
59
+ expected.length(), value.length(),
60
+ expected.length(), expected.start(),
61
+ value.length(), value.start());
62
+ }
63
+ if (strncmp(expected.start(), value.start(), expected.length()) != 0) {
64
+ V8_Fatal(file, line, "CHECK_EQ(%s, %s) failed\n"
65
+ "# Vectors contents differ:\n"
66
+ "# Expected: %.*s\n"
67
+ "# Found: %.*s",
68
+ expected_source, value_source,
69
+ expected.length(), expected.start(),
70
+ value.length(), value.start());
71
+ }
72
+ }
73
+
74
+
75
+ TEST(DynaBufSingleBlock) {
76
+ LogDynamicBuffer dynabuf(32, 32, "", 0);
77
+ EmbeddedVector<char, 32> ref_buf;
78
+ WriteData(&dynabuf, &ref_buf);
79
+ EmbeddedVector<char, 32> buf;
80
+ CHECK_EQ(32, dynabuf.Read(0, buf.start(), buf.length()));
81
+ CHECK_EQ(32, ReadData(&dynabuf, 0, &buf));
82
+ CHECK_EQ(ref_buf, buf);
83
+
84
+ // Verify that we can't read and write past the end.
85
+ CHECK_EQ(0, dynabuf.Read(32, buf.start(), buf.length()));
86
+ CHECK_EQ(0, dynabuf.Write(buf.start(), buf.length()));
87
+ }
88
+
89
+
90
+ TEST(DynaBufCrossBlocks) {
91
+ LogDynamicBuffer dynabuf(32, 128, "", 0);
92
+ EmbeddedVector<char, 48> ref_buf;
93
+ WriteData(&dynabuf, &ref_buf);
94
+ CHECK_EQ(48, dynabuf.Write(ref_buf.start(), ref_buf.length()));
95
+ // Verify that we can't write data when remaining buffer space isn't enough.
96
+ CHECK_EQ(0, dynabuf.Write(ref_buf.start(), ref_buf.length()));
97
+ EmbeddedVector<char, 48> buf;
98
+ CHECK_EQ(48, ReadData(&dynabuf, 0, &buf));
99
+ CHECK_EQ(ref_buf, buf);
100
+ CHECK_EQ(48, ReadData(&dynabuf, 48, &buf));
101
+ CHECK_EQ(ref_buf, buf);
102
+ CHECK_EQ(0, ReadData(&dynabuf, 48 * 2, &buf));
103
+ }
104
+
105
+
106
+ TEST(DynaBufReadTruncation) {
107
+ LogDynamicBuffer dynabuf(32, 128, "", 0);
108
+ EmbeddedVector<char, 128> ref_buf;
109
+ WriteData(&dynabuf, &ref_buf);
110
+ EmbeddedVector<char, 128> buf;
111
+ CHECK_EQ(128, ReadData(&dynabuf, 0, &buf));
112
+ CHECK_EQ(ref_buf, buf);
113
+ // Try to read near the end with a buffer larger than remaining data size.
114
+ EmbeddedVector<char, 48> tail_buf;
115
+ CHECK_EQ(32, ReadData(&dynabuf, 128 - 32, &tail_buf));
116
+ CHECK_EQ(ref_buf.SubVector(128 - 32, 128), tail_buf.SubVector(0, 32));
117
+ }
118
+
119
+
120
+ TEST(DynaBufSealing) {
121
+ const char* seal = "Sealed";
122
+ const int seal_size = StrLength(seal);
123
+ LogDynamicBuffer dynabuf(32, 128, seal, seal_size);
124
+ EmbeddedVector<char, 100> ref_buf;
125
+ WriteData(&dynabuf, &ref_buf);
126
+ // Try to write data that will not fit in the buffer.
127
+ CHECK_EQ(0, dynabuf.Write(ref_buf.start(), 128 - 100 - seal_size + 1));
128
+ // Now the buffer is sealed, writing of any amount of data is forbidden.
129
+ CHECK_EQ(0, dynabuf.Write(ref_buf.start(), 1));
130
+ EmbeddedVector<char, 100> buf;
131
+ CHECK_EQ(100, ReadData(&dynabuf, 0, &buf));
132
+ CHECK_EQ(ref_buf, buf);
133
+ // Check the seal.
134
+ EmbeddedVector<char, 50> seal_buf;
135
+ CHECK_EQ(seal_size, ReadData(&dynabuf, 100, &seal_buf));
136
+ CHECK_EQ(CStrVector(seal), seal_buf.SubVector(0, seal_size));
137
+ // Verify that there's no data beyond the seal.
138
+ CHECK_EQ(0, ReadData(&dynabuf, 100 + seal_size, &buf));
139
+ }
140
+
141
+
142
+ TEST(CompressorStore) {
143
+ LogRecordCompressor comp(2);
144
+ const Vector<const char> empty = CStrVector("");
145
+ CHECK(comp.Store(empty));
146
+ CHECK(!comp.Store(empty));
147
+ CHECK(!comp.Store(empty));
148
+ const Vector<const char> aaa = CStrVector("aaa");
149
+ CHECK(comp.Store(aaa));
150
+ CHECK(!comp.Store(aaa));
151
+ CHECK(!comp.Store(aaa));
152
+ CHECK(comp.Store(empty));
153
+ CHECK(!comp.Store(empty));
154
+ CHECK(!comp.Store(empty));
155
+ }
156
+
157
+
158
+ void CheckCompression(LogRecordCompressor* comp,
159
+ const Vector<const char>& after) {
160
+ EmbeddedVector<char, 100> result;
161
+ CHECK(comp->RetrievePreviousCompressed(&result));
162
+ CHECK_EQ(after, result);
163
+ }
164
+
165
+
166
+ void CheckCompression(LogRecordCompressor* comp,
167
+ const char* after) {
168
+ CheckCompression(comp, CStrVector(after));
169
+ }
170
+
171
+
172
+ TEST(CompressorNonCompressed) {
173
+ LogRecordCompressor comp(0);
174
+ CHECK(!comp.RetrievePreviousCompressed(NULL));
175
+ const Vector<const char> empty = CStrVector("");
176
+ CHECK(comp.Store(empty));
177
+ CHECK(!comp.RetrievePreviousCompressed(NULL));
178
+ const Vector<const char> a_x_20 = CStrVector("aaaaaaaaaaaaaaaaaaaa");
179
+ CHECK(comp.Store(a_x_20));
180
+ CheckCompression(&comp, empty);
181
+ CheckCompression(&comp, empty);
182
+ CHECK(comp.Store(empty));
183
+ CheckCompression(&comp, a_x_20);
184
+ CheckCompression(&comp, a_x_20);
185
+ }
186
+
187
+
188
+ TEST(CompressorSingleLine) {
189
+ LogRecordCompressor comp(1);
190
+ const Vector<const char> string_1 = CStrVector("eee,ddd,ccc,bbb,aaa");
191
+ CHECK(comp.Store(string_1));
192
+ const Vector<const char> string_2 = CStrVector("fff,ddd,ccc,bbb,aaa");
193
+ CHECK(comp.Store(string_2));
194
+ // string_1 hasn't been compressed.
195
+ CheckCompression(&comp, string_1);
196
+ CheckCompression(&comp, string_1);
197
+ const Vector<const char> string_3 = CStrVector("hhh,ggg,ccc,bbb,aaa");
198
+ CHECK(comp.Store(string_3));
199
+ // string_2 compressed using string_1.
200
+ CheckCompression(&comp, "fff#1:3");
201
+ CheckCompression(&comp, "fff#1:3");
202
+ CHECK(!comp.Store(string_3));
203
+ // Expecting no changes.
204
+ CheckCompression(&comp, "fff#1:3");
205
+ CHECK(!comp.Store(string_3));
206
+ // Expecting no changes.
207
+ CheckCompression(&comp, "fff#1:3");
208
+ const Vector<const char> string_4 = CStrVector("iii,hhh,ggg,ccc,bbb,aaa");
209
+ CHECK(comp.Store(string_4));
210
+ // string_3 compressed using string_2.
211
+ CheckCompression(&comp, "hhh,ggg#1:7");
212
+ const Vector<const char> string_5 = CStrVector("nnn,mmm,lll,kkk,jjj");
213
+ CHECK(comp.Store(string_5));
214
+ // string_4 compressed using string_3.
215
+ CheckCompression(&comp, "iii,#1");
216
+ const Vector<const char> string_6 = CStrVector("nnn,mmmmmm,lll,kkk,jjj");
217
+ CHECK(comp.Store(string_6));
218
+ // string_5 hasn't been compressed.
219
+ CheckCompression(&comp, string_5);
220
+ CHECK(comp.Store(string_5));
221
+ // string_6 compressed using string_5.
222
+ CheckCompression(&comp, "nnn,mmm#1:4");
223
+ const Vector<const char> string_7 = CStrVector("nnnnnn,mmm,lll,kkk,jjj");
224
+ CHECK(comp.Store(string_7));
225
+ // string_5 compressed using string_6.
226
+ CheckCompression(&comp, "nnn,#1:7");
227
+ const Vector<const char> string_8 = CStrVector("xxn,mmm,lll,kkk,jjj");
228
+ CHECK(comp.Store(string_8));
229
+ // string_7 compressed using string_5.
230
+ CheckCompression(&comp, "nnn#1");
231
+ const Vector<const char> string_9 =
232
+ CStrVector("aaaaaaaaaaaaa,bbbbbbbbbbbbbbbbb");
233
+ CHECK(comp.Store(string_9));
234
+ // string_8 compressed using string_7.
235
+ CheckCompression(&comp, "xx#1:5");
236
+ const Vector<const char> string_10 =
237
+ CStrVector("aaaaaaaaaaaaa,cccccccbbbbbbbbbb");
238
+ CHECK(comp.Store(string_10));
239
+ // string_9 hasn't been compressed.
240
+ CheckCompression(&comp, string_9);
241
+ CHECK(comp.Store(string_1));
242
+ // string_10 compressed using string_9.
243
+ CheckCompression(&comp, "aaaaaaaaaaaaa,ccccccc#1:21");
244
+ }
245
+
246
+
247
+
248
+ TEST(CompressorMultiLines) {
249
+ const int kWindowSize = 3;
250
+ LogRecordCompressor comp(kWindowSize);
251
+ const Vector<const char> string_1 = CStrVector("eee,ddd,ccc,bbb,aaa");
252
+ CHECK(comp.Store(string_1));
253
+ const Vector<const char> string_2 = CStrVector("iii,hhh,ggg,fff,aaa");
254
+ CHECK(comp.Store(string_2));
255
+ const Vector<const char> string_3 = CStrVector("mmm,lll,kkk,jjj,aaa");
256
+ CHECK(comp.Store(string_3));
257
+ const Vector<const char> string_4 = CStrVector("nnn,hhh,ggg,fff,aaa");
258
+ CHECK(comp.Store(string_4));
259
+ const Vector<const char> string_5 = CStrVector("ooo,lll,kkk,jjj,aaa");
260
+ CHECK(comp.Store(string_5));
261
+ // string_4 compressed using string_2.
262
+ CheckCompression(&comp, "nnn#2:3");
263
+ CHECK(comp.Store(string_1));
264
+ // string_5 compressed using string_3.
265
+ CheckCompression(&comp, "ooo#2:3");
266
+ CHECK(comp.Store(string_4));
267
+ // string_1 is out of buffer by now, so it shouldn't be compressed.
268
+ CHECK_GE(3, kWindowSize);
269
+ CheckCompression(&comp, string_1);
270
+ CHECK(comp.Store(string_2));
271
+ // string_4 compressed using itself.
272
+ CheckCompression(&comp, "#3");
273
+ }
274
+
275
+
276
+ TEST(CompressorBestSelection) {
277
+ LogRecordCompressor comp(3);
278
+ const Vector<const char> string_1 = CStrVector("eee,ddd,ccc,bbb,aaa");
279
+ CHECK(comp.Store(string_1));
280
+ const Vector<const char> string_2 = CStrVector("ddd,ccc,bbb,aaa");
281
+ CHECK(comp.Store(string_2));
282
+ const Vector<const char> string_3 = CStrVector("fff,eee,ddd,ccc,bbb,aaa");
283
+ CHECK(comp.Store(string_3));
284
+ // string_2 compressed using string_1.
285
+ CheckCompression(&comp, "#1:4");
286
+ const Vector<const char> string_4 = CStrVector("nnn,hhh,ggg,fff,aaa");
287
+ CHECK(comp.Store(string_4));
288
+ // Compressing string_3 using string_1 gives a better compression than
289
+ // using string_2.
290
+ CheckCompression(&comp, "fff,#2");
291
+ }
292
+
293
+
294
+ TEST(CompressorCompressibility) {
295
+ LogRecordCompressor comp(2);
296
+ const Vector<const char> string_1 = CStrVector("eee,ddd,ccc,bbb,aaa");
297
+ CHECK(comp.Store(string_1));
298
+ const Vector<const char> string_2 = CStrVector("ccc,bbb,aaa");
299
+ CHECK(comp.Store(string_2));
300
+ const Vector<const char> string_3 = CStrVector("aaa");
301
+ CHECK(comp.Store(string_3));
302
+ // string_2 compressed using string_1.
303
+ CheckCompression(&comp, "#1:8");
304
+ const Vector<const char> string_4 = CStrVector("xxx");
305
+ CHECK(comp.Store(string_4));
306
+ // string_3 can't be compressed using string_2 --- too short.
307
+ CheckCompression(&comp, string_3);
308
+ }
309
+
310
+ #endif // ENABLE_LOGGING_AND_PROFILING
@@ -0,0 +1,1081 @@
1
+ // Copyright 2006-2009 the V8 project authors. All rights reserved.
2
+ //
3
+ // Tests of logging functions from log.h
4
+
5
+ #ifdef ENABLE_LOGGING_AND_PROFILING
6
+
7
+ #ifdef __linux__
8
+ #include <math.h>
9
+ #include <pthread.h>
10
+ #include <signal.h>
11
+ #include <unistd.h>
12
+ #endif // __linux__
13
+
14
+ #include "v8.h"
15
+ #include "log.h"
16
+ #include "v8threads.h"
17
+ #include "cctest.h"
18
+
19
+ using v8::internal::Address;
20
+ using v8::internal::EmbeddedVector;
21
+ using v8::internal::Logger;
22
+ using v8::internal::StrLength;
23
+
24
+ namespace i = v8::internal;
25
+
26
+ static void SetUp() {
27
+ // Log to memory buffer.
28
+ i::FLAG_logfile = "*";
29
+ i::FLAG_log = true;
30
+ Logger::Setup();
31
+ }
32
+
33
+ static void TearDown() {
34
+ Logger::TearDown();
35
+ }
36
+
37
+
38
+ TEST(EmptyLog) {
39
+ SetUp();
40
+ CHECK_EQ(0, Logger::GetLogLines(0, NULL, 0));
41
+ CHECK_EQ(0, Logger::GetLogLines(100, NULL, 0));
42
+ CHECK_EQ(0, Logger::GetLogLines(0, NULL, 100));
43
+ CHECK_EQ(0, Logger::GetLogLines(100, NULL, 100));
44
+ TearDown();
45
+ }
46
+
47
+
48
+ TEST(GetMessages) {
49
+ SetUp();
50
+ Logger::StringEvent("aaa", "bbb");
51
+ Logger::StringEvent("cccc", "dddd");
52
+ CHECK_EQ(0, Logger::GetLogLines(0, NULL, 0));
53
+ char log_lines[100];
54
+ memset(log_lines, 0, sizeof(log_lines));
55
+ // Requesting data size which is smaller than first log message length.
56
+ CHECK_EQ(0, Logger::GetLogLines(0, log_lines, 3));
57
+ // See Logger::StringEvent.
58
+ const char* line_1 = "aaa,\"bbb\"\n";
59
+ const int line_1_len = StrLength(line_1);
60
+ // Still smaller than log message length.
61
+ CHECK_EQ(0, Logger::GetLogLines(0, log_lines, line_1_len - 1));
62
+ // The exact size.
63
+ CHECK_EQ(line_1_len, Logger::GetLogLines(0, log_lines, line_1_len));
64
+ CHECK_EQ(line_1, log_lines);
65
+ memset(log_lines, 0, sizeof(log_lines));
66
+ // A bit more than the first line length.
67
+ CHECK_EQ(line_1_len, Logger::GetLogLines(0, log_lines, line_1_len + 3));
68
+ log_lines[line_1_len] = '\0';
69
+ CHECK_EQ(line_1, log_lines);
70
+ memset(log_lines, 0, sizeof(log_lines));
71
+ const char* line_2 = "cccc,\"dddd\"\n";
72
+ const int line_2_len = StrLength(line_2);
73
+ // Now start with line_2 beginning.
74
+ CHECK_EQ(0, Logger::GetLogLines(line_1_len, log_lines, 0));
75
+ CHECK_EQ(0, Logger::GetLogLines(line_1_len, log_lines, 3));
76
+ CHECK_EQ(0, Logger::GetLogLines(line_1_len, log_lines, line_2_len - 1));
77
+ CHECK_EQ(line_2_len, Logger::GetLogLines(line_1_len, log_lines, line_2_len));
78
+ CHECK_EQ(line_2, log_lines);
79
+ memset(log_lines, 0, sizeof(log_lines));
80
+ CHECK_EQ(line_2_len,
81
+ Logger::GetLogLines(line_1_len, log_lines, line_2_len + 3));
82
+ CHECK_EQ(line_2, log_lines);
83
+ memset(log_lines, 0, sizeof(log_lines));
84
+ // Now get entire buffer contents.
85
+ const char* all_lines = "aaa,\"bbb\"\ncccc,\"dddd\"\n";
86
+ const int all_lines_len = StrLength(all_lines);
87
+ CHECK_EQ(all_lines_len, Logger::GetLogLines(0, log_lines, all_lines_len));
88
+ CHECK_EQ(all_lines, log_lines);
89
+ memset(log_lines, 0, sizeof(log_lines));
90
+ CHECK_EQ(all_lines_len, Logger::GetLogLines(0, log_lines, all_lines_len + 3));
91
+ CHECK_EQ(all_lines, log_lines);
92
+ memset(log_lines, 0, sizeof(log_lines));
93
+ TearDown();
94
+ }
95
+
96
+
97
+ static int GetLogLines(int start_pos, i::Vector<char>* buffer) {
98
+ return Logger::GetLogLines(start_pos, buffer->start(), buffer->length());
99
+ }
100
+
101
+
102
+ TEST(BeyondWritePosition) {
103
+ SetUp();
104
+ Logger::StringEvent("aaa", "bbb");
105
+ Logger::StringEvent("cccc", "dddd");
106
+ // See Logger::StringEvent.
107
+ const char* all_lines = "aaa,\"bbb\"\ncccc,\"dddd\"\n";
108
+ const int all_lines_len = StrLength(all_lines);
109
+ EmbeddedVector<char, 100> buffer;
110
+ const int beyond_write_pos = all_lines_len;
111
+ CHECK_EQ(0, Logger::GetLogLines(beyond_write_pos, buffer.start(), 1));
112
+ CHECK_EQ(0, GetLogLines(beyond_write_pos, &buffer));
113
+ CHECK_EQ(0, Logger::GetLogLines(beyond_write_pos + 1, buffer.start(), 1));
114
+ CHECK_EQ(0, GetLogLines(beyond_write_pos + 1, &buffer));
115
+ CHECK_EQ(0, Logger::GetLogLines(beyond_write_pos + 100, buffer.start(), 1));
116
+ CHECK_EQ(0, GetLogLines(beyond_write_pos + 100, &buffer));
117
+ CHECK_EQ(0, Logger::GetLogLines(10 * 1024 * 1024, buffer.start(), 1));
118
+ CHECK_EQ(0, GetLogLines(10 * 1024 * 1024, &buffer));
119
+ TearDown();
120
+ }
121
+
122
+
123
+ TEST(MemoryLoggingTurnedOff) {
124
+ // Log to stdout
125
+ i::FLAG_logfile = "-";
126
+ i::FLAG_log = true;
127
+ Logger::Setup();
128
+ CHECK_EQ(0, Logger::GetLogLines(0, NULL, 0));
129
+ CHECK_EQ(0, Logger::GetLogLines(100, NULL, 0));
130
+ CHECK_EQ(0, Logger::GetLogLines(0, NULL, 100));
131
+ CHECK_EQ(0, Logger::GetLogLines(100, NULL, 100));
132
+ Logger::TearDown();
133
+ }
134
+
135
+
136
+ static void CompileAndRunScript(const char *src) {
137
+ v8::Script::Compile(v8::String::New(src))->Run();
138
+ }
139
+
140
+
141
+ namespace v8 {
142
+ namespace internal {
143
+
144
+ class LoggerTestHelper : public AllStatic {
145
+ public:
146
+ static bool IsSamplerActive() { return Logger::IsProfilerSamplerActive(); }
147
+ };
148
+
149
+ } // namespace v8::internal
150
+ } // namespace v8
151
+
152
+ using v8::internal::LoggerTestHelper;
153
+
154
+
155
+ // Under Linux, we need to check if signals were delivered to avoid false
156
+ // positives. Under other platforms profiling is done via a high-priority
157
+ // thread, so this case never happen.
158
+ static bool was_sigprof_received = true;
159
+ #ifdef __linux__
160
+
161
+ struct sigaction old_sigprof_handler;
162
+ pthread_t our_thread;
163
+
164
+ static void SigProfSignalHandler(int signal, siginfo_t* info, void* context) {
165
+ if (signal != SIGPROF || !pthread_equal(pthread_self(), our_thread)) return;
166
+ was_sigprof_received = true;
167
+ old_sigprof_handler.sa_sigaction(signal, info, context);
168
+ }
169
+
170
+ #endif // __linux__
171
+
172
+
173
+ static int CheckThatProfilerWorks(int log_pos) {
174
+ Logger::ResumeProfiler(v8::PROFILER_MODULE_CPU);
175
+ CHECK(LoggerTestHelper::IsSamplerActive());
176
+
177
+ // Verify that the current map of compiled functions has been logged.
178
+ EmbeddedVector<char, 102400> buffer;
179
+ int map_log_size = GetLogLines(log_pos, &buffer);
180
+ printf("map_log_size: %d\n", map_log_size);
181
+ CHECK_GT(map_log_size, 0);
182
+ CHECK_GT(buffer.length(), map_log_size);
183
+ log_pos += map_log_size;
184
+ // Check buffer contents.
185
+ buffer[map_log_size] = '\0';
186
+ const char* code_creation = "\ncode-creation,"; // eq. to /^code-creation,/
187
+ CHECK_NE(NULL, strstr(buffer.start(), code_creation));
188
+
189
+ #ifdef __linux__
190
+ // Intercept SIGPROF handler to make sure that the test process
191
+ // had received it. Under load, system can defer it causing test failure.
192
+ // It is important to execute this after 'ResumeProfiler'.
193
+ our_thread = pthread_self();
194
+ was_sigprof_received = false;
195
+ struct sigaction sa;
196
+ sa.sa_sigaction = SigProfSignalHandler;
197
+ sigemptyset(&sa.sa_mask);
198
+ sa.sa_flags = SA_SIGINFO;
199
+ CHECK_EQ(0, sigaction(SIGPROF, &sa, &old_sigprof_handler));
200
+ #endif // __linux__
201
+
202
+ // Force compiler to generate new code by parametrizing source.
203
+ EmbeddedVector<char, 100> script_src;
204
+ i::OS::SNPrintF(script_src,
205
+ "for (var i = 0; i < 1000; ++i) { "
206
+ "(function(x) { return %d * x; })(i); }",
207
+ log_pos);
208
+ // Run code for 200 msecs to get some ticks.
209
+ const double end_time = i::OS::TimeCurrentMillis() + 200;
210
+ while (i::OS::TimeCurrentMillis() < end_time) {
211
+ CompileAndRunScript(script_src.start());
212
+ // Yield CPU to give Profiler thread a chance to process ticks.
213
+ i::OS::Sleep(1);
214
+ }
215
+
216
+ Logger::PauseProfiler(v8::PROFILER_MODULE_CPU);
217
+ CHECK(!LoggerTestHelper::IsSamplerActive());
218
+
219
+ // Wait 50 msecs to allow Profiler thread to process the last
220
+ // tick sample it has got.
221
+ i::OS::Sleep(50);
222
+
223
+ // Now we must have compiler and tick records.
224
+ int log_size = GetLogLines(log_pos, &buffer);
225
+ printf("log_size: %d\n", log_size);
226
+ CHECK_GT(log_size, 0);
227
+ CHECK_GT(buffer.length(), log_size);
228
+ log_pos += log_size;
229
+ // Check buffer contents.
230
+ buffer[log_size] = '\0';
231
+ const char* tick = "\ntick,";
232
+ CHECK_NE(NULL, strstr(buffer.start(), code_creation));
233
+ const bool ticks_found = strstr(buffer.start(), tick) != NULL;
234
+ CHECK_EQ(was_sigprof_received, ticks_found);
235
+
236
+ return log_pos;
237
+ }
238
+
239
+
240
+ TEST(ProfLazyMode) {
241
+ const bool saved_prof_lazy = i::FLAG_prof_lazy;
242
+ const bool saved_prof = i::FLAG_prof;
243
+ const bool saved_prof_auto = i::FLAG_prof_auto;
244
+ i::FLAG_prof = true;
245
+ i::FLAG_prof_lazy = true;
246
+ i::FLAG_prof_auto = false;
247
+ i::FLAG_logfile = "*";
248
+
249
+ // If tests are being run manually, V8 will be already initialized
250
+ // by the bottom test.
251
+ const bool need_to_set_up_logger = i::V8::IsRunning();
252
+ v8::HandleScope scope;
253
+ v8::Handle<v8::Context> env = v8::Context::New();
254
+ if (need_to_set_up_logger) Logger::Setup();
255
+ env->Enter();
256
+
257
+ // No sampling should happen prior to resuming profiler.
258
+ CHECK(!LoggerTestHelper::IsSamplerActive());
259
+
260
+ EmbeddedVector<char, 102400> buffer;
261
+ // Nothing must be logged until profiling is resumed.
262
+ int log_pos = GetLogLines(0, &buffer);
263
+ CHECK_EQ(0, log_pos);
264
+
265
+ CompileAndRunScript("var a = (function(x) { return x + 1; })(10);");
266
+
267
+ // Nothing must be logged while profiling is suspended.
268
+ CHECK_EQ(0, GetLogLines(log_pos, &buffer));
269
+
270
+ log_pos = CheckThatProfilerWorks(log_pos);
271
+
272
+ CompileAndRunScript("var a = (function(x) { return x + 1; })(10);");
273
+
274
+ // No new data beyond last retrieved position.
275
+ CHECK_EQ(0, GetLogLines(log_pos, &buffer));
276
+
277
+ // Check that profiling can be resumed again.
278
+ CheckThatProfilerWorks(log_pos);
279
+
280
+ env->Exit();
281
+ Logger::TearDown();
282
+ i::FLAG_prof_lazy = saved_prof_lazy;
283
+ i::FLAG_prof = saved_prof;
284
+ i::FLAG_prof_auto = saved_prof_auto;
285
+ }
286
+
287
+
288
+ // Profiling multiple threads that use V8 is currently only available on Linux.
289
+ #ifdef __linux__
290
+
291
+ namespace {
292
+
293
+ class LoopingThread : public v8::internal::Thread {
294
+ public:
295
+ LoopingThread()
296
+ : v8::internal::Thread(),
297
+ semaphore_(v8::internal::OS::CreateSemaphore(0)),
298
+ run_(true) {
299
+ }
300
+
301
+ virtual ~LoopingThread() { delete semaphore_; }
302
+
303
+ void Run() {
304
+ self_ = pthread_self();
305
+ RunLoop();
306
+ }
307
+
308
+ void SendSigProf() { pthread_kill(self_, SIGPROF); }
309
+
310
+ void Stop() { run_ = false; }
311
+
312
+ bool WaitForRunning() { return semaphore_->Wait(1000000); }
313
+
314
+ protected:
315
+ bool IsRunning() { return run_; }
316
+
317
+ virtual void RunLoop() = 0;
318
+
319
+ void SetV8ThreadId() {
320
+ v8_thread_id_ = v8::V8::GetCurrentThreadId();
321
+ }
322
+
323
+ void SignalRunning() { semaphore_->Signal(); }
324
+
325
+ private:
326
+ v8::internal::Semaphore* semaphore_;
327
+ bool run_;
328
+ pthread_t self_;
329
+ int v8_thread_id_;
330
+ };
331
+
332
+
333
+ class LoopingJsThread : public LoopingThread {
334
+ public:
335
+ void RunLoop() {
336
+ {
337
+ v8::Locker locker;
338
+ CHECK(v8::internal::ThreadManager::HasId());
339
+ SetV8ThreadId();
340
+ }
341
+ while (IsRunning()) {
342
+ v8::Locker locker;
343
+ v8::HandleScope scope;
344
+ v8::Persistent<v8::Context> context = v8::Context::New();
345
+ v8::Context::Scope context_scope(context);
346
+ SignalRunning();
347
+ CompileAndRunScript(
348
+ "var j; for (var i=0; i<10000; ++i) { j = Math.sin(i); }");
349
+ context.Dispose();
350
+ i::OS::Sleep(1);
351
+ }
352
+ }
353
+ };
354
+
355
+
356
+ class LoopingNonJsThread : public LoopingThread {
357
+ public:
358
+ void RunLoop() {
359
+ v8::Locker locker;
360
+ v8::Unlocker unlocker;
361
+ // Now thread has V8's id, but will not run VM code.
362
+ CHECK(v8::internal::ThreadManager::HasId());
363
+ double i = 10;
364
+ SignalRunning();
365
+ while (IsRunning()) {
366
+ i = sin(i);
367
+ i::OS::Sleep(1);
368
+ }
369
+ }
370
+ };
371
+
372
+
373
+ class TestSampler : public v8::internal::Sampler {
374
+ public:
375
+ TestSampler()
376
+ : Sampler(0, true),
377
+ semaphore_(v8::internal::OS::CreateSemaphore(0)),
378
+ was_sample_stack_called_(false) {
379
+ }
380
+
381
+ ~TestSampler() { delete semaphore_; }
382
+
383
+ void SampleStack(v8::internal::TickSample*) {
384
+ was_sample_stack_called_ = true;
385
+ }
386
+
387
+ void Tick(v8::internal::TickSample*) { semaphore_->Signal(); }
388
+
389
+ bool WaitForTick() { return semaphore_->Wait(1000000); }
390
+
391
+ void Reset() { was_sample_stack_called_ = false; }
392
+
393
+ bool WasSampleStackCalled() { return was_sample_stack_called_; }
394
+
395
+ private:
396
+ v8::internal::Semaphore* semaphore_;
397
+ bool was_sample_stack_called_;
398
+ };
399
+
400
+
401
+ } // namespace
402
+
403
+ TEST(ProfMultipleThreads) {
404
+ LoopingJsThread jsThread;
405
+ jsThread.Start();
406
+ LoopingNonJsThread nonJsThread;
407
+ nonJsThread.Start();
408
+
409
+ TestSampler sampler;
410
+ sampler.Start();
411
+ CHECK(!sampler.WasSampleStackCalled());
412
+ jsThread.WaitForRunning();
413
+ jsThread.SendSigProf();
414
+ CHECK(sampler.WaitForTick());
415
+ CHECK(sampler.WasSampleStackCalled());
416
+ sampler.Reset();
417
+ CHECK(!sampler.WasSampleStackCalled());
418
+ nonJsThread.WaitForRunning();
419
+ nonJsThread.SendSigProf();
420
+ CHECK(sampler.WaitForTick());
421
+ CHECK(!sampler.WasSampleStackCalled());
422
+ sampler.Stop();
423
+
424
+ jsThread.Stop();
425
+ nonJsThread.Stop();
426
+ jsThread.Join();
427
+ nonJsThread.Join();
428
+ }
429
+
430
+ #endif // __linux__
431
+
432
+
433
+ // Test for issue http://crbug.com/23768 in Chromium.
434
+ // Heap can contain scripts with already disposed external sources.
435
+ // We need to verify that LogCompiledFunctions doesn't crash on them.
436
+ namespace {
437
+
438
+ class SimpleExternalString : public v8::String::ExternalStringResource {
439
+ public:
440
+ explicit SimpleExternalString(const char* source)
441
+ : utf_source_(StrLength(source)) {
442
+ for (int i = 0; i < utf_source_.length(); ++i)
443
+ utf_source_[i] = source[i];
444
+ }
445
+ virtual ~SimpleExternalString() {}
446
+ virtual size_t length() const { return utf_source_.length(); }
447
+ virtual const uint16_t* data() const { return utf_source_.start(); }
448
+ private:
449
+ i::ScopedVector<uint16_t> utf_source_;
450
+ };
451
+
452
+ } // namespace
453
+
454
+ TEST(Issue23768) {
455
+ v8::HandleScope scope;
456
+ v8::Handle<v8::Context> env = v8::Context::New();
457
+ env->Enter();
458
+
459
+ SimpleExternalString source_ext_str("(function ext() {})();");
460
+ v8::Local<v8::String> source = v8::String::NewExternal(&source_ext_str);
461
+ // Script needs to have a name in order to trigger InitLineEnds execution.
462
+ v8::Handle<v8::String> origin = v8::String::New("issue-23768-test");
463
+ v8::Handle<v8::Script> evil_script = v8::Script::Compile(source, origin);
464
+ CHECK(!evil_script.IsEmpty());
465
+ CHECK(!evil_script->Run().IsEmpty());
466
+ i::Handle<i::ExternalTwoByteString> i_source(
467
+ i::ExternalTwoByteString::cast(*v8::Utils::OpenHandle(*source)));
468
+ // This situation can happen if source was an external string disposed
469
+ // by its owner.
470
+ i_source->set_resource(NULL);
471
+
472
+ // Must not crash.
473
+ i::Logger::LogCompiledFunctions();
474
+ }
475
+
476
+
477
+ static v8::Handle<v8::Value> ObjMethod1(const v8::Arguments& args) {
478
+ return v8::Handle<v8::Value>();
479
+ }
480
+
481
+ TEST(LogCallbacks) {
482
+ const bool saved_prof_lazy = i::FLAG_prof_lazy;
483
+ const bool saved_prof = i::FLAG_prof;
484
+ const bool saved_prof_auto = i::FLAG_prof_auto;
485
+ i::FLAG_prof = true;
486
+ i::FLAG_prof_lazy = false;
487
+ i::FLAG_prof_auto = false;
488
+ i::FLAG_logfile = "*";
489
+
490
+ // If tests are being run manually, V8 will be already initialized
491
+ // by the bottom test.
492
+ const bool need_to_set_up_logger = i::V8::IsRunning();
493
+ v8::HandleScope scope;
494
+ v8::Handle<v8::Context> env = v8::Context::New();
495
+ if (need_to_set_up_logger) Logger::Setup();
496
+ env->Enter();
497
+
498
+ // Skip all initially logged stuff.
499
+ EmbeddedVector<char, 102400> buffer;
500
+ int log_pos = GetLogLines(0, &buffer);
501
+
502
+ v8::Persistent<v8::FunctionTemplate> obj =
503
+ v8::Persistent<v8::FunctionTemplate>::New(v8::FunctionTemplate::New());
504
+ obj->SetClassName(v8::String::New("Obj"));
505
+ v8::Handle<v8::ObjectTemplate> proto = obj->PrototypeTemplate();
506
+ v8::Local<v8::Signature> signature = v8::Signature::New(obj);
507
+ proto->Set(v8::String::New("method1"),
508
+ v8::FunctionTemplate::New(ObjMethod1,
509
+ v8::Handle<v8::Value>(),
510
+ signature),
511
+ static_cast<v8::PropertyAttribute>(v8::DontDelete));
512
+
513
+ env->Global()->Set(v8_str("Obj"), obj->GetFunction());
514
+ CompileAndRunScript("Obj.prototype.method1.toString();");
515
+
516
+ i::Logger::LogCompiledFunctions();
517
+ log_pos = GetLogLines(log_pos, &buffer);
518
+ CHECK_GT(log_pos, 0);
519
+ buffer[log_pos] = 0;
520
+
521
+ const char* callback_rec = "code-creation,Callback,";
522
+ char* pos = strstr(buffer.start(), callback_rec);
523
+ CHECK_NE(NULL, pos);
524
+ pos += strlen(callback_rec);
525
+ EmbeddedVector<char, 100> ref_data;
526
+ i::OS::SNPrintF(ref_data,
527
+ "0x%" V8PRIxPTR ",1,\"method1\"", ObjMethod1);
528
+ *(pos + strlen(ref_data.start())) = '\0';
529
+ CHECK_EQ(ref_data.start(), pos);
530
+
531
+ obj.Dispose();
532
+
533
+ env->Exit();
534
+ Logger::TearDown();
535
+ i::FLAG_prof_lazy = saved_prof_lazy;
536
+ i::FLAG_prof = saved_prof;
537
+ i::FLAG_prof_auto = saved_prof_auto;
538
+ }
539
+
540
+
541
+ static v8::Handle<v8::Value> Prop1Getter(v8::Local<v8::String> property,
542
+ const v8::AccessorInfo& info) {
543
+ return v8::Handle<v8::Value>();
544
+ }
545
+
546
+ static void Prop1Setter(v8::Local<v8::String> property,
547
+ v8::Local<v8::Value> value,
548
+ const v8::AccessorInfo& info) {
549
+ }
550
+
551
+ static v8::Handle<v8::Value> Prop2Getter(v8::Local<v8::String> property,
552
+ const v8::AccessorInfo& info) {
553
+ return v8::Handle<v8::Value>();
554
+ }
555
+
556
+ TEST(LogAccessorCallbacks) {
557
+ const bool saved_prof_lazy = i::FLAG_prof_lazy;
558
+ const bool saved_prof = i::FLAG_prof;
559
+ const bool saved_prof_auto = i::FLAG_prof_auto;
560
+ i::FLAG_prof = true;
561
+ i::FLAG_prof_lazy = false;
562
+ i::FLAG_prof_auto = false;
563
+ i::FLAG_logfile = "*";
564
+
565
+ // If tests are being run manually, V8 will be already initialized
566
+ // by the bottom test.
567
+ const bool need_to_set_up_logger = i::V8::IsRunning();
568
+ v8::HandleScope scope;
569
+ v8::Handle<v8::Context> env = v8::Context::New();
570
+ if (need_to_set_up_logger) Logger::Setup();
571
+ env->Enter();
572
+
573
+ // Skip all initially logged stuff.
574
+ EmbeddedVector<char, 102400> buffer;
575
+ int log_pos = GetLogLines(0, &buffer);
576
+
577
+ v8::Persistent<v8::FunctionTemplate> obj =
578
+ v8::Persistent<v8::FunctionTemplate>::New(v8::FunctionTemplate::New());
579
+ obj->SetClassName(v8::String::New("Obj"));
580
+ v8::Handle<v8::ObjectTemplate> inst = obj->InstanceTemplate();
581
+ inst->SetAccessor(v8::String::New("prop1"), Prop1Getter, Prop1Setter);
582
+ inst->SetAccessor(v8::String::New("prop2"), Prop2Getter);
583
+
584
+ i::Logger::LogAccessorCallbacks();
585
+ log_pos = GetLogLines(log_pos, &buffer);
586
+ CHECK_GT(log_pos, 0);
587
+ buffer[log_pos] = 0;
588
+ printf("%s", buffer.start());
589
+
590
+ EmbeddedVector<char, 100> prop1_getter_record;
591
+ i::OS::SNPrintF(prop1_getter_record,
592
+ "code-creation,Callback,0x%" V8PRIxPTR ",1,\"get prop1\"",
593
+ Prop1Getter);
594
+ CHECK_NE(NULL, strstr(buffer.start(), prop1_getter_record.start()));
595
+ EmbeddedVector<char, 100> prop1_setter_record;
596
+ i::OS::SNPrintF(prop1_setter_record,
597
+ "code-creation,Callback,0x%" V8PRIxPTR ",1,\"set prop1\"",
598
+ Prop1Setter);
599
+ CHECK_NE(NULL, strstr(buffer.start(), prop1_setter_record.start()));
600
+ EmbeddedVector<char, 100> prop2_getter_record;
601
+ i::OS::SNPrintF(prop2_getter_record,
602
+ "code-creation,Callback,0x%" V8PRIxPTR ",1,\"get prop2\"",
603
+ Prop2Getter);
604
+ CHECK_NE(NULL, strstr(buffer.start(), prop2_getter_record.start()));
605
+
606
+ obj.Dispose();
607
+
608
+ env->Exit();
609
+ Logger::TearDown();
610
+ i::FLAG_prof_lazy = saved_prof_lazy;
611
+ i::FLAG_prof = saved_prof;
612
+ i::FLAG_prof_auto = saved_prof_auto;
613
+ }
614
+
615
+
616
+ static inline bool IsStringEqualTo(const char* r, const char* s) {
617
+ return strncmp(r, s, strlen(r)) == 0;
618
+ }
619
+
620
+
621
+ static bool Consume(const char* str, char** buf) {
622
+ if (IsStringEqualTo(str, *buf)) {
623
+ *buf += strlen(str);
624
+ return true;
625
+ }
626
+ return false;
627
+ }
628
+
629
+
630
+ namespace {
631
+
632
+ // A code entity is a pointer to a position of code-creation event in buffer log
633
+ // offset to a point where entity size begins, i.e.: '255,"func"\n'. This makes
634
+ // comparing code entities pretty easy.
635
+ typedef char* CodeEntityInfo;
636
+
637
+ class Interval {
638
+ public:
639
+ Interval()
640
+ : min_addr_(reinterpret_cast<Address>(-1)),
641
+ max_addr_(reinterpret_cast<Address>(0)), next_(NULL) {}
642
+
643
+ ~Interval() { delete next_; }
644
+
645
+ size_t Length() {
646
+ size_t result = max_addr_ - min_addr_ + 1;
647
+ if (next_ != NULL) result += next_->Length();
648
+ return result;
649
+ }
650
+
651
+ void CloneFrom(Interval* src) {
652
+ while (src != NULL) {
653
+ RegisterAddress(src->min_addr_);
654
+ RegisterAddress(src->max_addr_);
655
+ src = src->next_;
656
+ }
657
+ }
658
+
659
+ bool Contains(Address addr) {
660
+ if (min_addr_ <= addr && addr <= max_addr_) {
661
+ return true;
662
+ }
663
+ if (next_ != NULL) {
664
+ return next_->Contains(addr);
665
+ } else {
666
+ return false;
667
+ }
668
+ }
669
+
670
+ size_t GetIndex(Address addr) {
671
+ if (min_addr_ <= addr && addr <= max_addr_) {
672
+ return addr - min_addr_;
673
+ }
674
+ CHECK_NE(NULL, next_);
675
+ return (max_addr_ - min_addr_ + 1) + next_->GetIndex(addr);
676
+ }
677
+
678
+ Address GetMinAddr() {
679
+ return next_ == NULL ? min_addr_ : i::Min(min_addr_, next_->GetMinAddr());
680
+ }
681
+
682
+ Address GetMaxAddr() {
683
+ return next_ == NULL ? max_addr_ : i::Max(max_addr_, next_->GetMaxAddr());
684
+ }
685
+
686
+ void RegisterAddress(Address addr) {
687
+ if (min_addr_ == reinterpret_cast<Address>(-1)
688
+ || (size_t)(addr > min_addr_ ?
689
+ addr - min_addr_ : min_addr_ - addr) < MAX_DELTA) {
690
+ if (addr < min_addr_) min_addr_ = addr;
691
+ if (addr > max_addr_) max_addr_ = addr;
692
+ } else {
693
+ if (next_ == NULL) next_ = new Interval();
694
+ next_->RegisterAddress(addr);
695
+ }
696
+ }
697
+
698
+ Address raw_min_addr() { return min_addr_; }
699
+
700
+ Address raw_max_addr() { return max_addr_; }
701
+
702
+ Interval* get_next() { return next_; }
703
+
704
+ private:
705
+ static const size_t MAX_DELTA = 0x100000;
706
+ Address min_addr_;
707
+ Address max_addr_;
708
+ Interval* next_;
709
+ };
710
+
711
+
712
+ // A structure used to return log parsing results.
713
+ class ParseLogResult {
714
+ public:
715
+ ParseLogResult()
716
+ : entities_map(NULL), entities(NULL),
717
+ max_entities(0) {}
718
+
719
+ ~ParseLogResult() {
720
+ i::DeleteArray(entities_map);
721
+ i::DeleteArray(entities);
722
+ }
723
+
724
+ void AllocateEntities() {
725
+ // Make sure that the test doesn't operate on a bogus log.
726
+ CHECK_GT(max_entities, 0);
727
+ CHECK_GT(bounds.GetMinAddr(), 0);
728
+ CHECK_GT(bounds.GetMaxAddr(), bounds.GetMinAddr());
729
+
730
+ entities = i::NewArray<CodeEntityInfo>(max_entities);
731
+ for (int i = 0; i < max_entities; ++i) {
732
+ entities[i] = NULL;
733
+ }
734
+ const size_t map_length = bounds.Length();
735
+ entities_map = i::NewArray<int>(static_cast<int>(map_length));
736
+ for (size_t i = 0; i < map_length; ++i) {
737
+ entities_map[i] = -1;
738
+ }
739
+ }
740
+
741
+ bool HasIndexForAddress(Address addr) {
742
+ return bounds.Contains(addr);
743
+ }
744
+
745
+ size_t GetIndexForAddress(Address addr) {
746
+ CHECK(HasIndexForAddress(addr));
747
+ return bounds.GetIndex(addr);
748
+ }
749
+
750
+ CodeEntityInfo GetEntity(Address addr) {
751
+ if (HasIndexForAddress(addr)) {
752
+ size_t idx = GetIndexForAddress(addr);
753
+ int item = entities_map[idx];
754
+ return item != -1 ? entities[item] : NULL;
755
+ }
756
+ return NULL;
757
+ }
758
+
759
+ void ParseAddress(char* start) {
760
+ Address addr =
761
+ reinterpret_cast<Address>(strtoul(start, NULL, 16)); // NOLINT
762
+ bounds.RegisterAddress(addr);
763
+ }
764
+
765
+ Address ConsumeAddress(char** start) {
766
+ char* end_ptr;
767
+ Address addr =
768
+ reinterpret_cast<Address>(strtoul(*start, &end_ptr, 16)); // NOLINT
769
+ CHECK(HasIndexForAddress(addr));
770
+ *start = end_ptr;
771
+ return addr;
772
+ }
773
+
774
+ Interval bounds;
775
+ // Memory map of entities start addresses.
776
+ int* entities_map;
777
+ // An array of code entities.
778
+ CodeEntityInfo* entities;
779
+ // Maximal entities count. Actual entities count can be lower,
780
+ // empty entity slots are pointing to NULL.
781
+ int max_entities;
782
+ };
783
+
784
+ } // namespace
785
+
786
+
787
+ typedef void (*ParserBlock)(char* start, char* end, ParseLogResult* result);
788
+
789
+ static void ParserCycle(
790
+ char* start, char* end, ParseLogResult* result,
791
+ ParserBlock block_creation, ParserBlock block_delete,
792
+ ParserBlock block_move) {
793
+
794
+ const char* code_creation = "code-creation,";
795
+ const char* code_delete = "code-delete,";
796
+ const char* code_move = "code-move,";
797
+
798
+ const char* lazy_compile = "LazyCompile,";
799
+ const char* script = "Script,";
800
+ const char* function = "Function,";
801
+
802
+ while (start < end) {
803
+ if (Consume(code_creation, &start)) {
804
+ if (Consume(lazy_compile, &start)
805
+ || Consume(script, &start)
806
+ || Consume(function, &start)) {
807
+ block_creation(start, end, result);
808
+ }
809
+ } else if (Consume(code_delete, &start)) {
810
+ block_delete(start, end, result);
811
+ } else if (Consume(code_move, &start)) {
812
+ block_move(start, end, result);
813
+ }
814
+ while (start < end && *start != '\n') ++start;
815
+ ++start;
816
+ }
817
+ }
818
+
819
+
820
+ static void Pass1CodeCreation(char* start, char* end, ParseLogResult* result) {
821
+ result->ParseAddress(start);
822
+ ++result->max_entities;
823
+ }
824
+
825
+
826
+ static void Pass1CodeDelete(char* start, char* end, ParseLogResult* result) {
827
+ result->ParseAddress(start);
828
+ }
829
+
830
+
831
+ static void Pass1CodeMove(char* start, char* end, ParseLogResult* result) {
832
+ result->ParseAddress(start);
833
+ // Skip old address.
834
+ while (start < end && *start != ',') ++start;
835
+ CHECK_GT(end, start);
836
+ ++start; // Skip ','.
837
+ result->ParseAddress(start);
838
+ }
839
+
840
+
841
+ static void Pass2CodeCreation(char* start, char* end, ParseLogResult* result) {
842
+ Address addr = result->ConsumeAddress(&start);
843
+ CHECK_GT(end, start);
844
+ ++start; // Skip ','.
845
+
846
+ size_t idx = result->GetIndexForAddress(addr);
847
+ result->entities_map[idx] = -1;
848
+ for (int i = 0; i < result->max_entities; ++i) {
849
+ // Find an empty slot and fill it.
850
+ if (result->entities[i] == NULL) {
851
+ result->entities[i] = start;
852
+ result->entities_map[idx] = i;
853
+ break;
854
+ }
855
+ }
856
+ // Make sure that a slot was found.
857
+ CHECK_GE(result->entities_map[idx], 0);
858
+ }
859
+
860
+
861
+ static void Pass2CodeDelete(char* start, char* end, ParseLogResult* result) {
862
+ Address addr = result->ConsumeAddress(&start);
863
+ size_t idx = result->GetIndexForAddress(addr);
864
+ // There can be code deletes that are not related to JS code.
865
+ if (result->entities_map[idx] >= 0) {
866
+ result->entities[result->entities_map[idx]] = NULL;
867
+ result->entities_map[idx] = -1;
868
+ }
869
+ }
870
+
871
+
872
+ static void Pass2CodeMove(char* start, char* end, ParseLogResult* result) {
873
+ Address from_addr = result->ConsumeAddress(&start);
874
+ CHECK_GT(end, start);
875
+ ++start; // Skip ','.
876
+ Address to_addr = result->ConsumeAddress(&start);
877
+ CHECK_GT(end, start);
878
+
879
+ size_t from_idx = result->GetIndexForAddress(from_addr);
880
+ size_t to_idx = result->GetIndexForAddress(to_addr);
881
+ // There can be code moves that are not related to JS code.
882
+ if (from_idx != to_idx && result->entities_map[from_idx] >= 0) {
883
+ CHECK_EQ(-1, result->entities_map[to_idx]);
884
+ result->entities_map[to_idx] = result->entities_map[from_idx];
885
+ result->entities_map[from_idx] = -1;
886
+ };
887
+ }
888
+
889
+
890
+ static void ParseLog(char* start, char* end, ParseLogResult* result) {
891
+ // Pass 1: Calculate boundaries of addresses and entities count.
892
+ ParserCycle(start, end, result,
893
+ Pass1CodeCreation, Pass1CodeDelete, Pass1CodeMove);
894
+
895
+ printf("min_addr: %p, max_addr: %p, entities: %d\n",
896
+ result->bounds.GetMinAddr(), result->bounds.GetMaxAddr(),
897
+ result->max_entities);
898
+
899
+ result->AllocateEntities();
900
+
901
+ // Pass 2: Fill in code entries data.
902
+ ParserCycle(start, end, result,
903
+ Pass2CodeCreation, Pass2CodeDelete, Pass2CodeMove);
904
+ }
905
+
906
+
907
+ static inline void PrintCodeEntityInfo(CodeEntityInfo entity) {
908
+ const int max_len = 50;
909
+ if (entity != NULL) {
910
+ char* eol = strchr(entity, '\n');
911
+ int len = static_cast<int>(eol - entity);
912
+ len = len <= max_len ? len : max_len;
913
+ printf("%-*.*s ", max_len, len, entity);
914
+ } else {
915
+ printf("%*s", max_len + 1, "");
916
+ }
917
+ }
918
+
919
+
920
+ static void PrintCodeEntitiesInfo(
921
+ bool is_equal, Address addr,
922
+ CodeEntityInfo l_entity, CodeEntityInfo r_entity) {
923
+ printf("%c %p ", is_equal ? ' ' : '*', addr);
924
+ PrintCodeEntityInfo(l_entity);
925
+ PrintCodeEntityInfo(r_entity);
926
+ printf("\n");
927
+ }
928
+
929
+
930
+ static inline int StrChrLen(const char* s, char c) {
931
+ return static_cast<int>(strchr(s, c) - s);
932
+ }
933
+
934
+
935
+ static bool AreFuncSizesEqual(CodeEntityInfo ref_s, CodeEntityInfo new_s) {
936
+ int ref_len = StrChrLen(ref_s, ',');
937
+ int new_len = StrChrLen(new_s, ',');
938
+ return ref_len == new_len && strncmp(ref_s, new_s, ref_len) == 0;
939
+ }
940
+
941
+
942
+ static bool AreFuncNamesEqual(CodeEntityInfo ref_s, CodeEntityInfo new_s) {
943
+ // Skip size.
944
+ ref_s = strchr(ref_s, ',') + 1;
945
+ new_s = strchr(new_s, ',') + 1;
946
+ int ref_len = StrChrLen(ref_s, '\n');
947
+ int new_len = StrChrLen(new_s, '\n');
948
+ // If reference is anonymous (""), it's OK to have anything in new.
949
+ if (ref_len == 2) return true;
950
+ // A special case for ErrorPrototype. Haven't yet figured out why they
951
+ // are different.
952
+ const char* error_prototype = "\"ErrorPrototype";
953
+ if (IsStringEqualTo(error_prototype, ref_s)
954
+ && IsStringEqualTo(error_prototype, new_s)) {
955
+ return true;
956
+ }
957
+ // Built-in objects have problems too.
958
+ const char* built_ins[] = {
959
+ "\"Boolean\"", "\"Function\"", "\"Number\"",
960
+ "\"Object\"", "\"Script\"", "\"String\""
961
+ };
962
+ for (size_t i = 0; i < sizeof(built_ins) / sizeof(*built_ins); ++i) {
963
+ if (IsStringEqualTo(built_ins[i], new_s)) {
964
+ return true;
965
+ }
966
+ }
967
+ return ref_len == new_len && strncmp(ref_s, new_s, ref_len) == 0;
968
+ }
969
+
970
+
971
+ static bool AreEntitiesEqual(CodeEntityInfo ref_e, CodeEntityInfo new_e) {
972
+ if (ref_e == NULL && new_e != NULL) return true;
973
+ if (ref_e != NULL && new_e != NULL) {
974
+ return AreFuncSizesEqual(ref_e, new_e) && AreFuncNamesEqual(ref_e, new_e);
975
+ }
976
+ if (ref_e != NULL && new_e == NULL) {
977
+ // args_count entities (argument adapters) are not found by heap traversal,
978
+ // but they are not needed because they doesn't contain any code.
979
+ ref_e = strchr(ref_e, ',') + 1;
980
+ const char* args_count = "\"args_count:";
981
+ return IsStringEqualTo(args_count, ref_e);
982
+ }
983
+ return false;
984
+ }
985
+
986
+
987
+ // Test that logging of code create / move / delete events
988
+ // is equivalent to traversal of a resulting heap.
989
+ TEST(EquivalenceOfLoggingAndTraversal) {
990
+ // This test needs to be run on a "clean" V8 to ensure that snapshot log
991
+ // is loaded. This is always true when running using tools/test.py because
992
+ // it launches a new cctest instance for every test. To be sure that launching
993
+ // cctest manually also works, please be sure that no tests below
994
+ // are using V8.
995
+ //
996
+ // P.S. No, V8 can't be re-initialized after disposal, see include/v8.h.
997
+ CHECK(!i::V8::IsRunning());
998
+
999
+ i::FLAG_logfile = "*";
1000
+ i::FLAG_log = true;
1001
+ i::FLAG_log_code = true;
1002
+
1003
+ // Make sure objects move.
1004
+ bool saved_always_compact = i::FLAG_always_compact;
1005
+ if (!i::FLAG_never_compact) {
1006
+ i::FLAG_always_compact = true;
1007
+ }
1008
+
1009
+ v8::HandleScope scope;
1010
+ v8::Handle<v8::Value> global_object = v8::Handle<v8::Value>();
1011
+ v8::Handle<v8::Context> env = v8::Context::New(
1012
+ 0, v8::Handle<v8::ObjectTemplate>(), global_object);
1013
+ env->Enter();
1014
+
1015
+ // Compile and run a function that creates other functions.
1016
+ CompileAndRunScript(
1017
+ "(function f(obj) {\n"
1018
+ " obj.test =\n"
1019
+ " (function a(j) { return function b() { return j; } })(100);\n"
1020
+ "})(this);");
1021
+ i::Heap::CollectAllGarbage(false);
1022
+
1023
+ EmbeddedVector<char, 204800> buffer;
1024
+ int log_size;
1025
+ ParseLogResult ref_result;
1026
+
1027
+ // Retrieve the log.
1028
+ {
1029
+ // Make sure that no GCs occur prior to LogCompiledFunctions call.
1030
+ i::AssertNoAllocation no_alloc;
1031
+
1032
+ log_size = GetLogLines(0, &buffer);
1033
+ CHECK_GT(log_size, 0);
1034
+ CHECK_GT(buffer.length(), log_size);
1035
+
1036
+ // Fill a map of compiled code objects.
1037
+ ParseLog(buffer.start(), buffer.start() + log_size, &ref_result);
1038
+ }
1039
+
1040
+ // Iterate heap to find compiled functions, will write to log.
1041
+ i::Logger::LogCompiledFunctions();
1042
+ char* new_log_start = buffer.start() + log_size;
1043
+ const int new_log_size = Logger::GetLogLines(
1044
+ log_size, new_log_start, buffer.length() - log_size);
1045
+ CHECK_GT(new_log_size, 0);
1046
+ CHECK_GT(buffer.length(), log_size + new_log_size);
1047
+
1048
+ // Fill an equivalent map of compiled code objects.
1049
+ ParseLogResult new_result;
1050
+ ParseLog(new_log_start, new_log_start + new_log_size, &new_result);
1051
+
1052
+ // Test their actual equivalence.
1053
+ Interval combined;
1054
+ combined.CloneFrom(&ref_result.bounds);
1055
+ combined.CloneFrom(&new_result.bounds);
1056
+ Interval* iter = &combined;
1057
+ bool results_equal = true;
1058
+
1059
+ while (iter != NULL) {
1060
+ for (Address addr = iter->raw_min_addr();
1061
+ addr <= iter->raw_max_addr(); ++addr) {
1062
+ CodeEntityInfo ref_entity = ref_result.GetEntity(addr);
1063
+ CodeEntityInfo new_entity = new_result.GetEntity(addr);
1064
+ if (ref_entity != NULL || new_entity != NULL) {
1065
+ const bool equal = AreEntitiesEqual(ref_entity, new_entity);
1066
+ if (!equal) results_equal = false;
1067
+ PrintCodeEntitiesInfo(equal, addr, ref_entity, new_entity);
1068
+ }
1069
+ }
1070
+ iter = iter->get_next();
1071
+ }
1072
+ // Make sure that all log data is written prior crash due to CHECK failure.
1073
+ fflush(stdout);
1074
+ CHECK(results_equal);
1075
+
1076
+ env->Exit();
1077
+ Logger::TearDown();
1078
+ i::FLAG_always_compact = saved_always_compact;
1079
+ }
1080
+
1081
+ #endif // ENABLE_LOGGING_AND_PROFILING