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
@@ -36,11 +36,6 @@
36
36
 
37
37
  namespace v8 {
38
38
 
39
- static internal::Thread::LocalStorageKey thread_state_key =
40
- internal::Thread::CreateThreadLocalKey();
41
- static internal::Thread::LocalStorageKey thread_id_key =
42
- internal::Thread::CreateThreadLocalKey();
43
-
44
39
 
45
40
  // Track whether this V8 instance has ever called v8::Locker. This allows the
46
41
  // API code to verify that the lock is always held when V8 is being entered.
@@ -50,64 +45,88 @@ bool Locker::active_ = false;
50
45
  // Constructor for the Locker object. Once the Locker is constructed the
51
46
  // current thread will be guaranteed to have the big V8 lock.
52
47
  Locker::Locker() : has_lock_(false), top_level_(true) {
48
+ // TODO(isolates): When Locker has Isolate parameter and it is provided, grab
49
+ // that one instead of using the current one.
50
+ // We pull default isolate for Locker constructor w/o p[arameter.
51
+ // A thread should not enter an isolate before acquiring a lock,
52
+ // in cases which mandate using Lockers.
53
+ // So getting a lock is the first thing threads do in a scenario where
54
+ // multple threads share an isolate. Hence, we need to access
55
+ // 'locking isolate' before we can actually enter into default isolate.
56
+ internal::Isolate* isolate = internal::Isolate::GetDefaultIsolateForLocking();
57
+ ASSERT(isolate != NULL);
58
+
53
59
  // Record that the Locker has been used at least once.
54
60
  active_ = true;
55
61
  // Get the big lock if necessary.
56
- if (!internal::ThreadManager::IsLockedByCurrentThread()) {
57
- internal::ThreadManager::Lock();
62
+ if (!isolate->thread_manager()->IsLockedByCurrentThread()) {
63
+ isolate->thread_manager()->Lock();
58
64
  has_lock_ = true;
65
+
66
+ if (isolate->IsDefaultIsolate()) {
67
+ // This only enters if not yet entered.
68
+ internal::Isolate::EnterDefaultIsolate();
69
+ }
70
+
71
+ ASSERT(internal::Thread::HasThreadLocal(
72
+ internal::Isolate::thread_id_key()));
73
+
59
74
  // Make sure that V8 is initialized. Archiving of threads interferes
60
75
  // with deserialization by adding additional root pointers, so we must
61
76
  // initialize here, before anyone can call ~Locker() or Unlocker().
62
- if (!internal::V8::IsRunning()) {
77
+ if (!isolate->IsInitialized()) {
63
78
  V8::Initialize();
64
79
  }
65
80
  // This may be a locker within an unlocker in which case we have to
66
81
  // get the saved state for this thread and restore it.
67
- if (internal::ThreadManager::RestoreThread()) {
82
+ if (isolate->thread_manager()->RestoreThread()) {
68
83
  top_level_ = false;
69
84
  } else {
70
- internal::ExecutionAccess access;
71
- internal::StackGuard::ClearThread(access);
72
- internal::StackGuard::InitThread(access);
85
+ internal::ExecutionAccess access(isolate);
86
+ isolate->stack_guard()->ClearThread(access);
87
+ isolate->stack_guard()->InitThread(access);
73
88
  }
74
89
  }
75
- ASSERT(internal::ThreadManager::IsLockedByCurrentThread());
76
-
77
- // Make sure this thread is assigned a thread id.
78
- internal::ThreadManager::AssignId();
90
+ ASSERT(isolate->thread_manager()->IsLockedByCurrentThread());
79
91
  }
80
92
 
81
93
 
82
94
  bool Locker::IsLocked() {
83
- return internal::ThreadManager::IsLockedByCurrentThread();
95
+ return internal::Isolate::Current()->thread_manager()->
96
+ IsLockedByCurrentThread();
84
97
  }
85
98
 
86
99
 
87
100
  Locker::~Locker() {
88
- ASSERT(internal::ThreadManager::IsLockedByCurrentThread());
101
+ // TODO(isolate): this should use a field storing the isolate it
102
+ // locked instead.
103
+ internal::Isolate* isolate = internal::Isolate::Current();
104
+ ASSERT(isolate->thread_manager()->IsLockedByCurrentThread());
89
105
  if (has_lock_) {
90
106
  if (top_level_) {
91
- internal::ThreadManager::FreeThreadResources();
107
+ isolate->thread_manager()->FreeThreadResources();
92
108
  } else {
93
- internal::ThreadManager::ArchiveThread();
109
+ isolate->thread_manager()->ArchiveThread();
94
110
  }
95
- internal::ThreadManager::Unlock();
111
+ isolate->thread_manager()->Unlock();
96
112
  }
97
113
  }
98
114
 
99
115
 
100
116
  Unlocker::Unlocker() {
101
- ASSERT(internal::ThreadManager::IsLockedByCurrentThread());
102
- internal::ThreadManager::ArchiveThread();
103
- internal::ThreadManager::Unlock();
117
+ internal::Isolate* isolate = internal::Isolate::Current();
118
+ ASSERT(isolate->thread_manager()->IsLockedByCurrentThread());
119
+ isolate->thread_manager()->ArchiveThread();
120
+ isolate->thread_manager()->Unlock();
104
121
  }
105
122
 
106
123
 
107
124
  Unlocker::~Unlocker() {
108
- ASSERT(!internal::ThreadManager::IsLockedByCurrentThread());
109
- internal::ThreadManager::Lock();
110
- internal::ThreadManager::RestoreThread();
125
+ // TODO(isolates): check it's the isolate we unlocked.
126
+ internal::Isolate* isolate = internal::Isolate::Current();
127
+ ASSERT(!isolate->thread_manager()->IsLockedByCurrentThread());
128
+ isolate->thread_manager()->Lock();
129
+ isolate->thread_manager()->RestoreThread();
111
130
  }
112
131
 
113
132
 
@@ -130,44 +149,45 @@ bool ThreadManager::RestoreThread() {
130
149
  // had prepared back in the free list, since we didn't need it after all.
131
150
  if (lazily_archived_thread_.IsSelf()) {
132
151
  lazily_archived_thread_.Initialize(ThreadHandle::INVALID);
133
- ASSERT(Thread::GetThreadLocal(thread_state_key) ==
152
+ ASSERT(Isolate::CurrentPerIsolateThreadData()->thread_state() ==
134
153
  lazily_archived_thread_state_);
135
154
  lazily_archived_thread_state_->set_id(kInvalidId);
136
155
  lazily_archived_thread_state_->LinkInto(ThreadState::FREE_LIST);
137
156
  lazily_archived_thread_state_ = NULL;
138
- Thread::SetThreadLocal(thread_state_key, NULL);
157
+ Isolate::CurrentPerIsolateThreadData()->set_thread_state(NULL);
139
158
  return true;
140
159
  }
141
160
 
142
161
  // Make sure that the preemption thread cannot modify the thread state while
143
162
  // it is being archived or restored.
144
- ExecutionAccess access;
163
+ ExecutionAccess access(isolate_);
145
164
 
146
165
  // If there is another thread that was lazily archived then we have to really
147
166
  // archive it now.
148
167
  if (lazily_archived_thread_.IsValid()) {
149
168
  EagerlyArchiveThread();
150
169
  }
151
- ThreadState* state =
152
- reinterpret_cast<ThreadState*>(Thread::GetThreadLocal(thread_state_key));
153
- if (state == NULL) {
170
+ Isolate::PerIsolateThreadData* per_thread =
171
+ Isolate::CurrentPerIsolateThreadData();
172
+ if (per_thread == NULL || per_thread->thread_state() == NULL) {
154
173
  // This is a new thread.
155
- StackGuard::InitThread(access);
174
+ isolate_->stack_guard()->InitThread(access);
156
175
  return false;
157
176
  }
177
+ ThreadState* state = per_thread->thread_state();
158
178
  char* from = state->data();
159
- from = HandleScopeImplementer::RestoreThread(from);
160
- from = Top::RestoreThread(from);
179
+ from = isolate_->handle_scope_implementer()->RestoreThread(from);
180
+ from = isolate_->RestoreThread(from);
161
181
  from = Relocatable::RestoreState(from);
162
182
  #ifdef ENABLE_DEBUGGER_SUPPORT
163
- from = Debug::RestoreDebug(from);
183
+ from = isolate_->debug()->RestoreDebug(from);
164
184
  #endif
165
- from = StackGuard::RestoreStackGuard(from);
166
- from = RegExpStack::RestoreStack(from);
167
- from = Bootstrapper::RestoreState(from);
168
- Thread::SetThreadLocal(thread_state_key, NULL);
185
+ from = isolate_->stack_guard()->RestoreStackGuard(from);
186
+ from = isolate_->regexp_stack()->RestoreStack(from);
187
+ from = isolate_->bootstrapper()->RestoreState(from);
188
+ per_thread->set_thread_state(NULL);
169
189
  if (state->terminate_on_restore()) {
170
- StackGuard::TerminateExecution();
190
+ isolate_->stack_guard()->TerminateExecution();
171
191
  state->set_terminate_on_restore(false);
172
192
  }
173
193
  state->set_id(kInvalidId);
@@ -192,7 +212,7 @@ void ThreadManager::Unlock() {
192
212
 
193
213
  static int ArchiveSpacePerThread() {
194
214
  return HandleScopeImplementer::ArchiveSpacePerThread() +
195
- Top::ArchiveSpacePerThread() +
215
+ Isolate::ArchiveSpacePerThread() +
196
216
  #ifdef ENABLE_DEBUGGER_SUPPORT
197
217
  Debug::ArchiveSpacePerThread() +
198
218
  #endif
@@ -203,13 +223,12 @@ static int ArchiveSpacePerThread() {
203
223
  }
204
224
 
205
225
 
206
- ThreadState* ThreadState::free_anchor_ = new ThreadState();
207
- ThreadState* ThreadState::in_use_anchor_ = new ThreadState();
208
-
209
-
210
- ThreadState::ThreadState() : id_(ThreadManager::kInvalidId),
211
- terminate_on_restore_(false),
212
- next_(this), previous_(this) {
226
+ ThreadState::ThreadState(ThreadManager* thread_manager)
227
+ : id_(ThreadManager::kInvalidId),
228
+ terminate_on_restore_(false),
229
+ next_(this),
230
+ previous_(this),
231
+ thread_manager_(thread_manager) {
213
232
  }
214
233
 
215
234
 
@@ -226,7 +245,8 @@ void ThreadState::Unlink() {
226
245
 
227
246
  void ThreadState::LinkInto(List list) {
228
247
  ThreadState* flying_anchor =
229
- list == FREE_LIST ? free_anchor_ : in_use_anchor_;
248
+ list == FREE_LIST ? thread_manager_->free_anchor_
249
+ : thread_manager_->in_use_anchor_;
230
250
  next_ = flying_anchor->next_;
231
251
  previous_ = flying_anchor;
232
252
  flying_anchor->next_ = this;
@@ -234,10 +254,10 @@ void ThreadState::LinkInto(List list) {
234
254
  }
235
255
 
236
256
 
237
- ThreadState* ThreadState::GetFree() {
257
+ ThreadState* ThreadManager::GetFreeThreadState() {
238
258
  ThreadState* gotten = free_anchor_->next_;
239
259
  if (gotten == free_anchor_) {
240
- ThreadState* new_thread_state = new ThreadState();
260
+ ThreadState* new_thread_state = new ThreadState(this);
241
261
  new_thread_state->AllocateSpace();
242
262
  return new_thread_state;
243
263
  }
@@ -246,13 +266,13 @@ ThreadState* ThreadState::GetFree() {
246
266
 
247
267
 
248
268
  // Gets the first in the list of archived threads.
249
- ThreadState* ThreadState::FirstInUse() {
269
+ ThreadState* ThreadManager::FirstThreadStateInUse() {
250
270
  return in_use_anchor_->Next();
251
271
  }
252
272
 
253
273
 
254
274
  ThreadState* ThreadState::Next() {
255
- if (next_ == in_use_anchor_) return NULL;
275
+ if (next_ == thread_manager_->in_use_anchor_) return NULL;
256
276
  return next_;
257
277
  }
258
278
 
@@ -260,19 +280,29 @@ ThreadState* ThreadState::Next() {
260
280
  // Thread ids must start with 1, because in TLS having thread id 0 can't
261
281
  // be distinguished from not having a thread id at all (since NULL is
262
282
  // defined as 0.)
263
- int ThreadManager::last_id_ = 0;
264
- Mutex* ThreadManager::mutex_ = OS::CreateMutex();
265
- ThreadHandle ThreadManager::mutex_owner_(ThreadHandle::INVALID);
266
- ThreadHandle ThreadManager::lazily_archived_thread_(ThreadHandle::INVALID);
267
- ThreadState* ThreadManager::lazily_archived_thread_state_ = NULL;
283
+ ThreadManager::ThreadManager()
284
+ : mutex_(OS::CreateMutex()),
285
+ mutex_owner_(ThreadHandle::INVALID),
286
+ lazily_archived_thread_(ThreadHandle::INVALID),
287
+ lazily_archived_thread_state_(NULL),
288
+ free_anchor_(NULL),
289
+ in_use_anchor_(NULL) {
290
+ free_anchor_ = new ThreadState(this);
291
+ in_use_anchor_ = new ThreadState(this);
292
+ }
293
+
294
+
295
+ ThreadManager::~ThreadManager() {
296
+ // TODO(isolates): Destroy mutexes.
297
+ }
268
298
 
269
299
 
270
300
  void ThreadManager::ArchiveThread() {
271
301
  ASSERT(!lazily_archived_thread_.IsValid());
272
302
  ASSERT(!IsArchived());
273
- ThreadState* state = ThreadState::GetFree();
303
+ ThreadState* state = GetFreeThreadState();
274
304
  state->Unlink();
275
- Thread::SetThreadLocal(thread_state_key, reinterpret_cast<void*>(state));
305
+ Isolate::CurrentPerIsolateThreadData()->set_thread_state(state);
276
306
  lazily_archived_thread_.Initialize(ThreadHandle::SELF);
277
307
  lazily_archived_thread_state_ = state;
278
308
  ASSERT(state->id() == kInvalidId);
@@ -287,84 +317,69 @@ void ThreadManager::EagerlyArchiveThread() {
287
317
  char* to = state->data();
288
318
  // Ensure that data containing GC roots are archived first, and handle them
289
319
  // in ThreadManager::Iterate(ObjectVisitor*).
290
- to = HandleScopeImplementer::ArchiveThread(to);
291
- to = Top::ArchiveThread(to);
320
+ to = isolate_->handle_scope_implementer()->ArchiveThread(to);
321
+ to = isolate_->ArchiveThread(to);
292
322
  to = Relocatable::ArchiveState(to);
293
323
  #ifdef ENABLE_DEBUGGER_SUPPORT
294
- to = Debug::ArchiveDebug(to);
324
+ to = isolate_->debug()->ArchiveDebug(to);
295
325
  #endif
296
- to = StackGuard::ArchiveStackGuard(to);
297
- to = RegExpStack::ArchiveStack(to);
298
- to = Bootstrapper::ArchiveState(to);
326
+ to = isolate_->stack_guard()->ArchiveStackGuard(to);
327
+ to = isolate_->regexp_stack()->ArchiveStack(to);
328
+ to = isolate_->bootstrapper()->ArchiveState(to);
299
329
  lazily_archived_thread_.Initialize(ThreadHandle::INVALID);
300
330
  lazily_archived_thread_state_ = NULL;
301
331
  }
302
332
 
303
333
 
304
334
  void ThreadManager::FreeThreadResources() {
305
- HandleScopeImplementer::FreeThreadResources();
306
- Top::FreeThreadResources();
335
+ isolate_->handle_scope_implementer()->FreeThreadResources();
336
+ isolate_->FreeThreadResources();
307
337
  #ifdef ENABLE_DEBUGGER_SUPPORT
308
- Debug::FreeThreadResources();
338
+ isolate_->debug()->FreeThreadResources();
309
339
  #endif
310
- StackGuard::FreeThreadResources();
311
- RegExpStack::FreeThreadResources();
312
- Bootstrapper::FreeThreadResources();
340
+ isolate_->stack_guard()->FreeThreadResources();
341
+ isolate_->regexp_stack()->FreeThreadResources();
342
+ isolate_->bootstrapper()->FreeThreadResources();
313
343
  }
314
344
 
315
345
 
316
346
  bool ThreadManager::IsArchived() {
317
- return Thread::HasThreadLocal(thread_state_key);
347
+ Isolate::PerIsolateThreadData* data = Isolate::CurrentPerIsolateThreadData();
348
+ return data != NULL && data->thread_state() != NULL;
318
349
  }
319
350
 
320
351
 
321
352
  void ThreadManager::Iterate(ObjectVisitor* v) {
322
353
  // Expecting no threads during serialization/deserialization
323
- for (ThreadState* state = ThreadState::FirstInUse();
354
+ for (ThreadState* state = FirstThreadStateInUse();
324
355
  state != NULL;
325
356
  state = state->Next()) {
326
357
  char* data = state->data();
327
358
  data = HandleScopeImplementer::Iterate(v, data);
328
- data = Top::Iterate(v, data);
359
+ data = isolate_->Iterate(v, data);
329
360
  data = Relocatable::Iterate(v, data);
330
361
  }
331
362
  }
332
363
 
333
364
 
334
365
  void ThreadManager::IterateArchivedThreads(ThreadVisitor* v) {
335
- for (ThreadState* state = ThreadState::FirstInUse();
366
+ for (ThreadState* state = FirstThreadStateInUse();
336
367
  state != NULL;
337
368
  state = state->Next()) {
338
369
  char* data = state->data();
339
370
  data += HandleScopeImplementer::ArchiveSpacePerThread();
340
- Top::IterateThread(v, data);
371
+ isolate_->IterateThread(v, data);
341
372
  }
342
373
  }
343
374
 
344
375
 
345
376
  int ThreadManager::CurrentId() {
346
- return Thread::GetThreadLocalInt(thread_id_key);
347
- }
348
-
349
-
350
- void ThreadManager::AssignId() {
351
- if (!HasId()) {
352
- ASSERT(Locker::IsLocked());
353
- int thread_id = ++last_id_;
354
- ASSERT(thread_id > 0); // see the comment near last_id_ definition.
355
- Thread::SetThreadLocalInt(thread_id_key, thread_id);
356
- Top::set_thread_id(thread_id);
357
- }
358
- }
359
-
360
-
361
- bool ThreadManager::HasId() {
362
- return Thread::HasThreadLocal(thread_id_key);
377
+ return Thread::GetThreadLocalInt(Isolate::thread_id_key());
363
378
  }
364
379
 
365
380
 
366
381
  void ThreadManager::TerminateExecution(int thread_id) {
367
- for (ThreadState* state = ThreadState::FirstInUse();
382
+ for (ThreadState* state = FirstThreadStateInUse();
368
383
  state != NULL;
369
384
  state = state->Next()) {
370
385
  if (thread_id == state->id()) {
@@ -374,13 +389,8 @@ void ThreadManager::TerminateExecution(int thread_id) {
374
389
  }
375
390
 
376
391
 
377
- // This is the ContextSwitcher singleton. There is at most a single thread
378
- // running which delivers preemption events to V8 threads.
379
- ContextSwitcher* ContextSwitcher::singleton_ = NULL;
380
-
381
-
382
- ContextSwitcher::ContextSwitcher(int every_n_ms)
383
- : Thread("v8:CtxtSwitcher"),
392
+ ContextSwitcher::ContextSwitcher(Isolate* isolate, int every_n_ms)
393
+ : Thread(isolate, "v8:CtxtSwitcher"),
384
394
  keep_going_(true),
385
395
  sleep_ms_(every_n_ms) {
386
396
  }
@@ -389,15 +399,16 @@ ContextSwitcher::ContextSwitcher(int every_n_ms)
389
399
  // Set the scheduling interval of V8 threads. This function starts the
390
400
  // ContextSwitcher thread if needed.
391
401
  void ContextSwitcher::StartPreemption(int every_n_ms) {
402
+ Isolate* isolate = Isolate::Current();
392
403
  ASSERT(Locker::IsLocked());
393
- if (singleton_ == NULL) {
404
+ if (isolate->context_switcher() == NULL) {
394
405
  // If the ContextSwitcher thread is not running at the moment start it now.
395
- singleton_ = new ContextSwitcher(every_n_ms);
396
- singleton_->Start();
406
+ isolate->set_context_switcher(new ContextSwitcher(isolate, every_n_ms));
407
+ isolate->context_switcher()->Start();
397
408
  } else {
398
409
  // ContextSwitcher thread is already running, so we just change the
399
410
  // scheduling interval.
400
- singleton_->sleep_ms_ = every_n_ms;
411
+ isolate->context_switcher()->sleep_ms_ = every_n_ms;
401
412
  }
402
413
  }
403
414
 
@@ -405,15 +416,17 @@ void ContextSwitcher::StartPreemption(int every_n_ms) {
405
416
  // Disable preemption of V8 threads. If multiple threads want to use V8 they
406
417
  // must cooperatively schedule amongst them from this point on.
407
418
  void ContextSwitcher::StopPreemption() {
419
+ Isolate* isolate = Isolate::Current();
408
420
  ASSERT(Locker::IsLocked());
409
- if (singleton_ != NULL) {
421
+ if (isolate->context_switcher() != NULL) {
410
422
  // The ContextSwitcher thread is running. We need to stop it and release
411
423
  // its resources.
412
- singleton_->keep_going_ = false;
413
- singleton_->Join(); // Wait for the ContextSwitcher thread to exit.
424
+ isolate->context_switcher()->keep_going_ = false;
425
+ // Wait for the ContextSwitcher thread to exit.
426
+ isolate->context_switcher()->Join();
414
427
  // Thread has exited, now we can delete it.
415
- delete(singleton_);
416
- singleton_ = NULL;
428
+ delete(isolate->context_switcher());
429
+ isolate->set_context_switcher(NULL);
417
430
  }
418
431
  }
419
432
 
@@ -423,7 +436,7 @@ void ContextSwitcher::StopPreemption() {
423
436
  void ContextSwitcher::Run() {
424
437
  while (keep_going_) {
425
438
  OS::Sleep(sleep_ms_);
426
- StackGuard::Preempt();
439
+ isolate()->stack_guard()->Preempt();
427
440
  }
428
441
  }
429
442