libv8-sgonyea 3.3.10

Sign up to get free protection for your applications and to get access to all the features.
Files changed (500) hide show
  1. data/.gitignore +8 -0
  2. data/.gitmodules +3 -0
  3. data/Gemfile +4 -0
  4. data/README.md +76 -0
  5. data/Rakefile +113 -0
  6. data/ext/libv8/extconf.rb +28 -0
  7. data/lib/libv8.rb +15 -0
  8. data/lib/libv8/Makefile +30 -0
  9. data/lib/libv8/detect_cpu.rb +27 -0
  10. data/lib/libv8/fpic-on-linux-amd64.patch +13 -0
  11. data/lib/libv8/v8/.gitignore +35 -0
  12. data/lib/libv8/v8/AUTHORS +44 -0
  13. data/lib/libv8/v8/ChangeLog +2839 -0
  14. data/lib/libv8/v8/LICENSE +52 -0
  15. data/lib/libv8/v8/LICENSE.strongtalk +29 -0
  16. data/lib/libv8/v8/LICENSE.v8 +26 -0
  17. data/lib/libv8/v8/LICENSE.valgrind +45 -0
  18. data/lib/libv8/v8/SConstruct +1478 -0
  19. data/lib/libv8/v8/build/README.txt +49 -0
  20. data/lib/libv8/v8/build/all.gyp +18 -0
  21. data/lib/libv8/v8/build/armu.gypi +32 -0
  22. data/lib/libv8/v8/build/common.gypi +144 -0
  23. data/lib/libv8/v8/build/gyp_v8 +145 -0
  24. data/lib/libv8/v8/include/v8-debug.h +395 -0
  25. data/lib/libv8/v8/include/v8-preparser.h +117 -0
  26. data/lib/libv8/v8/include/v8-profiler.h +505 -0
  27. data/lib/libv8/v8/include/v8-testing.h +104 -0
  28. data/lib/libv8/v8/include/v8.h +4124 -0
  29. data/lib/libv8/v8/include/v8stdint.h +53 -0
  30. data/lib/libv8/v8/preparser/SConscript +38 -0
  31. data/lib/libv8/v8/preparser/preparser-process.cc +379 -0
  32. data/lib/libv8/v8/src/SConscript +368 -0
  33. data/lib/libv8/v8/src/accessors.cc +767 -0
  34. data/lib/libv8/v8/src/accessors.h +123 -0
  35. data/lib/libv8/v8/src/allocation-inl.h +49 -0
  36. data/lib/libv8/v8/src/allocation.cc +122 -0
  37. data/lib/libv8/v8/src/allocation.h +143 -0
  38. data/lib/libv8/v8/src/api.cc +5845 -0
  39. data/lib/libv8/v8/src/api.h +574 -0
  40. data/lib/libv8/v8/src/apinatives.js +110 -0
  41. data/lib/libv8/v8/src/apiutils.h +73 -0
  42. data/lib/libv8/v8/src/arguments.h +118 -0
  43. data/lib/libv8/v8/src/arm/assembler-arm-inl.h +353 -0
  44. data/lib/libv8/v8/src/arm/assembler-arm.cc +2661 -0
  45. data/lib/libv8/v8/src/arm/assembler-arm.h +1375 -0
  46. data/lib/libv8/v8/src/arm/builtins-arm.cc +1658 -0
  47. data/lib/libv8/v8/src/arm/code-stubs-arm.cc +6398 -0
  48. data/lib/libv8/v8/src/arm/code-stubs-arm.h +673 -0
  49. data/lib/libv8/v8/src/arm/codegen-arm.cc +52 -0
  50. data/lib/libv8/v8/src/arm/codegen-arm.h +91 -0
  51. data/lib/libv8/v8/src/arm/constants-arm.cc +152 -0
  52. data/lib/libv8/v8/src/arm/constants-arm.h +775 -0
  53. data/lib/libv8/v8/src/arm/cpu-arm.cc +120 -0
  54. data/lib/libv8/v8/src/arm/debug-arm.cc +317 -0
  55. data/lib/libv8/v8/src/arm/deoptimizer-arm.cc +754 -0
  56. data/lib/libv8/v8/src/arm/disasm-arm.cc +1506 -0
  57. data/lib/libv8/v8/src/arm/frames-arm.cc +45 -0
  58. data/lib/libv8/v8/src/arm/frames-arm.h +168 -0
  59. data/lib/libv8/v8/src/arm/full-codegen-arm.cc +4375 -0
  60. data/lib/libv8/v8/src/arm/ic-arm.cc +1562 -0
  61. data/lib/libv8/v8/src/arm/lithium-arm.cc +2206 -0
  62. data/lib/libv8/v8/src/arm/lithium-arm.h +2348 -0
  63. data/lib/libv8/v8/src/arm/lithium-codegen-arm.cc +4526 -0
  64. data/lib/libv8/v8/src/arm/lithium-codegen-arm.h +403 -0
  65. data/lib/libv8/v8/src/arm/lithium-gap-resolver-arm.cc +305 -0
  66. data/lib/libv8/v8/src/arm/lithium-gap-resolver-arm.h +84 -0
  67. data/lib/libv8/v8/src/arm/macro-assembler-arm.cc +3163 -0
  68. data/lib/libv8/v8/src/arm/macro-assembler-arm.h +1126 -0
  69. data/lib/libv8/v8/src/arm/regexp-macro-assembler-arm.cc +1287 -0
  70. data/lib/libv8/v8/src/arm/regexp-macro-assembler-arm.h +253 -0
  71. data/lib/libv8/v8/src/arm/simulator-arm.cc +3424 -0
  72. data/lib/libv8/v8/src/arm/simulator-arm.h +431 -0
  73. data/lib/libv8/v8/src/arm/stub-cache-arm.cc +4243 -0
  74. data/lib/libv8/v8/src/array.js +1366 -0
  75. data/lib/libv8/v8/src/assembler.cc +1207 -0
  76. data/lib/libv8/v8/src/assembler.h +858 -0
  77. data/lib/libv8/v8/src/ast-inl.h +112 -0
  78. data/lib/libv8/v8/src/ast.cc +1146 -0
  79. data/lib/libv8/v8/src/ast.h +2188 -0
  80. data/lib/libv8/v8/src/atomicops.h +167 -0
  81. data/lib/libv8/v8/src/atomicops_internals_arm_gcc.h +145 -0
  82. data/lib/libv8/v8/src/atomicops_internals_mips_gcc.h +169 -0
  83. data/lib/libv8/v8/src/atomicops_internals_x86_gcc.cc +133 -0
  84. data/lib/libv8/v8/src/atomicops_internals_x86_gcc.h +287 -0
  85. data/lib/libv8/v8/src/atomicops_internals_x86_macosx.h +301 -0
  86. data/lib/libv8/v8/src/atomicops_internals_x86_msvc.h +203 -0
  87. data/lib/libv8/v8/src/bignum-dtoa.cc +655 -0
  88. data/lib/libv8/v8/src/bignum-dtoa.h +81 -0
  89. data/lib/libv8/v8/src/bignum.cc +768 -0
  90. data/lib/libv8/v8/src/bignum.h +140 -0
  91. data/lib/libv8/v8/src/bootstrapper.cc +2184 -0
  92. data/lib/libv8/v8/src/bootstrapper.h +188 -0
  93. data/lib/libv8/v8/src/builtins.cc +1707 -0
  94. data/lib/libv8/v8/src/builtins.h +371 -0
  95. data/lib/libv8/v8/src/bytecodes-irregexp.h +105 -0
  96. data/lib/libv8/v8/src/cached-powers.cc +177 -0
  97. data/lib/libv8/v8/src/cached-powers.h +65 -0
  98. data/lib/libv8/v8/src/char-predicates-inl.h +94 -0
  99. data/lib/libv8/v8/src/char-predicates.h +67 -0
  100. data/lib/libv8/v8/src/checks.cc +110 -0
  101. data/lib/libv8/v8/src/checks.h +296 -0
  102. data/lib/libv8/v8/src/circular-queue-inl.h +53 -0
  103. data/lib/libv8/v8/src/circular-queue.cc +122 -0
  104. data/lib/libv8/v8/src/circular-queue.h +103 -0
  105. data/lib/libv8/v8/src/code-stubs.cc +267 -0
  106. data/lib/libv8/v8/src/code-stubs.h +1011 -0
  107. data/lib/libv8/v8/src/code.h +70 -0
  108. data/lib/libv8/v8/src/codegen.cc +231 -0
  109. data/lib/libv8/v8/src/codegen.h +84 -0
  110. data/lib/libv8/v8/src/compilation-cache.cc +540 -0
  111. data/lib/libv8/v8/src/compilation-cache.h +287 -0
  112. data/lib/libv8/v8/src/compiler.cc +786 -0
  113. data/lib/libv8/v8/src/compiler.h +312 -0
  114. data/lib/libv8/v8/src/contexts.cc +347 -0
  115. data/lib/libv8/v8/src/contexts.h +391 -0
  116. data/lib/libv8/v8/src/conversions-inl.h +106 -0
  117. data/lib/libv8/v8/src/conversions.cc +1131 -0
  118. data/lib/libv8/v8/src/conversions.h +135 -0
  119. data/lib/libv8/v8/src/counters.cc +93 -0
  120. data/lib/libv8/v8/src/counters.h +254 -0
  121. data/lib/libv8/v8/src/cpu-profiler-inl.h +101 -0
  122. data/lib/libv8/v8/src/cpu-profiler.cc +609 -0
  123. data/lib/libv8/v8/src/cpu-profiler.h +302 -0
  124. data/lib/libv8/v8/src/cpu.h +69 -0
  125. data/lib/libv8/v8/src/d8-debug.cc +367 -0
  126. data/lib/libv8/v8/src/d8-debug.h +158 -0
  127. data/lib/libv8/v8/src/d8-posix.cc +695 -0
  128. data/lib/libv8/v8/src/d8-readline.cc +130 -0
  129. data/lib/libv8/v8/src/d8-windows.cc +42 -0
  130. data/lib/libv8/v8/src/d8.cc +803 -0
  131. data/lib/libv8/v8/src/d8.gyp +91 -0
  132. data/lib/libv8/v8/src/d8.h +235 -0
  133. data/lib/libv8/v8/src/d8.js +2798 -0
  134. data/lib/libv8/v8/src/data-flow.cc +66 -0
  135. data/lib/libv8/v8/src/data-flow.h +205 -0
  136. data/lib/libv8/v8/src/date.js +1103 -0
  137. data/lib/libv8/v8/src/dateparser-inl.h +127 -0
  138. data/lib/libv8/v8/src/dateparser.cc +178 -0
  139. data/lib/libv8/v8/src/dateparser.h +266 -0
  140. data/lib/libv8/v8/src/debug-agent.cc +447 -0
  141. data/lib/libv8/v8/src/debug-agent.h +129 -0
  142. data/lib/libv8/v8/src/debug-debugger.js +2569 -0
  143. data/lib/libv8/v8/src/debug.cc +3165 -0
  144. data/lib/libv8/v8/src/debug.h +1057 -0
  145. data/lib/libv8/v8/src/deoptimizer.cc +1256 -0
  146. data/lib/libv8/v8/src/deoptimizer.h +602 -0
  147. data/lib/libv8/v8/src/disasm.h +80 -0
  148. data/lib/libv8/v8/src/disassembler.cc +343 -0
  149. data/lib/libv8/v8/src/disassembler.h +58 -0
  150. data/lib/libv8/v8/src/diy-fp.cc +58 -0
  151. data/lib/libv8/v8/src/diy-fp.h +117 -0
  152. data/lib/libv8/v8/src/double.h +238 -0
  153. data/lib/libv8/v8/src/dtoa.cc +103 -0
  154. data/lib/libv8/v8/src/dtoa.h +85 -0
  155. data/lib/libv8/v8/src/execution.cc +849 -0
  156. data/lib/libv8/v8/src/execution.h +297 -0
  157. data/lib/libv8/v8/src/extensions/experimental/break-iterator.cc +250 -0
  158. data/lib/libv8/v8/src/extensions/experimental/break-iterator.h +89 -0
  159. data/lib/libv8/v8/src/extensions/experimental/collator.cc +218 -0
  160. data/lib/libv8/v8/src/extensions/experimental/collator.h +69 -0
  161. data/lib/libv8/v8/src/extensions/experimental/experimental.gyp +94 -0
  162. data/lib/libv8/v8/src/extensions/experimental/i18n-extension.cc +78 -0
  163. data/lib/libv8/v8/src/extensions/experimental/i18n-extension.h +54 -0
  164. data/lib/libv8/v8/src/extensions/experimental/i18n-locale.cc +112 -0
  165. data/lib/libv8/v8/src/extensions/experimental/i18n-locale.h +60 -0
  166. data/lib/libv8/v8/src/extensions/experimental/i18n-utils.cc +43 -0
  167. data/lib/libv8/v8/src/extensions/experimental/i18n-utils.h +49 -0
  168. data/lib/libv8/v8/src/extensions/experimental/i18n.js +180 -0
  169. data/lib/libv8/v8/src/extensions/experimental/language-matcher.cc +251 -0
  170. data/lib/libv8/v8/src/extensions/experimental/language-matcher.h +95 -0
  171. data/lib/libv8/v8/src/extensions/externalize-string-extension.cc +141 -0
  172. data/lib/libv8/v8/src/extensions/externalize-string-extension.h +50 -0
  173. data/lib/libv8/v8/src/extensions/gc-extension.cc +58 -0
  174. data/lib/libv8/v8/src/extensions/gc-extension.h +49 -0
  175. data/lib/libv8/v8/src/factory.cc +1222 -0
  176. data/lib/libv8/v8/src/factory.h +442 -0
  177. data/lib/libv8/v8/src/fast-dtoa.cc +736 -0
  178. data/lib/libv8/v8/src/fast-dtoa.h +83 -0
  179. data/lib/libv8/v8/src/fixed-dtoa.cc +405 -0
  180. data/lib/libv8/v8/src/fixed-dtoa.h +55 -0
  181. data/lib/libv8/v8/src/flag-definitions.h +560 -0
  182. data/lib/libv8/v8/src/flags.cc +551 -0
  183. data/lib/libv8/v8/src/flags.h +79 -0
  184. data/lib/libv8/v8/src/frames-inl.h +247 -0
  185. data/lib/libv8/v8/src/frames.cc +1243 -0
  186. data/lib/libv8/v8/src/frames.h +870 -0
  187. data/lib/libv8/v8/src/full-codegen.cc +1374 -0
  188. data/lib/libv8/v8/src/full-codegen.h +771 -0
  189. data/lib/libv8/v8/src/func-name-inferrer.cc +92 -0
  190. data/lib/libv8/v8/src/func-name-inferrer.h +111 -0
  191. data/lib/libv8/v8/src/gdb-jit.cc +1555 -0
  192. data/lib/libv8/v8/src/gdb-jit.h +143 -0
  193. data/lib/libv8/v8/src/global-handles.cc +665 -0
  194. data/lib/libv8/v8/src/global-handles.h +284 -0
  195. data/lib/libv8/v8/src/globals.h +325 -0
  196. data/lib/libv8/v8/src/handles-inl.h +177 -0
  197. data/lib/libv8/v8/src/handles.cc +987 -0
  198. data/lib/libv8/v8/src/handles.h +382 -0
  199. data/lib/libv8/v8/src/hashmap.cc +230 -0
  200. data/lib/libv8/v8/src/hashmap.h +123 -0
  201. data/lib/libv8/v8/src/heap-inl.h +704 -0
  202. data/lib/libv8/v8/src/heap-profiler.cc +1173 -0
  203. data/lib/libv8/v8/src/heap-profiler.h +397 -0
  204. data/lib/libv8/v8/src/heap.cc +5930 -0
  205. data/lib/libv8/v8/src/heap.h +2268 -0
  206. data/lib/libv8/v8/src/hydrogen-instructions.cc +1769 -0
  207. data/lib/libv8/v8/src/hydrogen-instructions.h +3971 -0
  208. data/lib/libv8/v8/src/hydrogen.cc +6239 -0
  209. data/lib/libv8/v8/src/hydrogen.h +1202 -0
  210. data/lib/libv8/v8/src/ia32/assembler-ia32-inl.h +446 -0
  211. data/lib/libv8/v8/src/ia32/assembler-ia32.cc +2487 -0
  212. data/lib/libv8/v8/src/ia32/assembler-ia32.h +1144 -0
  213. data/lib/libv8/v8/src/ia32/builtins-ia32.cc +1621 -0
  214. data/lib/libv8/v8/src/ia32/code-stubs-ia32.cc +6198 -0
  215. data/lib/libv8/v8/src/ia32/code-stubs-ia32.h +517 -0
  216. data/lib/libv8/v8/src/ia32/codegen-ia32.cc +265 -0
  217. data/lib/libv8/v8/src/ia32/codegen-ia32.h +79 -0
  218. data/lib/libv8/v8/src/ia32/cpu-ia32.cc +88 -0
  219. data/lib/libv8/v8/src/ia32/debug-ia32.cc +312 -0
  220. data/lib/libv8/v8/src/ia32/deoptimizer-ia32.cc +774 -0
  221. data/lib/libv8/v8/src/ia32/disasm-ia32.cc +1628 -0
  222. data/lib/libv8/v8/src/ia32/frames-ia32.cc +45 -0
  223. data/lib/libv8/v8/src/ia32/frames-ia32.h +142 -0
  224. data/lib/libv8/v8/src/ia32/full-codegen-ia32.cc +4338 -0
  225. data/lib/libv8/v8/src/ia32/ic-ia32.cc +1597 -0
  226. data/lib/libv8/v8/src/ia32/lithium-codegen-ia32.cc +4461 -0
  227. data/lib/libv8/v8/src/ia32/lithium-codegen-ia32.h +375 -0
  228. data/lib/libv8/v8/src/ia32/lithium-gap-resolver-ia32.cc +475 -0
  229. data/lib/libv8/v8/src/ia32/lithium-gap-resolver-ia32.h +110 -0
  230. data/lib/libv8/v8/src/ia32/lithium-ia32.cc +2261 -0
  231. data/lib/libv8/v8/src/ia32/lithium-ia32.h +2396 -0
  232. data/lib/libv8/v8/src/ia32/macro-assembler-ia32.cc +2136 -0
  233. data/lib/libv8/v8/src/ia32/macro-assembler-ia32.h +775 -0
  234. data/lib/libv8/v8/src/ia32/regexp-macro-assembler-ia32.cc +1263 -0
  235. data/lib/libv8/v8/src/ia32/regexp-macro-assembler-ia32.h +216 -0
  236. data/lib/libv8/v8/src/ia32/simulator-ia32.cc +30 -0
  237. data/lib/libv8/v8/src/ia32/simulator-ia32.h +74 -0
  238. data/lib/libv8/v8/src/ia32/stub-cache-ia32.cc +3847 -0
  239. data/lib/libv8/v8/src/ic-inl.h +130 -0
  240. data/lib/libv8/v8/src/ic.cc +2577 -0
  241. data/lib/libv8/v8/src/ic.h +736 -0
  242. data/lib/libv8/v8/src/inspector.cc +63 -0
  243. data/lib/libv8/v8/src/inspector.h +62 -0
  244. data/lib/libv8/v8/src/interpreter-irregexp.cc +659 -0
  245. data/lib/libv8/v8/src/interpreter-irregexp.h +49 -0
  246. data/lib/libv8/v8/src/isolate-inl.h +50 -0
  247. data/lib/libv8/v8/src/isolate.cc +1869 -0
  248. data/lib/libv8/v8/src/isolate.h +1382 -0
  249. data/lib/libv8/v8/src/json-parser.cc +504 -0
  250. data/lib/libv8/v8/src/json-parser.h +161 -0
  251. data/lib/libv8/v8/src/json.js +342 -0
  252. data/lib/libv8/v8/src/jsregexp.cc +5385 -0
  253. data/lib/libv8/v8/src/jsregexp.h +1492 -0
  254. data/lib/libv8/v8/src/list-inl.h +212 -0
  255. data/lib/libv8/v8/src/list.h +174 -0
  256. data/lib/libv8/v8/src/lithium-allocator-inl.h +142 -0
  257. data/lib/libv8/v8/src/lithium-allocator.cc +2123 -0
  258. data/lib/libv8/v8/src/lithium-allocator.h +630 -0
  259. data/lib/libv8/v8/src/lithium.cc +190 -0
  260. data/lib/libv8/v8/src/lithium.h +597 -0
  261. data/lib/libv8/v8/src/liveedit-debugger.js +1082 -0
  262. data/lib/libv8/v8/src/liveedit.cc +1691 -0
  263. data/lib/libv8/v8/src/liveedit.h +180 -0
  264. data/lib/libv8/v8/src/liveobjectlist-inl.h +126 -0
  265. data/lib/libv8/v8/src/liveobjectlist.cc +2589 -0
  266. data/lib/libv8/v8/src/liveobjectlist.h +322 -0
  267. data/lib/libv8/v8/src/log-inl.h +59 -0
  268. data/lib/libv8/v8/src/log-utils.cc +428 -0
  269. data/lib/libv8/v8/src/log-utils.h +231 -0
  270. data/lib/libv8/v8/src/log.cc +1993 -0
  271. data/lib/libv8/v8/src/log.h +476 -0
  272. data/lib/libv8/v8/src/macro-assembler.h +120 -0
  273. data/lib/libv8/v8/src/macros.py +178 -0
  274. data/lib/libv8/v8/src/mark-compact.cc +3143 -0
  275. data/lib/libv8/v8/src/mark-compact.h +506 -0
  276. data/lib/libv8/v8/src/math.js +264 -0
  277. data/lib/libv8/v8/src/messages.cc +179 -0
  278. data/lib/libv8/v8/src/messages.h +113 -0
  279. data/lib/libv8/v8/src/messages.js +1096 -0
  280. data/lib/libv8/v8/src/mips/assembler-mips-inl.h +312 -0
  281. data/lib/libv8/v8/src/mips/assembler-mips.cc +1960 -0
  282. data/lib/libv8/v8/src/mips/assembler-mips.h +1138 -0
  283. data/lib/libv8/v8/src/mips/builtins-mips.cc +1628 -0
  284. data/lib/libv8/v8/src/mips/code-stubs-mips.cc +6656 -0
  285. data/lib/libv8/v8/src/mips/code-stubs-mips.h +682 -0
  286. data/lib/libv8/v8/src/mips/codegen-mips.cc +52 -0
  287. data/lib/libv8/v8/src/mips/codegen-mips.h +98 -0
  288. data/lib/libv8/v8/src/mips/constants-mips.cc +352 -0
  289. data/lib/libv8/v8/src/mips/constants-mips.h +739 -0
  290. data/lib/libv8/v8/src/mips/cpu-mips.cc +96 -0
  291. data/lib/libv8/v8/src/mips/debug-mips.cc +308 -0
  292. data/lib/libv8/v8/src/mips/deoptimizer-mips.cc +91 -0
  293. data/lib/libv8/v8/src/mips/disasm-mips.cc +1050 -0
  294. data/lib/libv8/v8/src/mips/frames-mips.cc +47 -0
  295. data/lib/libv8/v8/src/mips/frames-mips.h +219 -0
  296. data/lib/libv8/v8/src/mips/full-codegen-mips.cc +4388 -0
  297. data/lib/libv8/v8/src/mips/ic-mips.cc +1580 -0
  298. data/lib/libv8/v8/src/mips/lithium-codegen-mips.h +65 -0
  299. data/lib/libv8/v8/src/mips/lithium-mips.h +307 -0
  300. data/lib/libv8/v8/src/mips/macro-assembler-mips.cc +4056 -0
  301. data/lib/libv8/v8/src/mips/macro-assembler-mips.h +1214 -0
  302. data/lib/libv8/v8/src/mips/regexp-macro-assembler-mips.cc +1251 -0
  303. data/lib/libv8/v8/src/mips/regexp-macro-assembler-mips.h +252 -0
  304. data/lib/libv8/v8/src/mips/simulator-mips.cc +2621 -0
  305. data/lib/libv8/v8/src/mips/simulator-mips.h +401 -0
  306. data/lib/libv8/v8/src/mips/stub-cache-mips.cc +4285 -0
  307. data/lib/libv8/v8/src/mirror-debugger.js +2382 -0
  308. data/lib/libv8/v8/src/mksnapshot.cc +328 -0
  309. data/lib/libv8/v8/src/natives.h +64 -0
  310. data/lib/libv8/v8/src/objects-debug.cc +738 -0
  311. data/lib/libv8/v8/src/objects-inl.h +4323 -0
  312. data/lib/libv8/v8/src/objects-printer.cc +829 -0
  313. data/lib/libv8/v8/src/objects-visiting.cc +148 -0
  314. data/lib/libv8/v8/src/objects-visiting.h +424 -0
  315. data/lib/libv8/v8/src/objects.cc +10585 -0
  316. data/lib/libv8/v8/src/objects.h +6838 -0
  317. data/lib/libv8/v8/src/parser.cc +4997 -0
  318. data/lib/libv8/v8/src/parser.h +765 -0
  319. data/lib/libv8/v8/src/platform-cygwin.cc +779 -0
  320. data/lib/libv8/v8/src/platform-freebsd.cc +826 -0
  321. data/lib/libv8/v8/src/platform-linux.cc +1149 -0
  322. data/lib/libv8/v8/src/platform-macos.cc +830 -0
  323. data/lib/libv8/v8/src/platform-nullos.cc +479 -0
  324. data/lib/libv8/v8/src/platform-openbsd.cc +640 -0
  325. data/lib/libv8/v8/src/platform-posix.cc +424 -0
  326. data/lib/libv8/v8/src/platform-solaris.cc +762 -0
  327. data/lib/libv8/v8/src/platform-tls-mac.h +62 -0
  328. data/lib/libv8/v8/src/platform-tls-win32.h +62 -0
  329. data/lib/libv8/v8/src/platform-tls.h +50 -0
  330. data/lib/libv8/v8/src/platform-win32.cc +2021 -0
  331. data/lib/libv8/v8/src/platform.h +667 -0
  332. data/lib/libv8/v8/src/preparse-data-format.h +62 -0
  333. data/lib/libv8/v8/src/preparse-data.cc +183 -0
  334. data/lib/libv8/v8/src/preparse-data.h +225 -0
  335. data/lib/libv8/v8/src/preparser-api.cc +220 -0
  336. data/lib/libv8/v8/src/preparser.cc +1450 -0
  337. data/lib/libv8/v8/src/preparser.h +493 -0
  338. data/lib/libv8/v8/src/prettyprinter.cc +1493 -0
  339. data/lib/libv8/v8/src/prettyprinter.h +223 -0
  340. data/lib/libv8/v8/src/profile-generator-inl.h +128 -0
  341. data/lib/libv8/v8/src/profile-generator.cc +3098 -0
  342. data/lib/libv8/v8/src/profile-generator.h +1126 -0
  343. data/lib/libv8/v8/src/property.cc +105 -0
  344. data/lib/libv8/v8/src/property.h +365 -0
  345. data/lib/libv8/v8/src/proxy.js +83 -0
  346. data/lib/libv8/v8/src/regexp-macro-assembler-irregexp-inl.h +78 -0
  347. data/lib/libv8/v8/src/regexp-macro-assembler-irregexp.cc +471 -0
  348. data/lib/libv8/v8/src/regexp-macro-assembler-irregexp.h +142 -0
  349. data/lib/libv8/v8/src/regexp-macro-assembler-tracer.cc +373 -0
  350. data/lib/libv8/v8/src/regexp-macro-assembler-tracer.h +104 -0
  351. data/lib/libv8/v8/src/regexp-macro-assembler.cc +267 -0
  352. data/lib/libv8/v8/src/regexp-macro-assembler.h +243 -0
  353. data/lib/libv8/v8/src/regexp-stack.cc +111 -0
  354. data/lib/libv8/v8/src/regexp-stack.h +147 -0
  355. data/lib/libv8/v8/src/regexp.js +483 -0
  356. data/lib/libv8/v8/src/rewriter.cc +360 -0
  357. data/lib/libv8/v8/src/rewriter.h +50 -0
  358. data/lib/libv8/v8/src/runtime-profiler.cc +489 -0
  359. data/lib/libv8/v8/src/runtime-profiler.h +201 -0
  360. data/lib/libv8/v8/src/runtime.cc +12227 -0
  361. data/lib/libv8/v8/src/runtime.h +652 -0
  362. data/lib/libv8/v8/src/runtime.js +649 -0
  363. data/lib/libv8/v8/src/safepoint-table.cc +256 -0
  364. data/lib/libv8/v8/src/safepoint-table.h +270 -0
  365. data/lib/libv8/v8/src/scanner-base.cc +952 -0
  366. data/lib/libv8/v8/src/scanner-base.h +670 -0
  367. data/lib/libv8/v8/src/scanner.cc +345 -0
  368. data/lib/libv8/v8/src/scanner.h +146 -0
  369. data/lib/libv8/v8/src/scopeinfo.cc +646 -0
  370. data/lib/libv8/v8/src/scopeinfo.h +254 -0
  371. data/lib/libv8/v8/src/scopes.cc +1150 -0
  372. data/lib/libv8/v8/src/scopes.h +507 -0
  373. data/lib/libv8/v8/src/serialize.cc +1574 -0
  374. data/lib/libv8/v8/src/serialize.h +589 -0
  375. data/lib/libv8/v8/src/shell.h +55 -0
  376. data/lib/libv8/v8/src/simulator.h +43 -0
  377. data/lib/libv8/v8/src/small-pointer-list.h +163 -0
  378. data/lib/libv8/v8/src/smart-pointer.h +109 -0
  379. data/lib/libv8/v8/src/snapshot-common.cc +83 -0
  380. data/lib/libv8/v8/src/snapshot-empty.cc +54 -0
  381. data/lib/libv8/v8/src/snapshot.h +91 -0
  382. data/lib/libv8/v8/src/spaces-inl.h +529 -0
  383. data/lib/libv8/v8/src/spaces.cc +3145 -0
  384. data/lib/libv8/v8/src/spaces.h +2369 -0
  385. data/lib/libv8/v8/src/splay-tree-inl.h +310 -0
  386. data/lib/libv8/v8/src/splay-tree.h +205 -0
  387. data/lib/libv8/v8/src/string-search.cc +41 -0
  388. data/lib/libv8/v8/src/string-search.h +568 -0
  389. data/lib/libv8/v8/src/string-stream.cc +592 -0
  390. data/lib/libv8/v8/src/string-stream.h +191 -0
  391. data/lib/libv8/v8/src/string.js +994 -0
  392. data/lib/libv8/v8/src/strtod.cc +440 -0
  393. data/lib/libv8/v8/src/strtod.h +40 -0
  394. data/lib/libv8/v8/src/stub-cache.cc +1965 -0
  395. data/lib/libv8/v8/src/stub-cache.h +924 -0
  396. data/lib/libv8/v8/src/third_party/valgrind/valgrind.h +3925 -0
  397. data/lib/libv8/v8/src/token.cc +63 -0
  398. data/lib/libv8/v8/src/token.h +288 -0
  399. data/lib/libv8/v8/src/type-info.cc +507 -0
  400. data/lib/libv8/v8/src/type-info.h +272 -0
  401. data/lib/libv8/v8/src/unbound-queue-inl.h +95 -0
  402. data/lib/libv8/v8/src/unbound-queue.h +69 -0
  403. data/lib/libv8/v8/src/unicode-inl.h +238 -0
  404. data/lib/libv8/v8/src/unicode.cc +1624 -0
  405. data/lib/libv8/v8/src/unicode.h +280 -0
  406. data/lib/libv8/v8/src/uri.js +408 -0
  407. data/lib/libv8/v8/src/utils-inl.h +48 -0
  408. data/lib/libv8/v8/src/utils.cc +371 -0
  409. data/lib/libv8/v8/src/utils.h +800 -0
  410. data/lib/libv8/v8/src/v8-counters.cc +62 -0
  411. data/lib/libv8/v8/src/v8-counters.h +314 -0
  412. data/lib/libv8/v8/src/v8.cc +213 -0
  413. data/lib/libv8/v8/src/v8.h +131 -0
  414. data/lib/libv8/v8/src/v8checks.h +64 -0
  415. data/lib/libv8/v8/src/v8dll-main.cc +44 -0
  416. data/lib/libv8/v8/src/v8globals.h +512 -0
  417. data/lib/libv8/v8/src/v8memory.h +82 -0
  418. data/lib/libv8/v8/src/v8natives.js +1310 -0
  419. data/lib/libv8/v8/src/v8preparserdll-main.cc +39 -0
  420. data/lib/libv8/v8/src/v8threads.cc +464 -0
  421. data/lib/libv8/v8/src/v8threads.h +165 -0
  422. data/lib/libv8/v8/src/v8utils.h +319 -0
  423. data/lib/libv8/v8/src/variables.cc +114 -0
  424. data/lib/libv8/v8/src/variables.h +167 -0
  425. data/lib/libv8/v8/src/version.cc +116 -0
  426. data/lib/libv8/v8/src/version.h +68 -0
  427. data/lib/libv8/v8/src/vm-state-inl.h +138 -0
  428. data/lib/libv8/v8/src/vm-state.h +71 -0
  429. data/lib/libv8/v8/src/win32-headers.h +96 -0
  430. data/lib/libv8/v8/src/x64/assembler-x64-inl.h +462 -0
  431. data/lib/libv8/v8/src/x64/assembler-x64.cc +3027 -0
  432. data/lib/libv8/v8/src/x64/assembler-x64.h +1633 -0
  433. data/lib/libv8/v8/src/x64/builtins-x64.cc +1520 -0
  434. data/lib/libv8/v8/src/x64/code-stubs-x64.cc +5132 -0
  435. data/lib/libv8/v8/src/x64/code-stubs-x64.h +514 -0
  436. data/lib/libv8/v8/src/x64/codegen-x64.cc +146 -0
  437. data/lib/libv8/v8/src/x64/codegen-x64.h +76 -0
  438. data/lib/libv8/v8/src/x64/cpu-x64.cc +88 -0
  439. data/lib/libv8/v8/src/x64/debug-x64.cc +319 -0
  440. data/lib/libv8/v8/src/x64/deoptimizer-x64.cc +815 -0
  441. data/lib/libv8/v8/src/x64/disasm-x64.cc +1832 -0
  442. data/lib/libv8/v8/src/x64/frames-x64.cc +45 -0
  443. data/lib/libv8/v8/src/x64/frames-x64.h +130 -0
  444. data/lib/libv8/v8/src/x64/full-codegen-x64.cc +4318 -0
  445. data/lib/libv8/v8/src/x64/ic-x64.cc +1608 -0
  446. data/lib/libv8/v8/src/x64/lithium-codegen-x64.cc +4267 -0
  447. data/lib/libv8/v8/src/x64/lithium-codegen-x64.h +367 -0
  448. data/lib/libv8/v8/src/x64/lithium-gap-resolver-x64.cc +320 -0
  449. data/lib/libv8/v8/src/x64/lithium-gap-resolver-x64.h +74 -0
  450. data/lib/libv8/v8/src/x64/lithium-x64.cc +2202 -0
  451. data/lib/libv8/v8/src/x64/lithium-x64.h +2333 -0
  452. data/lib/libv8/v8/src/x64/macro-assembler-x64.cc +3745 -0
  453. data/lib/libv8/v8/src/x64/macro-assembler-x64.h +1290 -0
  454. data/lib/libv8/v8/src/x64/regexp-macro-assembler-x64.cc +1398 -0
  455. data/lib/libv8/v8/src/x64/regexp-macro-assembler-x64.h +282 -0
  456. data/lib/libv8/v8/src/x64/simulator-x64.cc +27 -0
  457. data/lib/libv8/v8/src/x64/simulator-x64.h +72 -0
  458. data/lib/libv8/v8/src/x64/stub-cache-x64.cc +3610 -0
  459. data/lib/libv8/v8/src/zone-inl.h +140 -0
  460. data/lib/libv8/v8/src/zone.cc +196 -0
  461. data/lib/libv8/v8/src/zone.h +240 -0
  462. data/lib/libv8/v8/tools/codemap.js +265 -0
  463. data/lib/libv8/v8/tools/consarray.js +93 -0
  464. data/lib/libv8/v8/tools/csvparser.js +78 -0
  465. data/lib/libv8/v8/tools/disasm.py +92 -0
  466. data/lib/libv8/v8/tools/freebsd-tick-processor +10 -0
  467. data/lib/libv8/v8/tools/gc-nvp-trace-processor.py +342 -0
  468. data/lib/libv8/v8/tools/gcmole/README +62 -0
  469. data/lib/libv8/v8/tools/gcmole/gccause.lua +60 -0
  470. data/lib/libv8/v8/tools/gcmole/gcmole.cc +1261 -0
  471. data/lib/libv8/v8/tools/gcmole/gcmole.lua +378 -0
  472. data/lib/libv8/v8/tools/generate-ten-powers.scm +286 -0
  473. data/lib/libv8/v8/tools/grokdump.py +841 -0
  474. data/lib/libv8/v8/tools/gyp/v8.gyp +995 -0
  475. data/lib/libv8/v8/tools/js2c.py +364 -0
  476. data/lib/libv8/v8/tools/jsmin.py +280 -0
  477. data/lib/libv8/v8/tools/linux-tick-processor +35 -0
  478. data/lib/libv8/v8/tools/ll_prof.py +942 -0
  479. data/lib/libv8/v8/tools/logreader.js +185 -0
  480. data/lib/libv8/v8/tools/mac-nm +18 -0
  481. data/lib/libv8/v8/tools/mac-tick-processor +6 -0
  482. data/lib/libv8/v8/tools/oom_dump/README +31 -0
  483. data/lib/libv8/v8/tools/oom_dump/SConstruct +42 -0
  484. data/lib/libv8/v8/tools/oom_dump/oom_dump.cc +288 -0
  485. data/lib/libv8/v8/tools/presubmit.py +305 -0
  486. data/lib/libv8/v8/tools/process-heap-prof.py +120 -0
  487. data/lib/libv8/v8/tools/profile.js +751 -0
  488. data/lib/libv8/v8/tools/profile_view.js +219 -0
  489. data/lib/libv8/v8/tools/run-valgrind.py +77 -0
  490. data/lib/libv8/v8/tools/splaytree.js +316 -0
  491. data/lib/libv8/v8/tools/stats-viewer.py +468 -0
  492. data/lib/libv8/v8/tools/test.py +1510 -0
  493. data/lib/libv8/v8/tools/tickprocessor-driver.js +59 -0
  494. data/lib/libv8/v8/tools/tickprocessor.js +877 -0
  495. data/lib/libv8/v8/tools/utils.py +96 -0
  496. data/lib/libv8/v8/tools/visual_studio/README.txt +12 -0
  497. data/lib/libv8/v8/tools/windows-tick-processor.bat +30 -0
  498. data/lib/libv8/version.rb +5 -0
  499. data/libv8.gemspec +36 -0
  500. metadata +578 -0
@@ -0,0 +1,1173 @@
1
+ // Copyright 2009-2010 the V8 project authors. All rights reserved.
2
+ // Redistribution and use in source and binary forms, with or without
3
+ // modification, are permitted provided that the following conditions are
4
+ // met:
5
+ //
6
+ // * Redistributions of source code must retain the above copyright
7
+ // notice, this list of conditions and the following disclaimer.
8
+ // * Redistributions in binary form must reproduce the above
9
+ // copyright notice, this list of conditions and the following
10
+ // disclaimer in the documentation and/or other materials provided
11
+ // with the distribution.
12
+ // * Neither the name of Google Inc. nor the names of its
13
+ // contributors may be used to endorse or promote products derived
14
+ // from this software without specific prior written permission.
15
+ //
16
+ // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17
+ // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18
+ // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19
+ // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20
+ // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21
+ // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22
+ // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23
+ // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24
+ // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25
+ // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26
+ // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
+
28
+ #include "v8.h"
29
+
30
+ #include "heap-profiler.h"
31
+ #include "frames-inl.h"
32
+ #include "global-handles.h"
33
+ #include "profile-generator.h"
34
+ #include "string-stream.h"
35
+
36
+ namespace v8 {
37
+ namespace internal {
38
+
39
+
40
+ #ifdef ENABLE_LOGGING_AND_PROFILING
41
+ namespace {
42
+
43
+ // Clusterizer is a set of helper functions for converting
44
+ // object references into clusters.
45
+ class Clusterizer : public AllStatic {
46
+ public:
47
+ static JSObjectsCluster Clusterize(HeapObject* obj) {
48
+ return Clusterize(obj, true);
49
+ }
50
+ static void InsertIntoTree(JSObjectsClusterTree* tree,
51
+ HeapObject* obj, bool fine_grain);
52
+ static void InsertReferenceIntoTree(JSObjectsClusterTree* tree,
53
+ const JSObjectsCluster& cluster) {
54
+ InsertIntoTree(tree, cluster, 0);
55
+ }
56
+
57
+ private:
58
+ static JSObjectsCluster Clusterize(HeapObject* obj, bool fine_grain);
59
+ static int CalculateNetworkSize(JSObject* obj);
60
+ static int GetObjectSize(HeapObject* obj) {
61
+ return obj->IsJSObject() ?
62
+ CalculateNetworkSize(JSObject::cast(obj)) : obj->Size();
63
+ }
64
+ static void InsertIntoTree(JSObjectsClusterTree* tree,
65
+ const JSObjectsCluster& cluster, int size);
66
+ };
67
+
68
+
69
+ JSObjectsCluster Clusterizer::Clusterize(HeapObject* obj, bool fine_grain) {
70
+ if (obj->IsJSObject()) {
71
+ JSObject* js_obj = JSObject::cast(obj);
72
+ String* constructor = GetConstructorNameForHeapProfile(
73
+ JSObject::cast(js_obj));
74
+ // Differentiate Object and Array instances.
75
+ if (fine_grain && (constructor == HEAP->Object_symbol() ||
76
+ constructor == HEAP->Array_symbol())) {
77
+ return JSObjectsCluster(constructor, obj);
78
+ } else {
79
+ return JSObjectsCluster(constructor);
80
+ }
81
+ } else if (obj->IsString()) {
82
+ return JSObjectsCluster(HEAP->String_symbol());
83
+ } else if (obj->IsJSGlobalPropertyCell()) {
84
+ return JSObjectsCluster(JSObjectsCluster::GLOBAL_PROPERTY);
85
+ } else if (obj->IsCode() || obj->IsSharedFunctionInfo() || obj->IsScript()) {
86
+ return JSObjectsCluster(JSObjectsCluster::CODE);
87
+ }
88
+ return JSObjectsCluster();
89
+ }
90
+
91
+
92
+ void Clusterizer::InsertIntoTree(JSObjectsClusterTree* tree,
93
+ HeapObject* obj, bool fine_grain) {
94
+ JSObjectsCluster cluster = Clusterize(obj, fine_grain);
95
+ if (cluster.is_null()) return;
96
+ InsertIntoTree(tree, cluster, GetObjectSize(obj));
97
+ }
98
+
99
+
100
+ void Clusterizer::InsertIntoTree(JSObjectsClusterTree* tree,
101
+ const JSObjectsCluster& cluster, int size) {
102
+ JSObjectsClusterTree::Locator loc;
103
+ tree->Insert(cluster, &loc);
104
+ NumberAndSizeInfo number_and_size = loc.value();
105
+ number_and_size.increment_number(1);
106
+ number_and_size.increment_bytes(size);
107
+ loc.set_value(number_and_size);
108
+ }
109
+
110
+
111
+ int Clusterizer::CalculateNetworkSize(JSObject* obj) {
112
+ int size = obj->Size();
113
+ // If 'properties' and 'elements' are non-empty (thus, non-shared),
114
+ // take their size into account.
115
+ if (obj->properties() != HEAP->empty_fixed_array()) {
116
+ size += obj->properties()->Size();
117
+ }
118
+ if (obj->elements() != HEAP->empty_fixed_array()) {
119
+ size += obj->elements()->Size();
120
+ }
121
+ // For functions, also account non-empty context and literals sizes.
122
+ if (obj->IsJSFunction()) {
123
+ JSFunction* f = JSFunction::cast(obj);
124
+ if (f->unchecked_context()->IsContext()) {
125
+ size += f->context()->Size();
126
+ }
127
+ if (f->literals()->length() != 0) {
128
+ size += f->literals()->Size();
129
+ }
130
+ }
131
+ return size;
132
+ }
133
+
134
+
135
+ // A helper class for recording back references.
136
+ class ReferencesExtractor : public ObjectVisitor {
137
+ public:
138
+ ReferencesExtractor(const JSObjectsCluster& cluster,
139
+ RetainerHeapProfile* profile)
140
+ : cluster_(cluster),
141
+ profile_(profile),
142
+ inside_array_(false) {
143
+ }
144
+
145
+ void VisitPointer(Object** o) {
146
+ if ((*o)->IsFixedArray() && !inside_array_) {
147
+ // Traverse one level deep for data members that are fixed arrays.
148
+ // This covers the case of 'elements' and 'properties' of JSObject,
149
+ // and function contexts.
150
+ inside_array_ = true;
151
+ FixedArray::cast(*o)->Iterate(this);
152
+ inside_array_ = false;
153
+ } else if ((*o)->IsHeapObject()) {
154
+ profile_->StoreReference(cluster_, HeapObject::cast(*o));
155
+ }
156
+ }
157
+
158
+ void VisitPointers(Object** start, Object** end) {
159
+ for (Object** p = start; p < end; p++) VisitPointer(p);
160
+ }
161
+
162
+ private:
163
+ const JSObjectsCluster& cluster_;
164
+ RetainerHeapProfile* profile_;
165
+ bool inside_array_;
166
+ };
167
+
168
+
169
+ // A printer interface implementation for the Retainers profile.
170
+ class RetainersPrinter : public RetainerHeapProfile::Printer {
171
+ public:
172
+ void PrintRetainers(const JSObjectsCluster& cluster,
173
+ const StringStream& retainers) {
174
+ HeapStringAllocator allocator;
175
+ StringStream stream(&allocator);
176
+ cluster.Print(&stream);
177
+ LOG(ISOLATE,
178
+ HeapSampleJSRetainersEvent(
179
+ *(stream.ToCString()), *(retainers.ToCString())));
180
+ }
181
+ };
182
+
183
+
184
+ // Visitor for printing a cluster tree.
185
+ class ClusterTreePrinter BASE_EMBEDDED {
186
+ public:
187
+ explicit ClusterTreePrinter(StringStream* stream) : stream_(stream) {}
188
+ void Call(const JSObjectsCluster& cluster,
189
+ const NumberAndSizeInfo& number_and_size) {
190
+ Print(stream_, cluster, number_and_size);
191
+ }
192
+ static void Print(StringStream* stream,
193
+ const JSObjectsCluster& cluster,
194
+ const NumberAndSizeInfo& number_and_size);
195
+
196
+ private:
197
+ StringStream* stream_;
198
+ };
199
+
200
+
201
+ void ClusterTreePrinter::Print(StringStream* stream,
202
+ const JSObjectsCluster& cluster,
203
+ const NumberAndSizeInfo& number_and_size) {
204
+ stream->Put(',');
205
+ cluster.Print(stream);
206
+ stream->Add(";%d", number_and_size.number());
207
+ }
208
+
209
+
210
+ // Visitor for printing a retainer tree.
211
+ class SimpleRetainerTreePrinter BASE_EMBEDDED {
212
+ public:
213
+ explicit SimpleRetainerTreePrinter(RetainerHeapProfile::Printer* printer)
214
+ : printer_(printer) {}
215
+ void Call(const JSObjectsCluster& cluster, JSObjectsClusterTree* tree);
216
+
217
+ private:
218
+ RetainerHeapProfile::Printer* printer_;
219
+ };
220
+
221
+
222
+ void SimpleRetainerTreePrinter::Call(const JSObjectsCluster& cluster,
223
+ JSObjectsClusterTree* tree) {
224
+ HeapStringAllocator allocator;
225
+ StringStream stream(&allocator);
226
+ ClusterTreePrinter retainers_printer(&stream);
227
+ tree->ForEach(&retainers_printer);
228
+ printer_->PrintRetainers(cluster, stream);
229
+ }
230
+
231
+
232
+ // Visitor for aggregating references count of equivalent clusters.
233
+ class RetainersAggregator BASE_EMBEDDED {
234
+ public:
235
+ RetainersAggregator(ClustersCoarser* coarser, JSObjectsClusterTree* dest_tree)
236
+ : coarser_(coarser), dest_tree_(dest_tree) {}
237
+ void Call(const JSObjectsCluster& cluster,
238
+ const NumberAndSizeInfo& number_and_size);
239
+
240
+ private:
241
+ ClustersCoarser* coarser_;
242
+ JSObjectsClusterTree* dest_tree_;
243
+ };
244
+
245
+
246
+ void RetainersAggregator::Call(const JSObjectsCluster& cluster,
247
+ const NumberAndSizeInfo& number_and_size) {
248
+ JSObjectsCluster eq = coarser_->GetCoarseEquivalent(cluster);
249
+ if (eq.is_null()) eq = cluster;
250
+ JSObjectsClusterTree::Locator loc;
251
+ dest_tree_->Insert(eq, &loc);
252
+ NumberAndSizeInfo aggregated_number = loc.value();
253
+ aggregated_number.increment_number(number_and_size.number());
254
+ loc.set_value(aggregated_number);
255
+ }
256
+
257
+
258
+ // Visitor for printing retainers tree. Aggregates equivalent retainer clusters.
259
+ class AggregatingRetainerTreePrinter BASE_EMBEDDED {
260
+ public:
261
+ AggregatingRetainerTreePrinter(ClustersCoarser* coarser,
262
+ RetainerHeapProfile::Printer* printer)
263
+ : coarser_(coarser), printer_(printer) {}
264
+ void Call(const JSObjectsCluster& cluster, JSObjectsClusterTree* tree);
265
+
266
+ private:
267
+ ClustersCoarser* coarser_;
268
+ RetainerHeapProfile::Printer* printer_;
269
+ };
270
+
271
+
272
+ void AggregatingRetainerTreePrinter::Call(const JSObjectsCluster& cluster,
273
+ JSObjectsClusterTree* tree) {
274
+ if (!coarser_->GetCoarseEquivalent(cluster).is_null()) return;
275
+ JSObjectsClusterTree dest_tree_;
276
+ RetainersAggregator retainers_aggregator(coarser_, &dest_tree_);
277
+ tree->ForEach(&retainers_aggregator);
278
+ HeapStringAllocator allocator;
279
+ StringStream stream(&allocator);
280
+ ClusterTreePrinter retainers_printer(&stream);
281
+ dest_tree_.ForEach(&retainers_printer);
282
+ printer_->PrintRetainers(cluster, stream);
283
+ }
284
+
285
+ } // namespace
286
+
287
+
288
+ // A helper class for building a retainers tree, that aggregates
289
+ // all equivalent clusters.
290
+ class RetainerTreeAggregator {
291
+ public:
292
+ explicit RetainerTreeAggregator(ClustersCoarser* coarser)
293
+ : coarser_(coarser) {}
294
+ void Process(JSObjectsRetainerTree* input_tree) {
295
+ input_tree->ForEach(this);
296
+ }
297
+ void Call(const JSObjectsCluster& cluster, JSObjectsClusterTree* tree);
298
+ JSObjectsRetainerTree& output_tree() { return output_tree_; }
299
+
300
+ private:
301
+ ClustersCoarser* coarser_;
302
+ JSObjectsRetainerTree output_tree_;
303
+ };
304
+
305
+
306
+ void RetainerTreeAggregator::Call(const JSObjectsCluster& cluster,
307
+ JSObjectsClusterTree* tree) {
308
+ JSObjectsCluster eq = coarser_->GetCoarseEquivalent(cluster);
309
+ if (eq.is_null()) return;
310
+ JSObjectsRetainerTree::Locator loc;
311
+ if (output_tree_.Insert(eq, &loc)) {
312
+ loc.set_value(new JSObjectsClusterTree());
313
+ }
314
+ RetainersAggregator retainers_aggregator(coarser_, loc.value());
315
+ tree->ForEach(&retainers_aggregator);
316
+ }
317
+
318
+
319
+ HeapProfiler::HeapProfiler()
320
+ : snapshots_(new HeapSnapshotsCollection()),
321
+ next_snapshot_uid_(1) {
322
+ }
323
+
324
+
325
+ HeapProfiler::~HeapProfiler() {
326
+ delete snapshots_;
327
+ }
328
+
329
+
330
+ void HeapProfiler::ResetSnapshots() {
331
+ delete snapshots_;
332
+ snapshots_ = new HeapSnapshotsCollection();
333
+ }
334
+
335
+
336
+ #endif // ENABLE_LOGGING_AND_PROFILING
337
+
338
+ void HeapProfiler::Setup() {
339
+ #ifdef ENABLE_LOGGING_AND_PROFILING
340
+ Isolate* isolate = Isolate::Current();
341
+ if (isolate->heap_profiler() == NULL) {
342
+ isolate->set_heap_profiler(new HeapProfiler());
343
+ }
344
+ #endif
345
+ }
346
+
347
+
348
+ void HeapProfiler::TearDown() {
349
+ #ifdef ENABLE_LOGGING_AND_PROFILING
350
+ Isolate* isolate = Isolate::Current();
351
+ delete isolate->heap_profiler();
352
+ isolate->set_heap_profiler(NULL);
353
+ #endif
354
+ }
355
+
356
+
357
+ #ifdef ENABLE_LOGGING_AND_PROFILING
358
+
359
+ HeapSnapshot* HeapProfiler::TakeSnapshot(const char* name,
360
+ int type,
361
+ v8::ActivityControl* control) {
362
+ ASSERT(Isolate::Current()->heap_profiler() != NULL);
363
+ return Isolate::Current()->heap_profiler()->TakeSnapshotImpl(name,
364
+ type,
365
+ control);
366
+ }
367
+
368
+
369
+ HeapSnapshot* HeapProfiler::TakeSnapshot(String* name,
370
+ int type,
371
+ v8::ActivityControl* control) {
372
+ ASSERT(Isolate::Current()->heap_profiler() != NULL);
373
+ return Isolate::Current()->heap_profiler()->TakeSnapshotImpl(name,
374
+ type,
375
+ control);
376
+ }
377
+
378
+
379
+ void HeapProfiler::DefineWrapperClass(
380
+ uint16_t class_id, v8::HeapProfiler::WrapperInfoCallback callback) {
381
+ ASSERT(class_id != v8::HeapProfiler::kPersistentHandleNoClassId);
382
+ if (wrapper_callbacks_.length() <= class_id) {
383
+ wrapper_callbacks_.AddBlock(
384
+ NULL, class_id - wrapper_callbacks_.length() + 1);
385
+ }
386
+ wrapper_callbacks_[class_id] = callback;
387
+ }
388
+
389
+
390
+ v8::RetainedObjectInfo* HeapProfiler::ExecuteWrapperClassCallback(
391
+ uint16_t class_id, Object** wrapper) {
392
+ if (wrapper_callbacks_.length() <= class_id) return NULL;
393
+ return wrapper_callbacks_[class_id](
394
+ class_id, Utils::ToLocal(Handle<Object>(wrapper)));
395
+ }
396
+
397
+
398
+ HeapSnapshot* HeapProfiler::TakeSnapshotImpl(const char* name,
399
+ int type,
400
+ v8::ActivityControl* control) {
401
+ HeapSnapshot::Type s_type = static_cast<HeapSnapshot::Type>(type);
402
+ HeapSnapshot* result =
403
+ snapshots_->NewSnapshot(s_type, name, next_snapshot_uid_++);
404
+ bool generation_completed = true;
405
+ switch (s_type) {
406
+ case HeapSnapshot::kFull: {
407
+ HEAP->CollectAllGarbage(true);
408
+ HeapSnapshotGenerator generator(result, control);
409
+ generation_completed = generator.GenerateSnapshot();
410
+ break;
411
+ }
412
+ case HeapSnapshot::kAggregated: {
413
+ HEAP->CollectAllGarbage(true);
414
+ AggregatedHeapSnapshot agg_snapshot;
415
+ AggregatedHeapSnapshotGenerator generator(&agg_snapshot);
416
+ generator.GenerateSnapshot();
417
+ generator.FillHeapSnapshot(result);
418
+ break;
419
+ }
420
+ default:
421
+ UNREACHABLE();
422
+ }
423
+ if (!generation_completed) {
424
+ delete result;
425
+ result = NULL;
426
+ }
427
+ snapshots_->SnapshotGenerationFinished(result);
428
+ return result;
429
+ }
430
+
431
+
432
+ HeapSnapshot* HeapProfiler::TakeSnapshotImpl(String* name,
433
+ int type,
434
+ v8::ActivityControl* control) {
435
+ return TakeSnapshotImpl(snapshots_->names()->GetName(name), type, control);
436
+ }
437
+
438
+
439
+ int HeapProfiler::GetSnapshotsCount() {
440
+ HeapProfiler* profiler = Isolate::Current()->heap_profiler();
441
+ ASSERT(profiler != NULL);
442
+ return profiler->snapshots_->snapshots()->length();
443
+ }
444
+
445
+
446
+ HeapSnapshot* HeapProfiler::GetSnapshot(int index) {
447
+ HeapProfiler* profiler = Isolate::Current()->heap_profiler();
448
+ ASSERT(profiler != NULL);
449
+ return profiler->snapshots_->snapshots()->at(index);
450
+ }
451
+
452
+
453
+ HeapSnapshot* HeapProfiler::FindSnapshot(unsigned uid) {
454
+ HeapProfiler* profiler = Isolate::Current()->heap_profiler();
455
+ ASSERT(profiler != NULL);
456
+ return profiler->snapshots_->GetSnapshot(uid);
457
+ }
458
+
459
+
460
+ void HeapProfiler::DeleteAllSnapshots() {
461
+ HeapProfiler* profiler = Isolate::Current()->heap_profiler();
462
+ ASSERT(profiler != NULL);
463
+ profiler->ResetSnapshots();
464
+ }
465
+
466
+
467
+ void HeapProfiler::ObjectMoveEvent(Address from, Address to) {
468
+ snapshots_->ObjectMoveEvent(from, to);
469
+ }
470
+
471
+
472
+ const JSObjectsClusterTreeConfig::Key JSObjectsClusterTreeConfig::kNoKey;
473
+ const JSObjectsClusterTreeConfig::Value JSObjectsClusterTreeConfig::kNoValue;
474
+
475
+
476
+ ConstructorHeapProfile::ConstructorHeapProfile()
477
+ : zscope_(Isolate::Current(), DELETE_ON_EXIT) {
478
+ }
479
+
480
+
481
+ void ConstructorHeapProfile::Call(const JSObjectsCluster& cluster,
482
+ const NumberAndSizeInfo& number_and_size) {
483
+ HeapStringAllocator allocator;
484
+ StringStream stream(&allocator);
485
+ cluster.Print(&stream);
486
+ LOG(ISOLATE,
487
+ HeapSampleJSConstructorEvent(*(stream.ToCString()),
488
+ number_and_size.number(),
489
+ number_and_size.bytes()));
490
+ }
491
+
492
+
493
+ void ConstructorHeapProfile::CollectStats(HeapObject* obj) {
494
+ Clusterizer::InsertIntoTree(&js_objects_info_tree_, obj, false);
495
+ }
496
+
497
+
498
+ void ConstructorHeapProfile::PrintStats() {
499
+ js_objects_info_tree_.ForEach(this);
500
+ }
501
+
502
+
503
+ static const char* GetConstructorName(const char* name) {
504
+ return name[0] != '\0' ? name : "(anonymous)";
505
+ }
506
+
507
+
508
+ const char* JSObjectsCluster::GetSpecialCaseName() const {
509
+ if (constructor_ == FromSpecialCase(ROOTS)) {
510
+ return "(roots)";
511
+ } else if (constructor_ == FromSpecialCase(GLOBAL_PROPERTY)) {
512
+ return "(global property)";
513
+ } else if (constructor_ == FromSpecialCase(CODE)) {
514
+ return "(code)";
515
+ } else if (constructor_ == FromSpecialCase(SELF)) {
516
+ return "(self)";
517
+ }
518
+ return NULL;
519
+ }
520
+
521
+
522
+ void JSObjectsCluster::Print(StringStream* accumulator) const {
523
+ ASSERT(!is_null());
524
+ const char* special_case_name = GetSpecialCaseName();
525
+ if (special_case_name != NULL) {
526
+ accumulator->Add(special_case_name);
527
+ } else {
528
+ SmartPointer<char> s_name(
529
+ constructor_->ToCString(DISALLOW_NULLS, ROBUST_STRING_TRAVERSAL));
530
+ accumulator->Add("%s", GetConstructorName(*s_name));
531
+ if (instance_ != NULL) {
532
+ accumulator->Add(":%p", static_cast<void*>(instance_));
533
+ }
534
+ }
535
+ }
536
+
537
+
538
+ void JSObjectsCluster::DebugPrint(StringStream* accumulator) const {
539
+ if (!is_null()) {
540
+ Print(accumulator);
541
+ } else {
542
+ accumulator->Add("(null cluster)");
543
+ }
544
+ }
545
+
546
+
547
+ inline ClustersCoarser::ClusterBackRefs::ClusterBackRefs(
548
+ const JSObjectsCluster& cluster_)
549
+ : cluster(cluster_), refs(kInitialBackrefsListCapacity) {
550
+ }
551
+
552
+
553
+ inline ClustersCoarser::ClusterBackRefs::ClusterBackRefs(
554
+ const ClustersCoarser::ClusterBackRefs& src)
555
+ : cluster(src.cluster), refs(src.refs.capacity()) {
556
+ refs.AddAll(src.refs);
557
+ }
558
+
559
+
560
+ inline ClustersCoarser::ClusterBackRefs&
561
+ ClustersCoarser::ClusterBackRefs::operator=(
562
+ const ClustersCoarser::ClusterBackRefs& src) {
563
+ if (this == &src) return *this;
564
+ cluster = src.cluster;
565
+ refs.Clear();
566
+ refs.AddAll(src.refs);
567
+ return *this;
568
+ }
569
+
570
+
571
+ inline int ClustersCoarser::ClusterBackRefs::Compare(
572
+ const ClustersCoarser::ClusterBackRefs& a,
573
+ const ClustersCoarser::ClusterBackRefs& b) {
574
+ int cmp = JSObjectsCluster::CompareConstructors(a.cluster, b.cluster);
575
+ if (cmp != 0) return cmp;
576
+ if (a.refs.length() < b.refs.length()) return -1;
577
+ if (a.refs.length() > b.refs.length()) return 1;
578
+ for (int i = 0; i < a.refs.length(); ++i) {
579
+ int cmp = JSObjectsCluster::Compare(a.refs[i], b.refs[i]);
580
+ if (cmp != 0) return cmp;
581
+ }
582
+ return 0;
583
+ }
584
+
585
+
586
+ ClustersCoarser::ClustersCoarser()
587
+ : zscope_(Isolate::Current(), DELETE_ON_EXIT),
588
+ sim_list_(ClustersCoarser::kInitialSimilarityListCapacity),
589
+ current_pair_(NULL),
590
+ current_set_(NULL),
591
+ self_(NULL) {
592
+ }
593
+
594
+
595
+ void ClustersCoarser::Call(const JSObjectsCluster& cluster,
596
+ JSObjectsClusterTree* tree) {
597
+ if (!cluster.can_be_coarsed()) return;
598
+ ClusterBackRefs pair(cluster);
599
+ ASSERT(current_pair_ == NULL);
600
+ current_pair_ = &pair;
601
+ current_set_ = new JSObjectsRetainerTree();
602
+ self_ = &cluster;
603
+ tree->ForEach(this);
604
+ sim_list_.Add(pair);
605
+ current_pair_ = NULL;
606
+ current_set_ = NULL;
607
+ self_ = NULL;
608
+ }
609
+
610
+
611
+ void ClustersCoarser::Call(const JSObjectsCluster& cluster,
612
+ const NumberAndSizeInfo& number_and_size) {
613
+ ASSERT(current_pair_ != NULL);
614
+ ASSERT(current_set_ != NULL);
615
+ ASSERT(self_ != NULL);
616
+ JSObjectsRetainerTree::Locator loc;
617
+ if (JSObjectsCluster::Compare(*self_, cluster) == 0) {
618
+ current_pair_->refs.Add(JSObjectsCluster(JSObjectsCluster::SELF));
619
+ return;
620
+ }
621
+ JSObjectsCluster eq = GetCoarseEquivalent(cluster);
622
+ if (!eq.is_null()) {
623
+ if (current_set_->Find(eq, &loc)) return;
624
+ current_pair_->refs.Add(eq);
625
+ current_set_->Insert(eq, &loc);
626
+ } else {
627
+ current_pair_->refs.Add(cluster);
628
+ }
629
+ }
630
+
631
+
632
+ void ClustersCoarser::Process(JSObjectsRetainerTree* tree) {
633
+ int last_eq_clusters = -1;
634
+ for (int i = 0; i < kMaxPassesCount; ++i) {
635
+ sim_list_.Clear();
636
+ const int curr_eq_clusters = DoProcess(tree);
637
+ // If no new cluster equivalents discovered, abort processing.
638
+ if (last_eq_clusters == curr_eq_clusters) break;
639
+ last_eq_clusters = curr_eq_clusters;
640
+ }
641
+ }
642
+
643
+
644
+ int ClustersCoarser::DoProcess(JSObjectsRetainerTree* tree) {
645
+ tree->ForEach(this);
646
+ sim_list_.Iterate(ClusterBackRefs::SortRefsIterator);
647
+ sim_list_.Sort(ClusterBackRefsCmp);
648
+ return FillEqualityTree();
649
+ }
650
+
651
+
652
+ JSObjectsCluster ClustersCoarser::GetCoarseEquivalent(
653
+ const JSObjectsCluster& cluster) {
654
+ if (!cluster.can_be_coarsed()) return JSObjectsCluster();
655
+ EqualityTree::Locator loc;
656
+ return eq_tree_.Find(cluster, &loc) ? loc.value() : JSObjectsCluster();
657
+ }
658
+
659
+
660
+ bool ClustersCoarser::HasAnEquivalent(const JSObjectsCluster& cluster) {
661
+ // Return true for coarsible clusters that have a non-identical equivalent.
662
+ if (!cluster.can_be_coarsed()) return false;
663
+ JSObjectsCluster eq = GetCoarseEquivalent(cluster);
664
+ return !eq.is_null() && JSObjectsCluster::Compare(cluster, eq) != 0;
665
+ }
666
+
667
+
668
+ int ClustersCoarser::FillEqualityTree() {
669
+ int eq_clusters_count = 0;
670
+ int eq_to = 0;
671
+ bool first_added = false;
672
+ for (int i = 1; i < sim_list_.length(); ++i) {
673
+ if (ClusterBackRefs::Compare(sim_list_[i], sim_list_[eq_to]) == 0) {
674
+ EqualityTree::Locator loc;
675
+ if (!first_added) {
676
+ // Add self-equivalence, if we have more than one item in this
677
+ // equivalence class.
678
+ eq_tree_.Insert(sim_list_[eq_to].cluster, &loc);
679
+ loc.set_value(sim_list_[eq_to].cluster);
680
+ first_added = true;
681
+ }
682
+ eq_tree_.Insert(sim_list_[i].cluster, &loc);
683
+ loc.set_value(sim_list_[eq_to].cluster);
684
+ ++eq_clusters_count;
685
+ } else {
686
+ eq_to = i;
687
+ first_added = false;
688
+ }
689
+ }
690
+ return eq_clusters_count;
691
+ }
692
+
693
+
694
+ const JSObjectsCluster ClustersCoarser::ClusterEqualityConfig::kNoKey;
695
+ const JSObjectsCluster ClustersCoarser::ClusterEqualityConfig::kNoValue;
696
+ const JSObjectsRetainerTreeConfig::Key JSObjectsRetainerTreeConfig::kNoKey;
697
+ const JSObjectsRetainerTreeConfig::Value JSObjectsRetainerTreeConfig::kNoValue =
698
+ NULL;
699
+
700
+
701
+ RetainerHeapProfile::RetainerHeapProfile()
702
+ : zscope_(Isolate::Current(), DELETE_ON_EXIT),
703
+ aggregator_(NULL) {
704
+ JSObjectsCluster roots(JSObjectsCluster::ROOTS);
705
+ ReferencesExtractor extractor(roots, this);
706
+ HEAP->IterateRoots(&extractor, VISIT_ONLY_STRONG);
707
+ }
708
+
709
+
710
+ RetainerHeapProfile::~RetainerHeapProfile() {
711
+ delete aggregator_;
712
+ }
713
+
714
+
715
+ void RetainerHeapProfile::StoreReference(const JSObjectsCluster& cluster,
716
+ HeapObject* ref) {
717
+ JSObjectsCluster ref_cluster = Clusterizer::Clusterize(ref);
718
+ if (ref_cluster.is_null()) return;
719
+ JSObjectsRetainerTree::Locator ref_loc;
720
+ if (retainers_tree_.Insert(ref_cluster, &ref_loc)) {
721
+ ref_loc.set_value(new JSObjectsClusterTree());
722
+ }
723
+ JSObjectsClusterTree* referenced_by = ref_loc.value();
724
+ Clusterizer::InsertReferenceIntoTree(referenced_by, cluster);
725
+ }
726
+
727
+
728
+ void RetainerHeapProfile::CollectStats(HeapObject* obj) {
729
+ const JSObjectsCluster cluster = Clusterizer::Clusterize(obj);
730
+ if (cluster.is_null()) return;
731
+ ReferencesExtractor extractor(cluster, this);
732
+ obj->Iterate(&extractor);
733
+ }
734
+
735
+
736
+ void RetainerHeapProfile::CoarseAndAggregate() {
737
+ coarser_.Process(&retainers_tree_);
738
+ ASSERT(aggregator_ == NULL);
739
+ aggregator_ = new RetainerTreeAggregator(&coarser_);
740
+ aggregator_->Process(&retainers_tree_);
741
+ }
742
+
743
+
744
+ void RetainerHeapProfile::DebugPrintStats(
745
+ RetainerHeapProfile::Printer* printer) {
746
+ // Print clusters that have no equivalents, aggregating their retainers.
747
+ AggregatingRetainerTreePrinter agg_printer(&coarser_, printer);
748
+ retainers_tree_.ForEach(&agg_printer);
749
+ // Print clusters that have equivalents.
750
+ SimpleRetainerTreePrinter s_printer(printer);
751
+ aggregator_->output_tree().ForEach(&s_printer);
752
+ }
753
+
754
+
755
+ void RetainerHeapProfile::PrintStats() {
756
+ RetainersPrinter printer;
757
+ DebugPrintStats(&printer);
758
+ }
759
+
760
+
761
+ //
762
+ // HeapProfiler class implementation.
763
+ //
764
+ static void StackWeakReferenceCallback(Persistent<Value> object,
765
+ void* trace) {
766
+ DeleteArray(static_cast<Address*>(trace));
767
+ object.Dispose();
768
+ }
769
+
770
+
771
+ static void PrintProducerStackTrace(Object* obj, void* trace) {
772
+ if (!obj->IsJSObject()) return;
773
+ String* constructor = GetConstructorNameForHeapProfile(JSObject::cast(obj));
774
+ SmartPointer<char> s_name(
775
+ constructor->ToCString(DISALLOW_NULLS, ROBUST_STRING_TRAVERSAL));
776
+ LOG(ISOLATE,
777
+ HeapSampleJSProducerEvent(GetConstructorName(*s_name),
778
+ reinterpret_cast<Address*>(trace)));
779
+ }
780
+
781
+
782
+ void HeapProfiler::WriteSample() {
783
+ Isolate* isolate = Isolate::Current();
784
+ LOG(isolate, HeapSampleBeginEvent("Heap", "allocated"));
785
+ LOG(isolate,
786
+ HeapSampleStats(
787
+ "Heap", "allocated", HEAP->CommittedMemory(), HEAP->SizeOfObjects()));
788
+
789
+ AggregatedHeapSnapshot snapshot;
790
+ AggregatedHeapSnapshotGenerator generator(&snapshot);
791
+ generator.GenerateSnapshot();
792
+
793
+ HistogramInfo* info = snapshot.info();
794
+ for (int i = FIRST_NONSTRING_TYPE;
795
+ i <= AggregatedHeapSnapshotGenerator::kAllStringsType;
796
+ ++i) {
797
+ if (info[i].bytes() > 0) {
798
+ LOG(isolate,
799
+ HeapSampleItemEvent(info[i].name(), info[i].number(),
800
+ info[i].bytes()));
801
+ }
802
+ }
803
+
804
+ snapshot.js_cons_profile()->PrintStats();
805
+ snapshot.js_retainer_profile()->PrintStats();
806
+
807
+ isolate->global_handles()->IterateWeakRoots(PrintProducerStackTrace,
808
+ StackWeakReferenceCallback);
809
+
810
+ LOG(isolate, HeapSampleEndEvent("Heap", "allocated"));
811
+ }
812
+
813
+
814
+ AggregatedHeapSnapshot::AggregatedHeapSnapshot()
815
+ : info_(NewArray<HistogramInfo>(
816
+ AggregatedHeapSnapshotGenerator::kAllStringsType + 1)) {
817
+ #define DEF_TYPE_NAME(name) info_[name].set_name(#name);
818
+ INSTANCE_TYPE_LIST(DEF_TYPE_NAME);
819
+ #undef DEF_TYPE_NAME
820
+ info_[AggregatedHeapSnapshotGenerator::kAllStringsType].set_name(
821
+ "STRING_TYPE");
822
+ }
823
+
824
+
825
+ AggregatedHeapSnapshot::~AggregatedHeapSnapshot() {
826
+ DeleteArray(info_);
827
+ }
828
+
829
+
830
+ AggregatedHeapSnapshotGenerator::AggregatedHeapSnapshotGenerator(
831
+ AggregatedHeapSnapshot* agg_snapshot)
832
+ : agg_snapshot_(agg_snapshot) {
833
+ }
834
+
835
+
836
+ void AggregatedHeapSnapshotGenerator::CalculateStringsStats() {
837
+ HistogramInfo* info = agg_snapshot_->info();
838
+ HistogramInfo& strings = info[kAllStringsType];
839
+ // Lump all the string types together.
840
+ #define INCREMENT_SIZE(type, size, name, camel_name) \
841
+ strings.increment_number(info[type].number()); \
842
+ strings.increment_bytes(info[type].bytes());
843
+ STRING_TYPE_LIST(INCREMENT_SIZE);
844
+ #undef INCREMENT_SIZE
845
+ }
846
+
847
+
848
+ void AggregatedHeapSnapshotGenerator::CollectStats(HeapObject* obj) {
849
+ InstanceType type = obj->map()->instance_type();
850
+ ASSERT(0 <= type && type <= LAST_TYPE);
851
+ agg_snapshot_->info()[type].increment_number(1);
852
+ agg_snapshot_->info()[type].increment_bytes(obj->Size());
853
+ }
854
+
855
+
856
+ void AggregatedHeapSnapshotGenerator::GenerateSnapshot() {
857
+ HeapIterator iterator(HeapIterator::kFilterUnreachable);
858
+ for (HeapObject* obj = iterator.next(); obj != NULL; obj = iterator.next()) {
859
+ CollectStats(obj);
860
+ agg_snapshot_->js_cons_profile()->CollectStats(obj);
861
+ agg_snapshot_->js_retainer_profile()->CollectStats(obj);
862
+ }
863
+ CalculateStringsStats();
864
+ agg_snapshot_->js_retainer_profile()->CoarseAndAggregate();
865
+ }
866
+
867
+
868
+ class CountingConstructorHeapProfileIterator {
869
+ public:
870
+ CountingConstructorHeapProfileIterator()
871
+ : entities_count_(0), children_count_(0) {
872
+ }
873
+
874
+ void Call(const JSObjectsCluster& cluster,
875
+ const NumberAndSizeInfo& number_and_size) {
876
+ ++entities_count_;
877
+ children_count_ += number_and_size.number();
878
+ }
879
+
880
+ int entities_count() { return entities_count_; }
881
+ int children_count() { return children_count_; }
882
+
883
+ private:
884
+ int entities_count_;
885
+ int children_count_;
886
+ };
887
+
888
+
889
+ static HeapEntry* AddEntryFromAggregatedSnapshot(HeapSnapshot* snapshot,
890
+ int* root_child_index,
891
+ HeapEntry::Type type,
892
+ const char* name,
893
+ int count,
894
+ int size,
895
+ int children_count,
896
+ int retainers_count) {
897
+ HeapEntry* entry = snapshot->AddEntry(
898
+ type, name, count, size, children_count, retainers_count);
899
+ ASSERT(entry != NULL);
900
+ snapshot->root()->SetUnidirElementReference(*root_child_index,
901
+ *root_child_index + 1,
902
+ entry);
903
+ *root_child_index = *root_child_index + 1;
904
+ return entry;
905
+ }
906
+
907
+
908
+ class AllocatingConstructorHeapProfileIterator {
909
+ public:
910
+ AllocatingConstructorHeapProfileIterator(HeapSnapshot* snapshot,
911
+ int* root_child_index)
912
+ : snapshot_(snapshot),
913
+ root_child_index_(root_child_index) {
914
+ }
915
+
916
+ void Call(const JSObjectsCluster& cluster,
917
+ const NumberAndSizeInfo& number_and_size) {
918
+ const char* name = cluster.GetSpecialCaseName();
919
+ if (name == NULL) {
920
+ name = snapshot_->collection()->names()->GetFunctionName(
921
+ cluster.constructor());
922
+ }
923
+ AddEntryFromAggregatedSnapshot(snapshot_,
924
+ root_child_index_,
925
+ HeapEntry::kObject,
926
+ name,
927
+ number_and_size.number(),
928
+ number_and_size.bytes(),
929
+ 0,
930
+ 0);
931
+ }
932
+
933
+ private:
934
+ HeapSnapshot* snapshot_;
935
+ int* root_child_index_;
936
+ };
937
+
938
+
939
+ static HeapObject* ClusterAsHeapObject(const JSObjectsCluster& cluster) {
940
+ return cluster.can_be_coarsed() ?
941
+ reinterpret_cast<HeapObject*>(cluster.instance()) : cluster.constructor();
942
+ }
943
+
944
+
945
+ static JSObjectsCluster HeapObjectAsCluster(HeapObject* object) {
946
+ if (object->IsString()) {
947
+ return JSObjectsCluster(String::cast(object));
948
+ } else {
949
+ JSObject* js_obj = JSObject::cast(object);
950
+ String* constructor = GetConstructorNameForHeapProfile(
951
+ JSObject::cast(js_obj));
952
+ return JSObjectsCluster(constructor, object);
953
+ }
954
+ }
955
+
956
+
957
+ class CountingRetainersIterator {
958
+ public:
959
+ CountingRetainersIterator(const JSObjectsCluster& child_cluster,
960
+ HeapEntriesAllocator* allocator,
961
+ HeapEntriesMap* map)
962
+ : child_(ClusterAsHeapObject(child_cluster)),
963
+ allocator_(allocator),
964
+ map_(map) {
965
+ if (map_->Map(child_) == NULL)
966
+ map_->Pair(child_, allocator_, HeapEntriesMap::kHeapEntryPlaceholder);
967
+ }
968
+
969
+ void Call(const JSObjectsCluster& cluster,
970
+ const NumberAndSizeInfo& number_and_size) {
971
+ if (map_->Map(ClusterAsHeapObject(cluster)) == NULL)
972
+ map_->Pair(ClusterAsHeapObject(cluster),
973
+ allocator_,
974
+ HeapEntriesMap::kHeapEntryPlaceholder);
975
+ map_->CountReference(ClusterAsHeapObject(cluster), child_);
976
+ }
977
+
978
+ private:
979
+ HeapObject* child_;
980
+ HeapEntriesAllocator* allocator_;
981
+ HeapEntriesMap* map_;
982
+ };
983
+
984
+
985
+ class AllocatingRetainersIterator {
986
+ public:
987
+ AllocatingRetainersIterator(const JSObjectsCluster& child_cluster,
988
+ HeapEntriesAllocator*,
989
+ HeapEntriesMap* map)
990
+ : child_(ClusterAsHeapObject(child_cluster)), map_(map) {
991
+ child_entry_ = map_->Map(child_);
992
+ ASSERT(child_entry_ != NULL);
993
+ }
994
+
995
+ void Call(const JSObjectsCluster& cluster,
996
+ const NumberAndSizeInfo& number_and_size) {
997
+ int child_index, retainer_index;
998
+ map_->CountReference(ClusterAsHeapObject(cluster),
999
+ child_,
1000
+ &child_index,
1001
+ &retainer_index);
1002
+ map_->Map(ClusterAsHeapObject(cluster))->SetIndexedReference(
1003
+ HeapGraphEdge::kElement,
1004
+ child_index,
1005
+ number_and_size.number(),
1006
+ child_entry_,
1007
+ retainer_index);
1008
+ }
1009
+
1010
+ private:
1011
+ HeapObject* child_;
1012
+ HeapEntriesMap* map_;
1013
+ HeapEntry* child_entry_;
1014
+ };
1015
+
1016
+
1017
+ template<class RetainersIterator>
1018
+ class AggregatingRetainerTreeIterator {
1019
+ public:
1020
+ explicit AggregatingRetainerTreeIterator(ClustersCoarser* coarser,
1021
+ HeapEntriesAllocator* allocator,
1022
+ HeapEntriesMap* map)
1023
+ : coarser_(coarser), allocator_(allocator), map_(map) {
1024
+ }
1025
+
1026
+ void Call(const JSObjectsCluster& cluster, JSObjectsClusterTree* tree) {
1027
+ if (coarser_ != NULL &&
1028
+ !coarser_->GetCoarseEquivalent(cluster).is_null()) return;
1029
+ JSObjectsClusterTree* tree_to_iterate = tree;
1030
+ ZoneScope zs(Isolate::Current(), DELETE_ON_EXIT);
1031
+ JSObjectsClusterTree dest_tree_;
1032
+ if (coarser_ != NULL) {
1033
+ RetainersAggregator retainers_aggregator(coarser_, &dest_tree_);
1034
+ tree->ForEach(&retainers_aggregator);
1035
+ tree_to_iterate = &dest_tree_;
1036
+ }
1037
+ RetainersIterator iterator(cluster, allocator_, map_);
1038
+ tree_to_iterate->ForEach(&iterator);
1039
+ }
1040
+
1041
+ private:
1042
+ ClustersCoarser* coarser_;
1043
+ HeapEntriesAllocator* allocator_;
1044
+ HeapEntriesMap* map_;
1045
+ };
1046
+
1047
+
1048
+ class AggregatedRetainerTreeAllocator : public HeapEntriesAllocator {
1049
+ public:
1050
+ AggregatedRetainerTreeAllocator(HeapSnapshot* snapshot,
1051
+ int* root_child_index)
1052
+ : snapshot_(snapshot), root_child_index_(root_child_index) {
1053
+ }
1054
+ ~AggregatedRetainerTreeAllocator() { }
1055
+
1056
+ HeapEntry* AllocateEntry(
1057
+ HeapThing ptr, int children_count, int retainers_count) {
1058
+ HeapObject* obj = reinterpret_cast<HeapObject*>(ptr);
1059
+ JSObjectsCluster cluster = HeapObjectAsCluster(obj);
1060
+ const char* name = cluster.GetSpecialCaseName();
1061
+ if (name == NULL) {
1062
+ name = snapshot_->collection()->names()->GetFunctionName(
1063
+ cluster.constructor());
1064
+ }
1065
+ return AddEntryFromAggregatedSnapshot(
1066
+ snapshot_, root_child_index_, HeapEntry::kObject, name,
1067
+ 0, 0, children_count, retainers_count);
1068
+ }
1069
+
1070
+ private:
1071
+ HeapSnapshot* snapshot_;
1072
+ int* root_child_index_;
1073
+ };
1074
+
1075
+
1076
+ template<class Iterator>
1077
+ void AggregatedHeapSnapshotGenerator::IterateRetainers(
1078
+ HeapEntriesAllocator* allocator, HeapEntriesMap* entries_map) {
1079
+ RetainerHeapProfile* p = agg_snapshot_->js_retainer_profile();
1080
+ AggregatingRetainerTreeIterator<Iterator> agg_ret_iter_1(
1081
+ p->coarser(), allocator, entries_map);
1082
+ p->retainers_tree()->ForEach(&agg_ret_iter_1);
1083
+ AggregatingRetainerTreeIterator<Iterator> agg_ret_iter_2(
1084
+ NULL, allocator, entries_map);
1085
+ p->aggregator()->output_tree().ForEach(&agg_ret_iter_2);
1086
+ }
1087
+
1088
+
1089
+ void AggregatedHeapSnapshotGenerator::FillHeapSnapshot(HeapSnapshot* snapshot) {
1090
+ // Count the number of entities.
1091
+ int histogram_entities_count = 0;
1092
+ int histogram_children_count = 0;
1093
+ int histogram_retainers_count = 0;
1094
+ for (int i = FIRST_NONSTRING_TYPE; i <= kAllStringsType; ++i) {
1095
+ if (agg_snapshot_->info()[i].bytes() > 0) {
1096
+ ++histogram_entities_count;
1097
+ }
1098
+ }
1099
+ CountingConstructorHeapProfileIterator counting_cons_iter;
1100
+ agg_snapshot_->js_cons_profile()->ForEach(&counting_cons_iter);
1101
+ histogram_entities_count += counting_cons_iter.entities_count();
1102
+ HeapEntriesMap entries_map;
1103
+ int root_child_index = 0;
1104
+ AggregatedRetainerTreeAllocator allocator(snapshot, &root_child_index);
1105
+ IterateRetainers<CountingRetainersIterator>(&allocator, &entries_map);
1106
+ histogram_entities_count += entries_map.entries_count();
1107
+ histogram_children_count += entries_map.total_children_count();
1108
+ histogram_retainers_count += entries_map.total_retainers_count();
1109
+
1110
+ // Root entry references all other entries.
1111
+ histogram_children_count += histogram_entities_count;
1112
+ int root_children_count = histogram_entities_count;
1113
+ ++histogram_entities_count;
1114
+
1115
+ // Allocate and fill entries in the snapshot, allocate references.
1116
+ snapshot->AllocateEntries(histogram_entities_count,
1117
+ histogram_children_count,
1118
+ histogram_retainers_count);
1119
+ snapshot->AddRootEntry(root_children_count);
1120
+ for (int i = FIRST_NONSTRING_TYPE; i <= kAllStringsType; ++i) {
1121
+ if (agg_snapshot_->info()[i].bytes() > 0) {
1122
+ AddEntryFromAggregatedSnapshot(snapshot,
1123
+ &root_child_index,
1124
+ HeapEntry::kHidden,
1125
+ agg_snapshot_->info()[i].name(),
1126
+ agg_snapshot_->info()[i].number(),
1127
+ agg_snapshot_->info()[i].bytes(),
1128
+ 0,
1129
+ 0);
1130
+ }
1131
+ }
1132
+ AllocatingConstructorHeapProfileIterator alloc_cons_iter(
1133
+ snapshot, &root_child_index);
1134
+ agg_snapshot_->js_cons_profile()->ForEach(&alloc_cons_iter);
1135
+ entries_map.AllocateEntries();
1136
+
1137
+ // Fill up references.
1138
+ IterateRetainers<AllocatingRetainersIterator>(&allocator, &entries_map);
1139
+
1140
+ snapshot->SetDominatorsToSelf();
1141
+ }
1142
+
1143
+
1144
+ void ProducerHeapProfile::Setup() {
1145
+ can_log_ = true;
1146
+ }
1147
+
1148
+ void ProducerHeapProfile::DoRecordJSObjectAllocation(Object* obj) {
1149
+ ASSERT(FLAG_log_producers);
1150
+ if (!can_log_) return;
1151
+ int framesCount = 0;
1152
+ for (JavaScriptFrameIterator it; !it.done(); it.Advance()) {
1153
+ ++framesCount;
1154
+ }
1155
+ if (framesCount == 0) return;
1156
+ ++framesCount; // Reserve place for the terminator item.
1157
+ Vector<Address> stack(NewArray<Address>(framesCount), framesCount);
1158
+ int i = 0;
1159
+ for (JavaScriptFrameIterator it; !it.done(); it.Advance()) {
1160
+ stack[i++] = it.frame()->pc();
1161
+ }
1162
+ stack[i] = NULL;
1163
+ Handle<Object> handle = isolate_->global_handles()->Create(obj);
1164
+ isolate_->global_handles()->MakeWeak(handle.location(),
1165
+ static_cast<void*>(stack.start()),
1166
+ StackWeakReferenceCallback);
1167
+ }
1168
+
1169
+
1170
+ #endif // ENABLE_LOGGING_AND_PROFILING
1171
+
1172
+
1173
+ } } // namespace v8::internal