mustang 0.0.1 → 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (560) hide show
  1. data/.rspec +1 -0
  2. data/Isolate +9 -0
  3. data/README.md +6 -12
  4. data/Rakefile +30 -4
  5. data/TODO.md +9 -0
  6. data/ext/v8/extconf.rb +56 -0
  7. data/ext/v8/v8.cpp +37 -0
  8. data/ext/v8/v8_array.cpp +161 -0
  9. data/ext/v8/v8_array.h +17 -0
  10. data/ext/v8/v8_base.cpp +147 -0
  11. data/ext/v8/v8_base.h +23 -0
  12. data/ext/v8/v8_cast.cpp +151 -0
  13. data/ext/v8/v8_cast.h +64 -0
  14. data/ext/v8/v8_context.cpp +174 -0
  15. data/ext/v8/v8_context.h +12 -0
  16. data/ext/v8/v8_date.cpp +61 -0
  17. data/ext/v8/v8_date.h +16 -0
  18. data/ext/v8/v8_errors.cpp +147 -0
  19. data/ext/v8/v8_errors.h +19 -0
  20. data/ext/v8/v8_external.cpp +66 -0
  21. data/ext/v8/v8_external.h +16 -0
  22. data/ext/v8/v8_function.cpp +182 -0
  23. data/ext/v8/v8_function.h +14 -0
  24. data/ext/v8/v8_integer.cpp +70 -0
  25. data/ext/v8/v8_integer.h +16 -0
  26. data/ext/v8/v8_macros.h +30 -0
  27. data/ext/v8/v8_main.cpp +53 -0
  28. data/ext/v8/v8_main.h +13 -0
  29. data/ext/v8/v8_number.cpp +62 -0
  30. data/ext/v8/v8_number.h +16 -0
  31. data/ext/v8/v8_object.cpp +172 -0
  32. data/ext/v8/v8_object.h +17 -0
  33. data/ext/v8/v8_ref.cpp +72 -0
  34. data/ext/v8/v8_ref.h +43 -0
  35. data/ext/v8/v8_regexp.cpp +148 -0
  36. data/ext/v8/v8_regexp.h +16 -0
  37. data/ext/v8/v8_string.cpp +78 -0
  38. data/ext/v8/v8_string.h +16 -0
  39. data/ext/v8/v8_value.cpp +370 -0
  40. data/ext/v8/v8_value.h +19 -0
  41. data/gemspec.yml +2 -1
  42. data/lib/core_ext/class.rb +14 -0
  43. data/lib/core_ext/object.rb +12 -0
  44. data/lib/core_ext/symbol.rb +23 -0
  45. data/lib/mustang.rb +44 -0
  46. data/lib/mustang/context.rb +69 -0
  47. data/lib/mustang/errors.rb +36 -0
  48. data/lib/support/delegated.rb +25 -0
  49. data/lib/v8/array.rb +21 -0
  50. data/lib/v8/context.rb +13 -0
  51. data/lib/v8/date.rb +20 -0
  52. data/lib/v8/error.rb +15 -0
  53. data/lib/v8/external.rb +16 -0
  54. data/lib/v8/function.rb +11 -0
  55. data/lib/v8/integer.rb +16 -0
  56. data/lib/v8/number.rb +16 -0
  57. data/lib/v8/object.rb +66 -0
  58. data/lib/v8/regexp.rb +23 -0
  59. data/lib/v8/string.rb +27 -0
  60. data/mustang.gemspec +3 -0
  61. data/spec/core_ext/class_spec.rb +19 -0
  62. data/spec/core_ext/object_spec.rb +19 -0
  63. data/spec/core_ext/symbol_spec.rb +27 -0
  64. data/spec/fixtures/test1.js +2 -0
  65. data/spec/fixtures/test2.js +2 -0
  66. data/spec/spec_helper.rb +20 -0
  67. data/spec/v8/array_spec.rb +88 -0
  68. data/spec/v8/cast_spec.rb +151 -0
  69. data/spec/v8/context_spec.rb +78 -0
  70. data/spec/v8/data_spec.rb +39 -0
  71. data/spec/v8/date_spec.rb +45 -0
  72. data/spec/v8/empty_spec.rb +27 -0
  73. data/spec/v8/errors_spec.rb +142 -0
  74. data/spec/v8/external_spec.rb +44 -0
  75. data/spec/v8/function_spec.rb +170 -0
  76. data/spec/v8/integer_spec.rb +41 -0
  77. data/spec/v8/main_spec.rb +18 -0
  78. data/spec/v8/null_spec.rb +27 -0
  79. data/spec/v8/number_spec.rb +40 -0
  80. data/spec/v8/object_spec.rb +79 -0
  81. data/spec/v8/primitive_spec.rb +9 -0
  82. data/spec/v8/regexp_spec.rb +65 -0
  83. data/spec/v8/string_spec.rb +48 -0
  84. data/spec/v8/undefined_spec.rb +27 -0
  85. data/spec/v8/value_spec.rb +215 -0
  86. data/vendor/v8/.gitignore +2 -0
  87. data/vendor/v8/AUTHORS +3 -1
  88. data/vendor/v8/ChangeLog +117 -0
  89. data/vendor/v8/SConstruct +334 -53
  90. data/vendor/v8/include/v8-debug.h +21 -11
  91. data/vendor/v8/include/v8-preparser.h +1 -1
  92. data/vendor/v8/include/v8-profiler.h +122 -43
  93. data/vendor/v8/include/v8-testing.h +5 -0
  94. data/vendor/v8/include/v8.h +171 -17
  95. data/vendor/v8/preparser/SConscript +38 -0
  96. data/vendor/v8/preparser/preparser-process.cc +77 -114
  97. data/vendor/v8/samples/shell.cc +232 -46
  98. data/vendor/v8/src/SConscript +29 -5
  99. data/vendor/v8/src/accessors.cc +70 -211
  100. data/vendor/v8/{test/cctest/test-mips.cc → src/allocation-inl.h} +15 -18
  101. data/vendor/v8/src/allocation.cc +0 -82
  102. data/vendor/v8/src/allocation.h +9 -42
  103. data/vendor/v8/src/api.cc +1645 -1156
  104. data/vendor/v8/src/api.h +76 -12
  105. data/vendor/v8/src/apiutils.h +0 -7
  106. data/vendor/v8/src/arguments.h +15 -4
  107. data/vendor/v8/src/arm/assembler-arm-inl.h +10 -9
  108. data/vendor/v8/src/arm/assembler-arm.cc +62 -23
  109. data/vendor/v8/src/arm/assembler-arm.h +76 -11
  110. data/vendor/v8/src/arm/builtins-arm.cc +39 -33
  111. data/vendor/v8/src/arm/code-stubs-arm.cc +1182 -402
  112. data/vendor/v8/src/arm/code-stubs-arm.h +20 -54
  113. data/vendor/v8/src/arm/codegen-arm.cc +159 -106
  114. data/vendor/v8/src/arm/codegen-arm.h +6 -6
  115. data/vendor/v8/src/arm/constants-arm.h +16 -1
  116. data/vendor/v8/src/arm/cpu-arm.cc +7 -5
  117. data/vendor/v8/src/arm/debug-arm.cc +6 -4
  118. data/vendor/v8/src/arm/deoptimizer-arm.cc +51 -14
  119. data/vendor/v8/src/arm/disasm-arm.cc +47 -15
  120. data/vendor/v8/src/arm/frames-arm.h +1 -1
  121. data/vendor/v8/src/arm/full-codegen-arm.cc +724 -408
  122. data/vendor/v8/src/arm/ic-arm.cc +90 -85
  123. data/vendor/v8/src/arm/lithium-arm.cc +140 -69
  124. data/vendor/v8/src/arm/lithium-arm.h +161 -46
  125. data/vendor/v8/src/arm/lithium-codegen-arm.cc +567 -297
  126. data/vendor/v8/src/arm/lithium-codegen-arm.h +21 -9
  127. data/vendor/v8/src/arm/lithium-gap-resolver-arm.cc +2 -0
  128. data/vendor/v8/src/arm/macro-assembler-arm.cc +457 -96
  129. data/vendor/v8/src/arm/macro-assembler-arm.h +115 -18
  130. data/vendor/v8/src/arm/regexp-macro-assembler-arm.cc +20 -13
  131. data/vendor/v8/src/arm/regexp-macro-assembler-arm.h +1 -0
  132. data/vendor/v8/src/arm/simulator-arm.cc +184 -101
  133. data/vendor/v8/src/arm/simulator-arm.h +26 -21
  134. data/vendor/v8/src/arm/stub-cache-arm.cc +450 -467
  135. data/vendor/v8/src/arm/virtual-frame-arm.cc +14 -12
  136. data/vendor/v8/src/arm/virtual-frame-arm.h +11 -8
  137. data/vendor/v8/src/array.js +35 -18
  138. data/vendor/v8/src/assembler.cc +186 -92
  139. data/vendor/v8/src/assembler.h +106 -69
  140. data/vendor/v8/src/ast-inl.h +5 -0
  141. data/vendor/v8/src/ast.cc +46 -35
  142. data/vendor/v8/src/ast.h +107 -50
  143. data/vendor/v8/src/atomicops.h +2 -0
  144. data/vendor/v8/src/atomicops_internals_mips_gcc.h +169 -0
  145. data/vendor/v8/src/bootstrapper.cc +649 -399
  146. data/vendor/v8/src/bootstrapper.h +94 -27
  147. data/vendor/v8/src/builtins.cc +359 -227
  148. data/vendor/v8/src/builtins.h +157 -123
  149. data/vendor/v8/src/checks.cc +2 -2
  150. data/vendor/v8/src/checks.h +4 -0
  151. data/vendor/v8/src/code-stubs.cc +27 -17
  152. data/vendor/v8/src/code-stubs.h +38 -17
  153. data/vendor/v8/src/codegen-inl.h +5 -1
  154. data/vendor/v8/src/codegen.cc +27 -17
  155. data/vendor/v8/src/codegen.h +9 -9
  156. data/vendor/v8/src/compilation-cache.cc +92 -206
  157. data/vendor/v8/src/compilation-cache.h +205 -30
  158. data/vendor/v8/src/compiler.cc +107 -120
  159. data/vendor/v8/src/compiler.h +17 -2
  160. data/vendor/v8/src/contexts.cc +22 -15
  161. data/vendor/v8/src/contexts.h +14 -8
  162. data/vendor/v8/src/conversions.cc +86 -30
  163. data/vendor/v8/src/counters.cc +19 -4
  164. data/vendor/v8/src/counters.h +28 -16
  165. data/vendor/v8/src/cpu-profiler-inl.h +4 -3
  166. data/vendor/v8/src/cpu-profiler.cc +123 -72
  167. data/vendor/v8/src/cpu-profiler.h +33 -19
  168. data/vendor/v8/src/cpu.h +2 -0
  169. data/vendor/v8/src/d8-debug.cc +3 -3
  170. data/vendor/v8/src/d8-debug.h +7 -6
  171. data/vendor/v8/src/d8-posix.cc +2 -0
  172. data/vendor/v8/src/d8.cc +22 -12
  173. data/vendor/v8/src/d8.gyp +3 -0
  174. data/vendor/v8/src/d8.js +618 -0
  175. data/vendor/v8/src/data-flow.h +3 -3
  176. data/vendor/v8/src/dateparser.h +4 -2
  177. data/vendor/v8/src/debug-agent.cc +10 -9
  178. data/vendor/v8/src/debug-agent.h +9 -11
  179. data/vendor/v8/src/debug-debugger.js +121 -0
  180. data/vendor/v8/src/debug.cc +331 -227
  181. data/vendor/v8/src/debug.h +248 -219
  182. data/vendor/v8/src/deoptimizer.cc +173 -62
  183. data/vendor/v8/src/deoptimizer.h +119 -19
  184. data/vendor/v8/src/disasm.h +3 -0
  185. data/vendor/v8/src/disassembler.cc +10 -9
  186. data/vendor/v8/src/execution.cc +185 -129
  187. data/vendor/v8/src/execution.h +47 -78
  188. data/vendor/v8/src/extensions/experimental/break-iterator.cc +250 -0
  189. data/vendor/v8/src/extensions/experimental/break-iterator.h +89 -0
  190. data/vendor/v8/src/extensions/experimental/experimental.gyp +2 -0
  191. data/vendor/v8/src/extensions/experimental/i18n-extension.cc +22 -2
  192. data/vendor/v8/src/extensions/externalize-string-extension.cc +2 -2
  193. data/vendor/v8/src/extensions/gc-extension.cc +1 -1
  194. data/vendor/v8/src/factory.cc +261 -154
  195. data/vendor/v8/src/factory.h +162 -158
  196. data/vendor/v8/src/flag-definitions.h +17 -11
  197. data/vendor/v8/src/frame-element.cc +0 -5
  198. data/vendor/v8/src/frame-element.h +9 -13
  199. data/vendor/v8/src/frames-inl.h +7 -0
  200. data/vendor/v8/src/frames.cc +56 -46
  201. data/vendor/v8/src/frames.h +36 -25
  202. data/vendor/v8/src/full-codegen.cc +15 -24
  203. data/vendor/v8/src/full-codegen.h +13 -41
  204. data/vendor/v8/src/func-name-inferrer.cc +7 -6
  205. data/vendor/v8/src/func-name-inferrer.h +1 -1
  206. data/vendor/v8/src/gdb-jit.cc +1 -0
  207. data/vendor/v8/src/global-handles.cc +118 -56
  208. data/vendor/v8/src/global-handles.h +98 -40
  209. data/vendor/v8/src/globals.h +2 -2
  210. data/vendor/v8/src/handles-inl.h +106 -9
  211. data/vendor/v8/src/handles.cc +220 -157
  212. data/vendor/v8/src/handles.h +38 -59
  213. data/vendor/v8/src/hashmap.h +3 -3
  214. data/vendor/v8/src/heap-inl.h +141 -25
  215. data/vendor/v8/src/heap-profiler.cc +117 -63
  216. data/vendor/v8/src/heap-profiler.h +38 -21
  217. data/vendor/v8/src/heap.cc +805 -564
  218. data/vendor/v8/src/heap.h +640 -594
  219. data/vendor/v8/src/hydrogen-instructions.cc +216 -73
  220. data/vendor/v8/src/hydrogen-instructions.h +259 -124
  221. data/vendor/v8/src/hydrogen.cc +996 -1171
  222. data/vendor/v8/src/hydrogen.h +163 -144
  223. data/vendor/v8/src/ia32/assembler-ia32-inl.h +12 -11
  224. data/vendor/v8/src/ia32/assembler-ia32.cc +85 -39
  225. data/vendor/v8/src/ia32/assembler-ia32.h +82 -16
  226. data/vendor/v8/src/ia32/builtins-ia32.cc +64 -58
  227. data/vendor/v8/src/ia32/code-stubs-ia32.cc +248 -324
  228. data/vendor/v8/src/ia32/code-stubs-ia32.h +3 -44
  229. data/vendor/v8/src/ia32/codegen-ia32.cc +217 -165
  230. data/vendor/v8/src/ia32/codegen-ia32.h +3 -0
  231. data/vendor/v8/src/ia32/cpu-ia32.cc +6 -5
  232. data/vendor/v8/src/ia32/debug-ia32.cc +8 -5
  233. data/vendor/v8/src/ia32/deoptimizer-ia32.cc +124 -14
  234. data/vendor/v8/src/ia32/disasm-ia32.cc +85 -62
  235. data/vendor/v8/src/ia32/frames-ia32.h +1 -1
  236. data/vendor/v8/src/ia32/full-codegen-ia32.cc +348 -435
  237. data/vendor/v8/src/ia32/ic-ia32.cc +91 -91
  238. data/vendor/v8/src/ia32/lithium-codegen-ia32.cc +500 -255
  239. data/vendor/v8/src/ia32/lithium-codegen-ia32.h +13 -4
  240. data/vendor/v8/src/ia32/lithium-gap-resolver-ia32.cc +6 -0
  241. data/vendor/v8/src/ia32/lithium-ia32.cc +122 -45
  242. data/vendor/v8/src/ia32/lithium-ia32.h +128 -41
  243. data/vendor/v8/src/ia32/macro-assembler-ia32.cc +109 -84
  244. data/vendor/v8/src/ia32/macro-assembler-ia32.h +18 -9
  245. data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.cc +26 -15
  246. data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.h +1 -0
  247. data/vendor/v8/src/ia32/register-allocator-ia32.cc +30 -30
  248. data/vendor/v8/src/ia32/simulator-ia32.h +4 -4
  249. data/vendor/v8/src/ia32/stub-cache-ia32.cc +383 -400
  250. data/vendor/v8/src/ia32/virtual-frame-ia32.cc +36 -13
  251. data/vendor/v8/src/ia32/virtual-frame-ia32.h +11 -5
  252. data/vendor/v8/src/ic-inl.h +12 -2
  253. data/vendor/v8/src/ic.cc +304 -221
  254. data/vendor/v8/src/ic.h +115 -58
  255. data/vendor/v8/src/interpreter-irregexp.cc +25 -21
  256. data/vendor/v8/src/interpreter-irregexp.h +2 -1
  257. data/vendor/v8/src/isolate.cc +883 -0
  258. data/vendor/v8/src/isolate.h +1304 -0
  259. data/vendor/v8/src/json.js +10 -10
  260. data/vendor/v8/src/jsregexp.cc +111 -80
  261. data/vendor/v8/src/jsregexp.h +6 -7
  262. data/vendor/v8/src/jump-target-heavy.cc +5 -8
  263. data/vendor/v8/src/jump-target-heavy.h +0 -6
  264. data/vendor/v8/src/jump-target-inl.h +1 -1
  265. data/vendor/v8/src/jump-target-light.cc +3 -3
  266. data/vendor/v8/src/lithium-allocator-inl.h +2 -0
  267. data/vendor/v8/src/lithium-allocator.cc +42 -30
  268. data/vendor/v8/src/lithium-allocator.h +8 -22
  269. data/vendor/v8/src/lithium.cc +1 -0
  270. data/vendor/v8/src/liveedit.cc +141 -99
  271. data/vendor/v8/src/liveedit.h +7 -2
  272. data/vendor/v8/src/liveobjectlist-inl.h +90 -0
  273. data/vendor/v8/src/liveobjectlist.cc +2537 -1
  274. data/vendor/v8/src/liveobjectlist.h +245 -35
  275. data/vendor/v8/src/log-utils.cc +122 -35
  276. data/vendor/v8/src/log-utils.h +33 -36
  277. data/vendor/v8/src/log.cc +299 -241
  278. data/vendor/v8/src/log.h +177 -110
  279. data/vendor/v8/src/mark-compact.cc +612 -470
  280. data/vendor/v8/src/mark-compact.h +153 -80
  281. data/vendor/v8/src/messages.cc +16 -14
  282. data/vendor/v8/src/messages.js +30 -7
  283. data/vendor/v8/src/mips/assembler-mips-inl.h +155 -35
  284. data/vendor/v8/src/mips/assembler-mips.cc +1093 -219
  285. data/vendor/v8/src/mips/assembler-mips.h +552 -153
  286. data/vendor/v8/src/mips/builtins-mips.cc +43 -100
  287. data/vendor/v8/src/mips/code-stubs-mips.cc +752 -0
  288. data/vendor/v8/src/mips/code-stubs-mips.h +511 -0
  289. data/vendor/v8/src/mips/codegen-mips-inl.h +8 -14
  290. data/vendor/v8/src/mips/codegen-mips.cc +672 -896
  291. data/vendor/v8/src/mips/codegen-mips.h +271 -69
  292. data/vendor/v8/src/mips/constants-mips.cc +44 -20
  293. data/vendor/v8/src/mips/constants-mips.h +238 -40
  294. data/vendor/v8/src/mips/cpu-mips.cc +20 -3
  295. data/vendor/v8/src/mips/debug-mips.cc +35 -7
  296. data/vendor/v8/src/mips/deoptimizer-mips.cc +91 -0
  297. data/vendor/v8/src/mips/disasm-mips.cc +329 -93
  298. data/vendor/v8/src/mips/frames-mips.cc +2 -50
  299. data/vendor/v8/src/mips/frames-mips.h +24 -9
  300. data/vendor/v8/src/mips/full-codegen-mips.cc +473 -23
  301. data/vendor/v8/src/mips/ic-mips.cc +81 -45
  302. data/vendor/v8/src/mips/jump-target-mips.cc +11 -106
  303. data/vendor/v8/src/mips/lithium-codegen-mips.h +65 -0
  304. data/vendor/v8/src/mips/lithium-mips.h +304 -0
  305. data/vendor/v8/src/mips/macro-assembler-mips.cc +2391 -390
  306. data/vendor/v8/src/mips/macro-assembler-mips.h +718 -121
  307. data/vendor/v8/src/mips/regexp-macro-assembler-mips.cc +478 -0
  308. data/vendor/v8/src/mips/regexp-macro-assembler-mips.h +250 -0
  309. data/vendor/v8/src/mips/register-allocator-mips-inl.h +0 -3
  310. data/vendor/v8/src/mips/register-allocator-mips.h +3 -2
  311. data/vendor/v8/src/mips/simulator-mips.cc +1009 -221
  312. data/vendor/v8/src/mips/simulator-mips.h +119 -36
  313. data/vendor/v8/src/mips/stub-cache-mips.cc +331 -148
  314. data/vendor/v8/src/mips/{fast-codegen-mips.cc → virtual-frame-mips-inl.h} +11 -30
  315. data/vendor/v8/src/mips/virtual-frame-mips.cc +137 -149
  316. data/vendor/v8/src/mips/virtual-frame-mips.h +294 -312
  317. data/vendor/v8/src/mirror-debugger.js +9 -8
  318. data/vendor/v8/src/mksnapshot.cc +2 -2
  319. data/vendor/v8/src/objects-debug.cc +16 -16
  320. data/vendor/v8/src/objects-inl.h +421 -195
  321. data/vendor/v8/src/objects-printer.cc +7 -7
  322. data/vendor/v8/src/objects-visiting.cc +1 -1
  323. data/vendor/v8/src/objects-visiting.h +33 -12
  324. data/vendor/v8/src/objects.cc +935 -658
  325. data/vendor/v8/src/objects.h +234 -139
  326. data/vendor/v8/src/parser.cc +484 -439
  327. data/vendor/v8/src/parser.h +35 -14
  328. data/vendor/v8/src/platform-cygwin.cc +173 -107
  329. data/vendor/v8/src/platform-freebsd.cc +224 -72
  330. data/vendor/v8/src/platform-linux.cc +234 -95
  331. data/vendor/v8/src/platform-macos.cc +215 -82
  332. data/vendor/v8/src/platform-nullos.cc +9 -3
  333. data/vendor/v8/src/platform-openbsd.cc +22 -7
  334. data/vendor/v8/src/platform-posix.cc +30 -5
  335. data/vendor/v8/src/platform-solaris.cc +120 -38
  336. data/vendor/v8/src/platform-tls-mac.h +62 -0
  337. data/vendor/v8/src/platform-tls-win32.h +62 -0
  338. data/vendor/v8/src/platform-tls.h +50 -0
  339. data/vendor/v8/src/platform-win32.cc +195 -97
  340. data/vendor/v8/src/platform.h +72 -15
  341. data/vendor/v8/src/preparse-data.cc +2 -0
  342. data/vendor/v8/src/preparser-api.cc +8 -2
  343. data/vendor/v8/src/preparser.cc +1 -1
  344. data/vendor/v8/src/prettyprinter.cc +43 -52
  345. data/vendor/v8/src/prettyprinter.h +1 -1
  346. data/vendor/v8/src/profile-generator-inl.h +0 -28
  347. data/vendor/v8/src/profile-generator.cc +942 -685
  348. data/vendor/v8/src/profile-generator.h +210 -176
  349. data/vendor/v8/src/property.cc +6 -0
  350. data/vendor/v8/src/property.h +14 -3
  351. data/vendor/v8/src/regexp-macro-assembler-irregexp.cc +1 -1
  352. data/vendor/v8/src/regexp-macro-assembler.cc +28 -19
  353. data/vendor/v8/src/regexp-macro-assembler.h +11 -6
  354. data/vendor/v8/src/regexp-stack.cc +18 -10
  355. data/vendor/v8/src/regexp-stack.h +45 -21
  356. data/vendor/v8/src/regexp.js +3 -3
  357. data/vendor/v8/src/register-allocator-inl.h +3 -3
  358. data/vendor/v8/src/register-allocator.cc +1 -7
  359. data/vendor/v8/src/register-allocator.h +5 -15
  360. data/vendor/v8/src/rewriter.cc +2 -1
  361. data/vendor/v8/src/runtime-profiler.cc +158 -128
  362. data/vendor/v8/src/runtime-profiler.h +131 -15
  363. data/vendor/v8/src/runtime.cc +2409 -1692
  364. data/vendor/v8/src/runtime.h +93 -17
  365. data/vendor/v8/src/safepoint-table.cc +3 -0
  366. data/vendor/v8/src/safepoint-table.h +9 -3
  367. data/vendor/v8/src/scanner-base.cc +21 -28
  368. data/vendor/v8/src/scanner-base.h +22 -11
  369. data/vendor/v8/src/scanner.cc +3 -5
  370. data/vendor/v8/src/scanner.h +4 -2
  371. data/vendor/v8/src/scopeinfo.cc +11 -16
  372. data/vendor/v8/src/scopeinfo.h +26 -15
  373. data/vendor/v8/src/scopes.cc +67 -37
  374. data/vendor/v8/src/scopes.h +26 -12
  375. data/vendor/v8/src/serialize.cc +193 -154
  376. data/vendor/v8/src/serialize.h +41 -36
  377. data/vendor/v8/src/small-pointer-list.h +163 -0
  378. data/vendor/v8/src/snapshot-common.cc +1 -1
  379. data/vendor/v8/src/snapshot.h +3 -1
  380. data/vendor/v8/src/spaces-inl.h +30 -25
  381. data/vendor/v8/src/spaces.cc +263 -370
  382. data/vendor/v8/src/spaces.h +178 -166
  383. data/vendor/v8/src/string-search.cc +4 -3
  384. data/vendor/v8/src/string-search.h +21 -20
  385. data/vendor/v8/src/string-stream.cc +32 -24
  386. data/vendor/v8/src/string.js +7 -7
  387. data/vendor/v8/src/stub-cache.cc +324 -248
  388. data/vendor/v8/src/stub-cache.h +181 -155
  389. data/vendor/v8/src/token.cc +3 -3
  390. data/vendor/v8/src/token.h +3 -3
  391. data/vendor/v8/src/top.cc +218 -390
  392. data/vendor/v8/src/type-info.cc +98 -32
  393. data/vendor/v8/src/type-info.h +10 -3
  394. data/vendor/v8/src/unicode.cc +1 -1
  395. data/vendor/v8/src/unicode.h +1 -1
  396. data/vendor/v8/src/utils.h +3 -0
  397. data/vendor/v8/src/v8-counters.cc +18 -11
  398. data/vendor/v8/src/v8-counters.h +34 -13
  399. data/vendor/v8/src/v8.cc +66 -121
  400. data/vendor/v8/src/v8.h +7 -4
  401. data/vendor/v8/src/v8globals.h +18 -12
  402. data/vendor/v8/src/{memory.h → v8memory.h} +0 -0
  403. data/vendor/v8/src/v8natives.js +59 -18
  404. data/vendor/v8/src/v8threads.cc +127 -114
  405. data/vendor/v8/src/v8threads.h +42 -35
  406. data/vendor/v8/src/v8utils.h +2 -39
  407. data/vendor/v8/src/variables.h +1 -1
  408. data/vendor/v8/src/version.cc +26 -5
  409. data/vendor/v8/src/version.h +4 -0
  410. data/vendor/v8/src/virtual-frame-heavy-inl.h +2 -4
  411. data/vendor/v8/src/virtual-frame-light-inl.h +5 -4
  412. data/vendor/v8/src/vm-state-inl.h +21 -17
  413. data/vendor/v8/src/vm-state.h +7 -5
  414. data/vendor/v8/src/win32-headers.h +1 -0
  415. data/vendor/v8/src/x64/assembler-x64-inl.h +12 -11
  416. data/vendor/v8/src/x64/assembler-x64.cc +80 -40
  417. data/vendor/v8/src/x64/assembler-x64.h +67 -17
  418. data/vendor/v8/src/x64/builtins-x64.cc +34 -33
  419. data/vendor/v8/src/x64/code-stubs-x64.cc +636 -377
  420. data/vendor/v8/src/x64/code-stubs-x64.h +14 -48
  421. data/vendor/v8/src/x64/codegen-x64-inl.h +1 -1
  422. data/vendor/v8/src/x64/codegen-x64.cc +158 -136
  423. data/vendor/v8/src/x64/codegen-x64.h +4 -1
  424. data/vendor/v8/src/x64/cpu-x64.cc +7 -5
  425. data/vendor/v8/src/x64/debug-x64.cc +8 -6
  426. data/vendor/v8/src/x64/deoptimizer-x64.cc +195 -20
  427. data/vendor/v8/src/x64/disasm-x64.cc +42 -23
  428. data/vendor/v8/src/x64/frames-x64.cc +1 -1
  429. data/vendor/v8/src/x64/frames-x64.h +2 -2
  430. data/vendor/v8/src/x64/full-codegen-x64.cc +780 -218
  431. data/vendor/v8/src/x64/ic-x64.cc +77 -79
  432. data/vendor/v8/src/x64/jump-target-x64.cc +1 -1
  433. data/vendor/v8/src/x64/lithium-codegen-x64.cc +698 -181
  434. data/vendor/v8/src/x64/lithium-codegen-x64.h +31 -6
  435. data/vendor/v8/src/x64/lithium-x64.cc +136 -54
  436. data/vendor/v8/src/x64/lithium-x64.h +142 -51
  437. data/vendor/v8/src/x64/macro-assembler-x64.cc +456 -187
  438. data/vendor/v8/src/x64/macro-assembler-x64.h +166 -34
  439. data/vendor/v8/src/x64/regexp-macro-assembler-x64.cc +44 -28
  440. data/vendor/v8/src/x64/regexp-macro-assembler-x64.h +8 -4
  441. data/vendor/v8/src/x64/register-allocator-x64-inl.h +3 -3
  442. data/vendor/v8/src/x64/register-allocator-x64.cc +12 -8
  443. data/vendor/v8/src/x64/simulator-x64.h +5 -5
  444. data/vendor/v8/src/x64/stub-cache-x64.cc +299 -344
  445. data/vendor/v8/src/x64/virtual-frame-x64.cc +37 -13
  446. data/vendor/v8/src/x64/virtual-frame-x64.h +13 -7
  447. data/vendor/v8/src/zone-inl.h +49 -3
  448. data/vendor/v8/src/zone.cc +42 -41
  449. data/vendor/v8/src/zone.h +37 -34
  450. data/vendor/v8/test/benchmarks/testcfg.py +100 -0
  451. data/vendor/v8/test/cctest/SConscript +5 -4
  452. data/vendor/v8/test/cctest/cctest.h +3 -2
  453. data/vendor/v8/test/cctest/cctest.status +6 -11
  454. data/vendor/v8/test/cctest/test-accessors.cc +3 -3
  455. data/vendor/v8/test/cctest/test-alloc.cc +39 -33
  456. data/vendor/v8/test/cctest/test-api.cc +1092 -205
  457. data/vendor/v8/test/cctest/test-assembler-arm.cc +39 -25
  458. data/vendor/v8/test/cctest/test-assembler-ia32.cc +36 -37
  459. data/vendor/v8/test/cctest/test-assembler-mips.cc +1098 -40
  460. data/vendor/v8/test/cctest/test-assembler-x64.cc +32 -25
  461. data/vendor/v8/test/cctest/test-ast.cc +1 -0
  462. data/vendor/v8/test/cctest/test-circular-queue.cc +8 -5
  463. data/vendor/v8/test/cctest/test-compiler.cc +24 -24
  464. data/vendor/v8/test/cctest/test-cpu-profiler.cc +140 -5
  465. data/vendor/v8/test/cctest/test-dataflow.cc +1 -0
  466. data/vendor/v8/test/cctest/test-debug.cc +136 -77
  467. data/vendor/v8/test/cctest/test-decls.cc +1 -1
  468. data/vendor/v8/test/cctest/test-deoptimization.cc +25 -24
  469. data/vendor/v8/test/cctest/test-disasm-arm.cc +9 -4
  470. data/vendor/v8/test/cctest/test-disasm-ia32.cc +10 -8
  471. data/vendor/v8/test/cctest/test-func-name-inference.cc +10 -4
  472. data/vendor/v8/test/cctest/test-heap-profiler.cc +226 -164
  473. data/vendor/v8/test/cctest/test-heap.cc +240 -217
  474. data/vendor/v8/test/cctest/test-liveedit.cc +1 -0
  475. data/vendor/v8/test/cctest/test-log-stack-tracer.cc +18 -20
  476. data/vendor/v8/test/cctest/test-log.cc +114 -108
  477. data/vendor/v8/test/cctest/test-macro-assembler-x64.cc +247 -177
  478. data/vendor/v8/test/cctest/test-mark-compact.cc +129 -90
  479. data/vendor/v8/test/cctest/test-parsing.cc +15 -14
  480. data/vendor/v8/test/cctest/test-platform-linux.cc +1 -0
  481. data/vendor/v8/test/cctest/test-platform-tls.cc +66 -0
  482. data/vendor/v8/test/cctest/test-platform-win32.cc +1 -0
  483. data/vendor/v8/test/cctest/test-profile-generator.cc +1 -1
  484. data/vendor/v8/test/cctest/test-regexp.cc +53 -41
  485. data/vendor/v8/test/cctest/test-reloc-info.cc +18 -11
  486. data/vendor/v8/test/cctest/test-serialize.cc +44 -43
  487. data/vendor/v8/test/cctest/test-sockets.cc +8 -3
  488. data/vendor/v8/test/cctest/test-spaces.cc +47 -29
  489. data/vendor/v8/test/cctest/test-strings.cc +20 -20
  490. data/vendor/v8/test/cctest/test-thread-termination.cc +8 -3
  491. data/vendor/v8/test/cctest/test-threads.cc +5 -3
  492. data/vendor/v8/test/cctest/test-utils.cc +5 -4
  493. data/vendor/v8/test/cctest/testcfg.py +7 -3
  494. data/vendor/v8/test/es5conform/es5conform.status +2 -77
  495. data/vendor/v8/test/es5conform/testcfg.py +1 -1
  496. data/vendor/v8/test/message/testcfg.py +1 -1
  497. data/vendor/v8/test/mjsunit/accessors-on-global-object.js +3 -3
  498. data/vendor/v8/test/mjsunit/array-concat.js +43 -1
  499. data/vendor/v8/test/mjsunit/array-join.js +25 -0
  500. data/vendor/v8/test/mjsunit/bitops-info.js +7 -1
  501. data/vendor/v8/test/mjsunit/compiler/array-length.js +2 -2
  502. data/vendor/v8/test/mjsunit/compiler/global-accessors.js +47 -0
  503. data/vendor/v8/test/mjsunit/compiler/pic.js +1 -1
  504. data/vendor/v8/test/mjsunit/compiler/regress-loadfield.js +65 -0
  505. data/vendor/v8/test/mjsunit/math-sqrt.js +5 -1
  506. data/vendor/v8/test/mjsunit/mjsunit.js +59 -8
  507. data/vendor/v8/test/mjsunit/mjsunit.status +0 -12
  508. data/vendor/v8/test/mjsunit/mul-exhaustive.js +129 -11
  509. data/vendor/v8/test/mjsunit/negate-zero.js +1 -1
  510. data/vendor/v8/test/mjsunit/object-freeze.js +5 -13
  511. data/vendor/v8/test/mjsunit/object-prevent-extensions.js +9 -50
  512. data/vendor/v8/test/mjsunit/object-seal.js +4 -13
  513. data/vendor/v8/test/mjsunit/override-eval-with-non-function.js +36 -0
  514. data/vendor/v8/test/mjsunit/regress/regress-1145.js +54 -0
  515. data/vendor/v8/test/mjsunit/regress/regress-1172-bis.js +37 -0
  516. data/vendor/v8/test/mjsunit/regress/regress-1181.js +54 -0
  517. data/vendor/v8/test/mjsunit/regress/regress-1207.js +35 -0
  518. data/vendor/v8/test/mjsunit/regress/regress-1209.js +34 -0
  519. data/vendor/v8/test/mjsunit/regress/regress-1210.js +48 -0
  520. data/vendor/v8/test/mjsunit/regress/regress-1213.js +43 -0
  521. data/vendor/v8/test/mjsunit/regress/regress-1218.js +29 -0
  522. data/vendor/v8/test/mjsunit/regress/regress-1229.js +79 -0
  523. data/vendor/v8/test/mjsunit/regress/regress-1233.js +47 -0
  524. data/vendor/v8/test/mjsunit/regress/regress-1236.js +34 -0
  525. data/vendor/v8/test/mjsunit/regress/regress-1237.js +36 -0
  526. data/vendor/v8/test/mjsunit/regress/regress-1240.js +39 -0
  527. data/vendor/v8/test/mjsunit/regress/regress-1257.js +58 -0
  528. data/vendor/v8/test/mjsunit/regress/regress-1278.js +69 -0
  529. data/vendor/v8/test/mjsunit/regress/regress-create-exception.js +1 -0
  530. data/vendor/v8/test/mjsunit/regress/regress-lazy-deopt-reloc.js +52 -0
  531. data/vendor/v8/test/mjsunit/sin-cos.js +15 -10
  532. data/vendor/v8/test/mjsunit/smi-negative-zero.js +2 -2
  533. data/vendor/v8/test/mjsunit/str-to-num.js +1 -1
  534. data/vendor/v8/test/mjsunit/strict-mode.js +435 -0
  535. data/vendor/v8/test/mjsunit/testcfg.py +23 -6
  536. data/vendor/v8/test/mozilla/mozilla.status +0 -2
  537. data/vendor/v8/test/mozilla/testcfg.py +1 -1
  538. data/vendor/v8/test/preparser/empty.js +28 -0
  539. data/vendor/v8/test/preparser/functions-only.js +38 -0
  540. data/vendor/v8/test/preparser/non-alphanum.js +34 -0
  541. data/vendor/v8/test/preparser/symbols-only.js +49 -0
  542. data/vendor/v8/test/preparser/testcfg.py +90 -0
  543. data/vendor/v8/test/sputnik/testcfg.py +1 -1
  544. data/vendor/v8/test/test262/README +16 -0
  545. data/vendor/v8/test/test262/harness-adapt.js +80 -0
  546. data/vendor/v8/test/test262/test262.status +1506 -0
  547. data/vendor/v8/test/test262/testcfg.py +123 -0
  548. data/vendor/v8/tools/freebsd-tick-processor +10 -0
  549. data/vendor/v8/tools/gyp/v8.gyp +8 -33
  550. data/vendor/v8/tools/linux-tick-processor +5 -3
  551. data/vendor/v8/tools/test.py +37 -14
  552. data/vendor/v8/tools/tickprocessor.js +22 -8
  553. data/vendor/v8/tools/visual_studio/v8_base.vcproj +13 -1
  554. data/vendor/v8/tools/visual_studio/v8_base_arm.vcproj +5 -1
  555. data/vendor/v8/tools/visual_studio/v8_base_x64.vcproj +5 -1
  556. data/vendor/v8/tools/visual_studio/x64.vsprops +1 -0
  557. metadata +1495 -1341
  558. data/ext/extconf.rb +0 -22
  559. data/ext/mustang.cpp +0 -58
  560. data/vendor/v8/src/top.h +0 -608
@@ -28,6 +28,7 @@
28
28
  #ifndef V8_FRAMES_H_
29
29
  #define V8_FRAMES_H_
30
30
 
31
+ #include "handles.h"
31
32
  #include "safepoint-table.h"
32
33
 
33
34
  namespace v8 {
@@ -44,11 +45,10 @@ int JSCallerSavedCode(int n);
44
45
 
45
46
  // Forward declarations.
46
47
  class StackFrameIterator;
47
- class Top;
48
48
  class ThreadLocalTop;
49
+ class Isolate;
49
50
 
50
-
51
- class PcToCodeCache : AllStatic {
51
+ class PcToCodeCache {
52
52
  public:
53
53
  struct PcToCodeCacheEntry {
54
54
  Address pc;
@@ -56,22 +56,28 @@ class PcToCodeCache : AllStatic {
56
56
  SafepointEntry safepoint_entry;
57
57
  };
58
58
 
59
- static PcToCodeCacheEntry* cache(int index) {
60
- return &cache_[index];
59
+ explicit PcToCodeCache(Isolate* isolate) : isolate_(isolate) {
60
+ Flush();
61
61
  }
62
62
 
63
- static Code* GcSafeFindCodeForPc(Address pc);
64
- static Code* GcSafeCastToCode(HeapObject* object, Address pc);
63
+ Code* GcSafeFindCodeForPc(Address pc);
64
+ Code* GcSafeCastToCode(HeapObject* object, Address pc);
65
65
 
66
- static void FlushPcToCodeCache() {
66
+ void Flush() {
67
67
  memset(&cache_[0], 0, sizeof(cache_));
68
68
  }
69
69
 
70
- static PcToCodeCacheEntry* GetCacheEntry(Address pc);
70
+ PcToCodeCacheEntry* GetCacheEntry(Address pc);
71
71
 
72
72
  private:
73
+ PcToCodeCacheEntry* cache(int index) { return &cache_[index]; }
74
+
75
+ Isolate* isolate_;
76
+
73
77
  static const int kPcToCodeCacheSize = 1024;
74
- static PcToCodeCacheEntry cache_[kPcToCodeCacheSize];
78
+ PcToCodeCacheEntry cache_[kPcToCodeCacheSize];
79
+
80
+ DISALLOW_COPY_AND_ASSIGN(PcToCodeCache);
75
81
  };
76
82
 
77
83
 
@@ -199,12 +205,12 @@ class StackFrame BASE_EMBEDDED {
199
205
  virtual Code* unchecked_code() const = 0;
200
206
 
201
207
  // Get the code associated with this frame.
202
- Code* code() const { return GetContainingCode(pc()); }
208
+ Code* LookupCode(Isolate* isolate) const {
209
+ return GetContainingCode(isolate, pc());
210
+ }
203
211
 
204
212
  // Get the code object that contains the given pc.
205
- static Code* GetContainingCode(Address pc) {
206
- return PcToCodeCache::GetCacheEntry(pc)->code;
207
- }
213
+ static inline Code* GetContainingCode(Isolate* isolate, Address pc);
208
214
 
209
215
  // Get the code object containing the given pc and fill in the
210
216
  // safepoint entry and the number of stack slots. The pc must be at
@@ -424,7 +430,7 @@ class FrameSummary BASE_EMBEDDED {
424
430
  Handle<Object> receiver() { return receiver_; }
425
431
  Handle<JSFunction> function() { return function_; }
426
432
  Handle<Code> code() { return code_; }
427
- Address pc() { return reinterpret_cast<Address>(*code_) + offset_; }
433
+ Address pc() { return code_->address() + offset_; }
428
434
  int offset() { return offset_; }
429
435
  bool is_constructor() { return is_constructor_; }
430
436
 
@@ -452,12 +458,6 @@ class JavaScriptFrame: public StandardFrame {
452
458
  Object* GetParameter(int index) const;
453
459
  int ComputeParametersCount() const;
454
460
 
455
- // Temporary way of getting access to the number of parameters
456
- // passed on the stack by the caller. Once argument adaptor frames
457
- // has been introduced on ARM, this number will always match the
458
- // computed parameters count.
459
- int GetProvidedParametersCount() const;
460
-
461
461
  // Check if this frame is a constructor frame invoked through 'new'.
462
462
  bool IsConstructor() const;
463
463
 
@@ -618,7 +618,7 @@ class StackFrameIterator BASE_EMBEDDED {
618
618
  // An iterator that can start from a given FP address.
619
619
  // If use_top, then work as usual, if fp isn't NULL, use it,
620
620
  // otherwise, do nothing.
621
- StackFrameIterator(bool use_top, Address fp, Address sp);
621
+ StackFrameIterator(Isolate* isolate, bool use_top, Address fp, Address sp);
622
622
 
623
623
  StackFrame* frame() const {
624
624
  ASSERT(!done());
@@ -681,6 +681,13 @@ class JavaScriptFrameIteratorTemp BASE_EMBEDDED {
681
681
  if (!done()) Advance();
682
682
  }
683
683
 
684
+ JavaScriptFrameIteratorTemp(Isolate* isolate,
685
+ Address fp, Address sp,
686
+ Address low_bound, Address high_bound) :
687
+ iterator_(isolate, fp, sp, low_bound, high_bound) {
688
+ if (!done()) Advance();
689
+ }
690
+
684
691
  inline JavaScriptFrame* frame() const;
685
692
 
686
693
  bool done() const { return iterator_.done(); }
@@ -718,7 +725,8 @@ class StackTraceFrameIterator: public JavaScriptFrameIterator {
718
725
 
719
726
  class SafeStackFrameIterator BASE_EMBEDDED {
720
727
  public:
721
- SafeStackFrameIterator(Address fp, Address sp,
728
+ SafeStackFrameIterator(Isolate* isolate,
729
+ Address fp, Address sp,
722
730
  Address low_bound, Address high_bound);
723
731
 
724
732
  StackFrame* frame() const {
@@ -768,7 +776,8 @@ class SafeStackFrameIterator BASE_EMBEDDED {
768
776
  bool CanIterateHandles(StackFrame* frame, StackHandler* handler);
769
777
  bool IsValidFrame(StackFrame* frame) const;
770
778
  bool IsValidCaller(StackFrame* frame);
771
- static bool IsValidTop(Address low_bound, Address high_bound);
779
+ static bool IsValidTop(Isolate* isolate,
780
+ Address low_bound, Address high_bound);
772
781
 
773
782
  // This is a nasty hack to make sure the active count is incremented
774
783
  // before the constructor for the embedded iterator is invoked. This
@@ -782,6 +791,7 @@ class SafeStackFrameIterator BASE_EMBEDDED {
782
791
  };
783
792
 
784
793
  ActiveCountMaintainer maintainer_;
794
+ // TODO(isolates): this is dangerous.
785
795
  static int active_count_;
786
796
  StackAddressValidator stack_validator_;
787
797
  const bool is_valid_top_;
@@ -799,7 +809,8 @@ typedef JavaScriptFrameIteratorTemp<SafeStackFrameIterator>
799
809
 
800
810
  class SafeStackTraceFrameIterator: public SafeJavaScriptFrameIterator {
801
811
  public:
802
- explicit SafeStackTraceFrameIterator(Address fp, Address sp,
812
+ explicit SafeStackTraceFrameIterator(Isolate* isolate,
813
+ Address fp, Address sp,
803
814
  Address low_bound, Address high_bound);
804
815
  void Advance();
805
816
  };
@@ -275,17 +275,18 @@ void BreakableStatementChecker::VisitThisFunction(ThisFunction* expr) {
275
275
  #define __ ACCESS_MASM(masm())
276
276
 
277
277
  bool FullCodeGenerator::MakeCode(CompilationInfo* info) {
278
+ Isolate* isolate = info->isolate();
278
279
  Handle<Script> script = info->script();
279
280
  if (!script->IsUndefined() && !script->source()->IsUndefined()) {
280
281
  int len = String::cast(script->source())->length();
281
- Counters::total_full_codegen_source_size.Increment(len);
282
+ isolate->counters()->total_full_codegen_source_size()->Increment(len);
282
283
  }
283
284
  if (FLAG_trace_codegen) {
284
285
  PrintF("Full Compiler - ");
285
286
  }
286
287
  CodeGenerator::MakeCodePrologue(info);
287
288
  const int kInitialBufferSize = 4 * KB;
288
- MacroAssembler masm(NULL, kInitialBufferSize);
289
+ MacroAssembler masm(info->isolate(), NULL, kInitialBufferSize);
289
290
  #ifdef ENABLE_GDB_JIT_INTERFACE
290
291
  masm.positions_recorder()->StartGDBJITLineInfoRecording();
291
292
  #endif
@@ -293,7 +294,7 @@ bool FullCodeGenerator::MakeCode(CompilationInfo* info) {
293
294
  FullCodeGenerator cgen(&masm);
294
295
  cgen.Generate(info);
295
296
  if (cgen.HasStackOverflow()) {
296
- ASSERT(!Top::has_pending_exception());
297
+ ASSERT(!isolate->has_pending_exception());
297
298
  return false;
298
299
  }
299
300
  unsigned table_offset = cgen.EmitStackCheckTable();
@@ -343,7 +344,8 @@ void FullCodeGenerator::PopulateDeoptimizationData(Handle<Code> code) {
343
344
  if (!info_->HasDeoptimizationSupport()) return;
344
345
  int length = bailout_entries_.length();
345
346
  Handle<DeoptimizationOutputData> data =
346
- Factory::NewDeoptimizationOutputData(length, TENURED);
347
+ isolate()->factory()->
348
+ NewDeoptimizationOutputData(length, TENURED);
347
349
  for (int i = 0; i < length; i++) {
348
350
  data->SetAstId(i, Smi::FromInt(bailout_entries_[i].id));
349
351
  data->SetPcAndState(i, Smi::FromInt(bailout_entries_[i].pc_and_state));
@@ -545,7 +547,8 @@ void FullCodeGenerator::VisitDeclarations(
545
547
  // Compute array of global variable and function declarations.
546
548
  // Do nothing in case of no declared global functions or variables.
547
549
  if (globals > 0) {
548
- Handle<FixedArray> array = Factory::NewFixedArray(2 * globals, TENURED);
550
+ Handle<FixedArray> array =
551
+ isolate()->factory()->NewFixedArray(2 * globals, TENURED);
549
552
  for (int j = 0, i = 0; i < length; i++) {
550
553
  Declaration* decl = declarations->at(i);
551
554
  Variable* var = decl->proxy()->var();
@@ -596,7 +599,7 @@ void FullCodeGenerator::SetReturnPosition(FunctionLiteral* fun) {
596
599
  void FullCodeGenerator::SetStatementPosition(Statement* stmt) {
597
600
  if (FLAG_debug_info) {
598
601
  #ifdef ENABLE_DEBUGGER_SUPPORT
599
- if (!Debugger::IsDebuggerActive()) {
602
+ if (!isolate()->debugger()->IsDebuggerActive()) {
600
603
  CodeGenerator::RecordPositions(masm_, stmt->statement_pos());
601
604
  } else {
602
605
  // Check if the statement will be breakable without adding a debug break
@@ -624,7 +627,7 @@ void FullCodeGenerator::SetStatementPosition(Statement* stmt) {
624
627
  void FullCodeGenerator::SetExpressionPosition(Expression* expr, int pos) {
625
628
  if (FLAG_debug_info) {
626
629
  #ifdef ENABLE_DEBUGGER_SUPPORT
627
- if (!Debugger::IsDebuggerActive()) {
630
+ if (!isolate()->debugger()->IsDebuggerActive()) {
628
631
  CodeGenerator::RecordPositions(masm_, pos);
629
632
  } else {
630
633
  // Check if the expression will be breakable without adding a debug break
@@ -694,7 +697,7 @@ FullCodeGenerator::InlineFunctionGenerator
694
697
  void FullCodeGenerator::EmitInlineRuntimeCall(CallRuntime* node) {
695
698
  ZoneList<Expression*>* args = node->arguments();
696
699
  Handle<String> name = node->name();
697
- Runtime::Function* function = node->function();
700
+ const Runtime::Function* function = node->function();
698
701
  ASSERT(function != NULL);
699
702
  ASSERT(function->intrinsic_type == Runtime::INLINE);
700
703
  InlineFunctionGenerator generator =
@@ -739,25 +742,13 @@ void FullCodeGenerator::VisitBinaryOperation(BinaryOperation* expr) {
739
742
  case Token::SHL:
740
743
  case Token::SHR:
741
744
  case Token::SAR: {
742
- // Figure out if either of the operands is a constant.
743
- ConstantOperand constant = ShouldInlineSmiCase(op)
744
- ? GetConstantOperand(op, left, right)
745
- : kNoConstants;
746
-
747
- // Load only the operands that we need to materialize.
748
- if (constant == kNoConstants) {
749
- VisitForStackValue(left);
750
- VisitForAccumulatorValue(right);
751
- } else if (constant == kRightConstant) {
752
- VisitForAccumulatorValue(left);
753
- } else {
754
- ASSERT(constant == kLeftConstant);
755
- VisitForAccumulatorValue(right);
756
- }
745
+ // Load both operands.
746
+ VisitForStackValue(left);
747
+ VisitForAccumulatorValue(right);
757
748
 
758
749
  SetSourcePosition(expr->position());
759
750
  if (ShouldInlineSmiCase(op)) {
760
- EmitInlineSmiBinaryOp(expr, op, mode, left, right, constant);
751
+ EmitInlineSmiBinaryOp(expr, op, mode, left, right);
761
752
  } else {
762
753
  EmitBinaryOp(op, mode);
763
754
  }
@@ -274,12 +274,6 @@ class FullCodeGenerator: public AstVisitor {
274
274
  ForwardBailoutStack* const parent_;
275
275
  };
276
276
 
277
- enum ConstantOperand {
278
- kNoConstants,
279
- kLeftConstant,
280
- kRightConstant
281
- };
282
-
283
277
  // Type of a member function that generates inline code for a native function.
284
278
  typedef void (FullCodeGenerator::*InlineFunctionGenerator)
285
279
  (ZoneList<Expression*>*);
@@ -298,11 +292,6 @@ class FullCodeGenerator: public AstVisitor {
298
292
  // operation.
299
293
  bool ShouldInlineSmiCase(Token::Value op);
300
294
 
301
- // Compute which (if any) of the operands is a compile-time constant.
302
- ConstantOperand GetConstantOperand(Token::Value op,
303
- Expression* left,
304
- Expression* right);
305
-
306
295
  // Helper function to convert a pure value into a test context. The value
307
296
  // is expected on the stack or the accumulator, depending on the platform.
308
297
  // See the platform-specific implementation for details.
@@ -432,6 +421,14 @@ class FullCodeGenerator: public AstVisitor {
432
421
  Label* done);
433
422
  void EmitVariableLoad(Variable* expr);
434
423
 
424
+ enum ResolveEvalFlag {
425
+ SKIP_CONTEXT_LOOKUP,
426
+ PERFORM_CONTEXT_LOOKUP
427
+ };
428
+
429
+ // Expects the arguments and the function already pushed.
430
+ void EmitResolvePossiblyDirectEval(ResolveEvalFlag flag, int arg_count);
431
+
435
432
  // Platform-specific support for allocating a new closure based on
436
433
  // the given function info.
437
434
  void EmitNewClosure(Handle<SharedFunctionInfo> info, bool pretenure);
@@ -457,34 +454,7 @@ class FullCodeGenerator: public AstVisitor {
457
454
  Token::Value op,
458
455
  OverwriteMode mode,
459
456
  Expression* left,
460
- Expression* right,
461
- ConstantOperand constant);
462
-
463
- void EmitConstantSmiBinaryOp(Expression* expr,
464
- Token::Value op,
465
- OverwriteMode mode,
466
- bool left_is_constant_smi,
467
- Smi* value);
468
-
469
- void EmitConstantSmiBitOp(Expression* expr,
470
- Token::Value op,
471
- OverwriteMode mode,
472
- Smi* value);
473
-
474
- void EmitConstantSmiShiftOp(Expression* expr,
475
- Token::Value op,
476
- OverwriteMode mode,
477
- Smi* value);
478
-
479
- void EmitConstantSmiAdd(Expression* expr,
480
- OverwriteMode mode,
481
- bool left_is_constant_smi,
482
- Smi* value);
483
-
484
- void EmitConstantSmiSub(Expression* expr,
485
- OverwriteMode mode,
486
- bool left_is_constant_smi,
487
- Smi* value);
457
+ Expression* right);
488
458
 
489
459
  // Assign to the given expression as if via '='. The right-hand-side value
490
460
  // is expected in the accumulator.
@@ -531,9 +501,9 @@ class FullCodeGenerator: public AstVisitor {
531
501
 
532
502
  Handle<Script> script() { return info_->script(); }
533
503
  bool is_eval() { return info_->is_eval(); }
534
- bool is_strict() { return function()->strict_mode(); }
504
+ bool is_strict_mode() { return function()->strict_mode(); }
535
505
  StrictModeFlag strict_mode_flag() {
536
- return is_strict() ? kStrictMode : kNonStrictMode;
506
+ return is_strict_mode() ? kStrictMode : kNonStrictMode;
537
507
  }
538
508
  FunctionLiteral* function() { return info_->function(); }
539
509
  Scope* scope() { return info_->scope(); }
@@ -583,6 +553,8 @@ class FullCodeGenerator: public AstVisitor {
583
553
  codegen_->set_new_context(old_);
584
554
  }
585
555
 
556
+ Isolate* isolate() const { return codegen_->isolate(); }
557
+
586
558
  // Convert constant control flow (true or false) to the result expected for
587
559
  // this expression context.
588
560
  virtual void Plug(bool flag) const = 0;
@@ -38,21 +38,22 @@ void FuncNameInferrer::PushEnclosingName(Handle<String> name) {
38
38
  // Enclosing name is a name of a constructor function. To check
39
39
  // that it is really a constructor, we check that it is not empty
40
40
  // and starts with a capital letter.
41
- if (name->length() > 0 && Runtime::IsUpperCaseChar(name->Get(0))) {
41
+ if (name->length() > 0 && Runtime::IsUpperCaseChar(
42
+ Isolate::Current()->runtime_state(), name->Get(0))) {
42
43
  names_stack_.Add(name);
43
44
  }
44
45
  }
45
46
 
46
47
 
47
48
  void FuncNameInferrer::PushLiteralName(Handle<String> name) {
48
- if (IsOpen() && !Heap::prototype_symbol()->Equals(*name)) {
49
+ if (IsOpen() && !HEAP->prototype_symbol()->Equals(*name)) {
49
50
  names_stack_.Add(name);
50
51
  }
51
52
  }
52
53
 
53
54
 
54
55
  void FuncNameInferrer::PushVariableName(Handle<String> name) {
55
- if (IsOpen() && !Heap::result_symbol()->Equals(*name)) {
56
+ if (IsOpen() && !HEAP->result_symbol()->Equals(*name)) {
56
57
  names_stack_.Add(name);
57
58
  }
58
59
  }
@@ -60,7 +61,7 @@ void FuncNameInferrer::PushVariableName(Handle<String> name) {
60
61
 
61
62
  Handle<String> FuncNameInferrer::MakeNameFromStack() {
62
63
  if (names_stack_.is_empty()) {
63
- return Factory::empty_string();
64
+ return FACTORY->empty_string();
64
65
  } else {
65
66
  return MakeNameFromStackHelper(1, names_stack_.at(0));
66
67
  }
@@ -72,8 +73,8 @@ Handle<String> FuncNameInferrer::MakeNameFromStackHelper(int pos,
72
73
  if (pos >= names_stack_.length()) {
73
74
  return prev;
74
75
  } else {
75
- Handle<String> curr = Factory::NewConsString(dot_, names_stack_.at(pos));
76
- return MakeNameFromStackHelper(pos + 1, Factory::NewConsString(prev, curr));
76
+ Handle<String> curr = FACTORY->NewConsString(dot_, names_stack_.at(pos));
77
+ return MakeNameFromStackHelper(pos + 1, FACTORY->NewConsString(prev, curr));
77
78
  }
78
79
  }
79
80
 
@@ -47,7 +47,7 @@ class FuncNameInferrer : public ZoneObject {
47
47
  : entries_stack_(10),
48
48
  names_stack_(5),
49
49
  funcs_to_infer_(4),
50
- dot_(Factory::NewStringFromAscii(CStrVector("."))) {
50
+ dot_(FACTORY->NewStringFromAscii(CStrVector("."))) {
51
51
  }
52
52
 
53
53
  // Returns whether we have entered name collection state.
@@ -26,6 +26,7 @@
26
26
  // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
27
 
28
28
  #ifdef ENABLE_GDB_JIT_INTERFACE
29
+ #include "v8.h"
29
30
  #include "gdb-jit.h"
30
31
 
31
32
  #include "bootstrapper.h"
@@ -35,12 +35,19 @@
35
35
  namespace v8 {
36
36
  namespace internal {
37
37
 
38
+
39
+ ObjectGroup::~ObjectGroup() {
40
+ if (info_ != NULL) info_->Dispose();
41
+ }
42
+
43
+
38
44
  class GlobalHandles::Node : public Malloced {
39
45
  public:
40
46
 
41
47
  void Initialize(Object* object) {
42
48
  // Set the initial value of the handle.
43
49
  object_ = object;
50
+ class_id_ = v8::HeapProfiler::kPersistentHandleNoClassId;
44
51
  state_ = NORMAL;
45
52
  parameter_or_next_free_.parameter = NULL;
46
53
  callback_ = NULL;
@@ -57,7 +64,7 @@ class GlobalHandles::Node : public Malloced {
57
64
  }
58
65
 
59
66
  ~Node() {
60
- if (state_ != DESTROYED) Destroy();
67
+ if (state_ != DESTROYED) Destroy(Isolate::Current()->global_handles());
61
68
  #ifdef DEBUG
62
69
  // Zap the values for eager trapping.
63
70
  object_ = NULL;
@@ -66,11 +73,11 @@ class GlobalHandles::Node : public Malloced {
66
73
  #endif
67
74
  }
68
75
 
69
- void Destroy() {
76
+ void Destroy(GlobalHandles* global_handles) {
70
77
  if (state_ == WEAK || IsNearDeath()) {
71
- GlobalHandles::number_of_weak_handles_--;
78
+ global_handles->number_of_weak_handles_--;
72
79
  if (object_->IsJSGlobalObject()) {
73
- GlobalHandles::number_of_global_object_weak_handles_--;
80
+ global_handles->number_of_global_object_weak_handles_--;
74
81
  }
75
82
  }
76
83
  state_ = DESTROYED;
@@ -101,13 +108,15 @@ class GlobalHandles::Node : public Malloced {
101
108
  Handle<Object> handle() { return Handle<Object>(&object_); }
102
109
 
103
110
  // Make this handle weak.
104
- void MakeWeak(void* parameter, WeakReferenceCallback callback) {
105
- LOG(HandleEvent("GlobalHandle::MakeWeak", handle().location()));
111
+ void MakeWeak(GlobalHandles* global_handles, void* parameter,
112
+ WeakReferenceCallback callback) {
113
+ LOG(global_handles->isolate(),
114
+ HandleEvent("GlobalHandle::MakeWeak", handle().location()));
106
115
  ASSERT(state_ != DESTROYED);
107
116
  if (state_ != WEAK && !IsNearDeath()) {
108
- GlobalHandles::number_of_weak_handles_++;
117
+ global_handles->number_of_weak_handles_++;
109
118
  if (object_->IsJSGlobalObject()) {
110
- GlobalHandles::number_of_global_object_weak_handles_++;
119
+ global_handles->number_of_global_object_weak_handles_++;
111
120
  }
112
121
  }
113
122
  state_ = WEAK;
@@ -115,13 +124,14 @@ class GlobalHandles::Node : public Malloced {
115
124
  callback_ = callback;
116
125
  }
117
126
 
118
- void ClearWeakness() {
119
- LOG(HandleEvent("GlobalHandle::ClearWeakness", handle().location()));
127
+ void ClearWeakness(GlobalHandles* global_handles) {
128
+ LOG(global_handles->isolate(),
129
+ HandleEvent("GlobalHandle::ClearWeakness", handle().location()));
120
130
  ASSERT(state_ != DESTROYED);
121
131
  if (state_ == WEAK || IsNearDeath()) {
122
- GlobalHandles::number_of_weak_handles_--;
132
+ global_handles->number_of_weak_handles_--;
123
133
  if (object_->IsJSGlobalObject()) {
124
- GlobalHandles::number_of_global_object_weak_handles_--;
134
+ global_handles->number_of_global_object_weak_handles_--;
125
135
  }
126
136
  }
127
137
  state_ = NORMAL;
@@ -137,6 +147,14 @@ class GlobalHandles::Node : public Malloced {
137
147
  return state_ == WEAK;
138
148
  }
139
149
 
150
+ bool CanBeRetainer() {
151
+ return state_ != DESTROYED && state_ != NEAR_DEATH;
152
+ }
153
+
154
+ void SetWrapperClassId(uint16_t class_id) {
155
+ class_id_ = class_id;
156
+ }
157
+
140
158
  // Returns the id for this weak handle.
141
159
  void set_parameter(void* parameter) {
142
160
  ASSERT(state_ != DESTROYED);
@@ -150,12 +168,13 @@ class GlobalHandles::Node : public Malloced {
150
168
  // Returns the callback for this weak handle.
151
169
  WeakReferenceCallback callback() { return callback_; }
152
170
 
153
- bool PostGarbageCollectionProcessing() {
171
+ bool PostGarbageCollectionProcessing(Isolate* isolate,
172
+ GlobalHandles* global_handles) {
154
173
  if (state_ != Node::PENDING) return false;
155
- LOG(HandleEvent("GlobalHandle::Processing", handle().location()));
174
+ LOG(isolate, HandleEvent("GlobalHandle::Processing", handle().location()));
156
175
  WeakReferenceCallback func = callback();
157
176
  if (func == NULL) {
158
- Destroy();
177
+ Destroy(global_handles);
159
178
  return false;
160
179
  }
161
180
  void* par = parameter();
@@ -167,9 +186,9 @@ class GlobalHandles::Node : public Malloced {
167
186
  // Forbid reuse of destroyed nodes as they might be already deallocated.
168
187
  // It's fine though to reuse nodes that were destroyed in weak callback
169
188
  // as those cannot be deallocated until we are back from the callback.
170
- set_first_free(NULL);
171
- if (first_deallocated()) {
172
- first_deallocated()->set_next(head());
189
+ global_handles->set_first_free(NULL);
190
+ if (global_handles->first_deallocated()) {
191
+ global_handles->first_deallocated()->set_next(global_handles->head());
173
192
  }
174
193
  // Check that we are not passing a finalized external string to
175
194
  // the callback.
@@ -178,7 +197,7 @@ class GlobalHandles::Node : public Malloced {
178
197
  ASSERT(!object_->IsExternalTwoByteString() ||
179
198
  ExternalTwoByteString::cast(object_)->resource() != NULL);
180
199
  // Leaving V8.
181
- VMState state(EXTERNAL);
200
+ VMState state(isolate, EXTERNAL);
182
201
  func(object, par);
183
202
  }
184
203
  // Absense of explicit cleanup or revival of weak handle
@@ -190,6 +209,8 @@ class GlobalHandles::Node : public Malloced {
190
209
  // Place the handle address first to avoid offset computation.
191
210
  Object* object_; // Storage for object pointer.
192
211
 
212
+ uint16_t class_id_;
213
+
193
214
  // Transition diagram:
194
215
  // NORMAL <-> WEAK -> PENDING -> NEAR_DEATH -> { NORMAL, WEAK, DESTROYED }
195
216
  enum State {
@@ -199,7 +220,7 @@ class GlobalHandles::Node : public Malloced {
199
220
  NEAR_DEATH, // Callback has informed the handle is near death.
200
221
  DESTROYED
201
222
  };
202
- State state_;
223
+ State state_ : 4; // Need one more bit for MSVC as it treats enums as signed.
203
224
 
204
225
  private:
205
226
  // Handle specific callback.
@@ -219,7 +240,7 @@ class GlobalHandles::Node : public Malloced {
219
240
  };
220
241
 
221
242
 
222
- class GlobalHandles::Pool BASE_EMBEDDED {
243
+ class GlobalHandles::Pool {
223
244
  public:
224
245
  Pool() {
225
246
  current_ = new Chunk();
@@ -277,11 +298,27 @@ class GlobalHandles::Pool BASE_EMBEDDED {
277
298
  };
278
299
 
279
300
 
280
- static GlobalHandles::Pool pool_;
301
+ GlobalHandles::GlobalHandles(Isolate* isolate)
302
+ : isolate_(isolate),
303
+ number_of_weak_handles_(0),
304
+ number_of_global_object_weak_handles_(0),
305
+ head_(NULL),
306
+ first_free_(NULL),
307
+ first_deallocated_(NULL),
308
+ pool_(new Pool()),
309
+ post_gc_processing_count_(0),
310
+ object_groups_(4) {
311
+ }
312
+
313
+
314
+ GlobalHandles::~GlobalHandles() {
315
+ delete pool_;
316
+ pool_ = 0;
317
+ }
281
318
 
282
319
 
283
320
  Handle<Object> GlobalHandles::Create(Object* value) {
284
- Counters::global_handles.Increment();
321
+ isolate_->counters()->global_handles()->Increment();
285
322
  Node* result;
286
323
  if (first_free()) {
287
324
  // Take the first node in the free list.
@@ -295,7 +332,7 @@ Handle<Object> GlobalHandles::Create(Object* value) {
295
332
  set_head(result);
296
333
  } else {
297
334
  // Allocate a new node.
298
- result = pool_.Allocate();
335
+ result = pool_->Allocate();
299
336
  result->set_next(head());
300
337
  set_head(result);
301
338
  }
@@ -305,10 +342,10 @@ Handle<Object> GlobalHandles::Create(Object* value) {
305
342
 
306
343
 
307
344
  void GlobalHandles::Destroy(Object** location) {
308
- Counters::global_handles.Decrement();
345
+ isolate_->counters()->global_handles()->Decrement();
309
346
  if (location == NULL) return;
310
347
  Node* node = Node::FromLocation(location);
311
- node->Destroy();
348
+ node->Destroy(this);
312
349
  // Link the destroyed.
313
350
  node->set_next_free(first_free());
314
351
  set_first_free(node);
@@ -318,12 +355,12 @@ void GlobalHandles::Destroy(Object** location) {
318
355
  void GlobalHandles::MakeWeak(Object** location, void* parameter,
319
356
  WeakReferenceCallback callback) {
320
357
  ASSERT(callback != NULL);
321
- Node::FromLocation(location)->MakeWeak(parameter, callback);
358
+ Node::FromLocation(location)->MakeWeak(this, parameter, callback);
322
359
  }
323
360
 
324
361
 
325
362
  void GlobalHandles::ClearWeakness(Object** location) {
326
- Node::FromLocation(location)->ClearWeakness();
363
+ Node::FromLocation(location)->ClearWeakness(this);
327
364
  }
328
365
 
329
366
 
@@ -337,6 +374,11 @@ bool GlobalHandles::IsWeak(Object** location) {
337
374
  }
338
375
 
339
376
 
377
+ void GlobalHandles::SetWrapperClassId(Object** location, uint16_t class_id) {
378
+ Node::FromLocation(location)->SetWrapperClassId(class_id);
379
+ }
380
+
381
+
340
382
  void GlobalHandles::IterateWeakRoots(ObjectVisitor* v) {
341
383
  // Traversal of GC roots in the global handle list that are marked as
342
384
  // WEAK or PENDING.
@@ -365,27 +407,26 @@ void GlobalHandles::IdentifyWeakHandles(WeakSlotCallback f) {
365
407
  if (current->state_ == Node::WEAK) {
366
408
  if (f(&current->object_)) {
367
409
  current->state_ = Node::PENDING;
368
- LOG(HandleEvent("GlobalHandle::Pending", current->handle().location()));
410
+ LOG(isolate_,
411
+ HandleEvent("GlobalHandle::Pending", current->handle().location()));
369
412
  }
370
413
  }
371
414
  }
372
415
  }
373
416
 
374
417
 
375
- int post_gc_processing_count = 0;
376
-
377
418
  bool GlobalHandles::PostGarbageCollectionProcessing() {
378
419
  // Process weak global handle callbacks. This must be done after the
379
420
  // GC is completely done, because the callbacks may invoke arbitrary
380
421
  // API functions.
381
422
  // At the same time deallocate all DESTROYED nodes.
382
- ASSERT(Heap::gc_state() == Heap::NOT_IN_GC);
383
- const int initial_post_gc_processing_count = ++post_gc_processing_count;
423
+ ASSERT(isolate_->heap()->gc_state() == Heap::NOT_IN_GC);
424
+ const int initial_post_gc_processing_count = ++post_gc_processing_count_;
384
425
  bool next_gc_likely_to_collect_more = false;
385
426
  Node** p = &head_;
386
427
  while (*p != NULL) {
387
- if ((*p)->PostGarbageCollectionProcessing()) {
388
- if (initial_post_gc_processing_count != post_gc_processing_count) {
428
+ if ((*p)->PostGarbageCollectionProcessing(isolate_, this)) {
429
+ if (initial_post_gc_processing_count != post_gc_processing_count_) {
389
430
  // Weak callback triggered another GC and another round of
390
431
  // PostGarbageCollection processing. The current node might
391
432
  // have been deleted in that round, so we need to bail out (or
@@ -435,22 +476,25 @@ void GlobalHandles::IterateAllRoots(ObjectVisitor* v) {
435
476
  }
436
477
 
437
478
 
479
+ void GlobalHandles::IterateAllRootsWithClassIds(ObjectVisitor* v) {
480
+ for (Node* current = head_; current != NULL; current = current->next()) {
481
+ if (current->class_id_ != v8::HeapProfiler::kPersistentHandleNoClassId &&
482
+ current->CanBeRetainer()) {
483
+ v->VisitEmbedderReference(&current->object_, current->class_id_);
484
+ }
485
+ }
486
+ }
487
+
488
+
438
489
  void GlobalHandles::TearDown() {
439
490
  // Reset all the lists.
440
491
  set_head(NULL);
441
492
  set_first_free(NULL);
442
493
  set_first_deallocated(NULL);
443
- pool_.Release();
494
+ pool_->Release();
444
495
  }
445
496
 
446
497
 
447
- int GlobalHandles::number_of_weak_handles_ = 0;
448
- int GlobalHandles::number_of_global_object_weak_handles_ = 0;
449
-
450
- GlobalHandles::Node* GlobalHandles::head_ = NULL;
451
- GlobalHandles::Node* GlobalHandles::first_free_ = NULL;
452
- GlobalHandles::Node* GlobalHandles::first_deallocated_ = NULL;
453
-
454
498
  void GlobalHandles::RecordStats(HeapStats* stats) {
455
499
  *stats->global_handle_count = 0;
456
500
  *stats->weak_global_handle_count = 0;
@@ -509,26 +553,44 @@ void GlobalHandles::Print() {
509
553
 
510
554
  #endif
511
555
 
512
- List<ObjectGroup*>* GlobalHandles::ObjectGroups() {
513
- // Lazily initialize the list to avoid startup time static constructors.
514
- static List<ObjectGroup*> groups(4);
515
- return &groups;
516
- }
517
556
 
518
- void GlobalHandles::AddGroup(Object*** handles, size_t length) {
519
- ObjectGroup* new_entry = new ObjectGroup(length);
520
- for (size_t i = 0; i < length; ++i)
557
+
558
+ void GlobalHandles::AddObjectGroup(Object*** handles,
559
+ size_t length,
560
+ v8::RetainedObjectInfo* info) {
561
+ ObjectGroup* new_entry = new ObjectGroup(length, info);
562
+ for (size_t i = 0; i < length; ++i) {
521
563
  new_entry->objects_.Add(handles[i]);
522
- ObjectGroups()->Add(new_entry);
564
+ }
565
+ object_groups_.Add(new_entry);
566
+ }
567
+
568
+
569
+ void GlobalHandles::AddImplicitReferences(HeapObject* parent,
570
+ Object*** children,
571
+ size_t length) {
572
+ ImplicitRefGroup* new_entry = new ImplicitRefGroup(parent, length);
573
+ for (size_t i = 0; i < length; ++i) {
574
+ new_entry->children_.Add(children[i]);
575
+ }
576
+ implicit_ref_groups_.Add(new_entry);
523
577
  }
524
578
 
525
579
 
526
580
  void GlobalHandles::RemoveObjectGroups() {
527
- List<ObjectGroup*>* object_groups = ObjectGroups();
528
- for (int i = 0; i< object_groups->length(); i++) {
529
- delete object_groups->at(i);
581
+ for (int i = 0; i < object_groups_.length(); i++) {
582
+ delete object_groups_.at(i);
530
583
  }
531
- object_groups->Clear();
584
+ object_groups_.Clear();
532
585
  }
533
586
 
587
+
588
+ void GlobalHandles::RemoveImplicitRefGroups() {
589
+ for (int i = 0; i < implicit_ref_groups_.length(); i++) {
590
+ delete implicit_ref_groups_.at(i);
591
+ }
592
+ implicit_ref_groups_.Clear();
593
+ }
594
+
595
+
534
596
  } } // namespace v8::internal