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
@@ -288,7 +288,7 @@ void VirtualFrame::CallJSFunction(int arg_count) {
288
288
  }
289
289
 
290
290
 
291
- void VirtualFrame::CallRuntime(Runtime::Function* f, int arg_count) {
291
+ void VirtualFrame::CallRuntime(const Runtime::Function* f, int arg_count) {
292
292
  SpillAll();
293
293
  Forget(arg_count);
294
294
  ASSERT(cgen()->HasValidEntryRegisters());
@@ -321,7 +321,8 @@ void VirtualFrame::InvokeBuiltin(Builtins::JavaScript id,
321
321
 
322
322
 
323
323
  void VirtualFrame::CallLoadIC(Handle<String> name, RelocInfo::Mode mode) {
324
- Handle<Code> ic(Builtins::builtin(Builtins::LoadIC_Initialize));
324
+ Handle<Code> ic(Isolate::Current()->builtins()->builtin(
325
+ Builtins::kLoadIC_Initialize));
325
326
  PopToR0();
326
327
  SpillAll();
327
328
  __ mov(r2, Operand(name));
@@ -332,9 +333,9 @@ void VirtualFrame::CallLoadIC(Handle<String> name, RelocInfo::Mode mode) {
332
333
  void VirtualFrame::CallStoreIC(Handle<String> name,
333
334
  bool is_contextual,
334
335
  StrictModeFlag strict_mode) {
335
- Handle<Code> ic(Builtins::builtin(strict_mode == kStrictMode
336
- ? Builtins::StoreIC_Initialize_Strict
337
- : Builtins::StoreIC_Initialize));
336
+ Handle<Code> ic(Isolate::Current()->builtins()->builtin(
337
+ (strict_mode == kStrictMode) ? Builtins::kStoreIC_Initialize_Strict
338
+ : Builtins::kStoreIC_Initialize));
338
339
  PopToR0();
339
340
  RelocInfo::Mode mode;
340
341
  if (is_contextual) {
@@ -352,15 +353,18 @@ void VirtualFrame::CallStoreIC(Handle<String> name,
352
353
 
353
354
 
354
355
  void VirtualFrame::CallKeyedLoadIC() {
355
- Handle<Code> ic(Builtins::builtin(Builtins::KeyedLoadIC_Initialize));
356
+ Handle<Code> ic(Isolate::Current()->builtins()->builtin(
357
+ Builtins::kKeyedLoadIC_Initialize));
356
358
  PopToR1R0();
357
359
  SpillAll();
358
360
  CallCodeObject(ic, RelocInfo::CODE_TARGET, 0);
359
361
  }
360
362
 
361
363
 
362
- void VirtualFrame::CallKeyedStoreIC() {
363
- Handle<Code> ic(Builtins::builtin(Builtins::KeyedStoreIC_Initialize));
364
+ void VirtualFrame::CallKeyedStoreIC(StrictModeFlag strict_mode) {
365
+ Handle<Code> ic(Isolate::Current()->builtins()->builtin(
366
+ (strict_mode == kStrictMode) ? Builtins::kKeyedStoreIC_Initialize_Strict
367
+ : Builtins::kKeyedStoreIC_Initialize));
364
368
  PopToR1R0();
365
369
  SpillAll();
366
370
  EmitPop(r2);
@@ -383,7 +387,8 @@ void VirtualFrame::CallCodeObject(Handle<Code> code,
383
387
  ASSERT(dropped_args == 0);
384
388
  break;
385
389
  case Code::BUILTIN:
386
- ASSERT(*code == Builtins::builtin(Builtins::JSConstructCall));
390
+ ASSERT(*code == Isolate::Current()->builtins()->builtin(
391
+ Builtins::kJSConstructCall));
387
392
  break;
388
393
  default:
389
394
  UNREACHABLE();
@@ -420,9 +425,6 @@ const VirtualFrame::TopOfStack VirtualFrame::kStateAfterPush[TOS_STATES] =
420
425
  { R0_TOS, R1_R0_TOS, R0_R1_TOS, R0_R1_TOS, R1_R0_TOS };
421
426
 
422
427
 
423
- bool VirtualFrame::SpilledScope::is_spilled_ = false;
424
-
425
-
426
428
  void VirtualFrame::Drop(int count) {
427
429
  ASSERT(count >= 0);
428
430
  ASSERT(height() >= count);
@@ -55,23 +55,26 @@ class VirtualFrame : public ZoneObject {
55
55
  class SpilledScope BASE_EMBEDDED {
56
56
  public:
57
57
  explicit SpilledScope(VirtualFrame* frame)
58
- : old_is_spilled_(is_spilled_) {
58
+ : old_is_spilled_(
59
+ Isolate::Current()->is_virtual_frame_in_spilled_scope()) {
59
60
  if (frame != NULL) {
60
- if (!is_spilled_) {
61
+ if (!old_is_spilled_) {
61
62
  frame->SpillAll();
62
63
  } else {
63
64
  frame->AssertIsSpilled();
64
65
  }
65
66
  }
66
- is_spilled_ = true;
67
+ Isolate::Current()->set_is_virtual_frame_in_spilled_scope(true);
67
68
  }
68
69
  ~SpilledScope() {
69
- is_spilled_ = old_is_spilled_;
70
+ Isolate::Current()->set_is_virtual_frame_in_spilled_scope(
71
+ old_is_spilled_);
72
+ }
73
+ static bool is_spilled() {
74
+ return Isolate::Current()->is_virtual_frame_in_spilled_scope();
70
75
  }
71
- static bool is_spilled() { return is_spilled_; }
72
76
 
73
77
  private:
74
- static bool is_spilled_;
75
78
  int old_is_spilled_;
76
79
 
77
80
  SpilledScope() { }
@@ -274,7 +277,7 @@ class VirtualFrame : public ZoneObject {
274
277
 
275
278
  // Call runtime given the number of arguments expected on (and
276
279
  // removed from) the stack.
277
- void CallRuntime(Runtime::Function* f, int arg_count);
280
+ void CallRuntime(const Runtime::Function* f, int arg_count);
278
281
  void CallRuntime(Runtime::FunctionId id, int arg_count);
279
282
 
280
283
  #ifdef ENABLE_DEBUGGER_SUPPORT
@@ -303,7 +306,7 @@ class VirtualFrame : public ZoneObject {
303
306
 
304
307
  // Call keyed store IC. Value, key and receiver are on the stack. All three
305
308
  // are consumed. Result is returned in r0.
306
- void CallKeyedStoreIC();
309
+ void CallKeyedStoreIC(StrictModeFlag strict_mode);
307
310
 
308
311
  // Call into an IC stub given the number of arguments it removes
309
312
  // from the stack. Register arguments to the IC stub are implicit,
@@ -33,7 +33,7 @@
33
33
 
34
34
  // Global list of arrays visited during toString, toLocaleString and
35
35
  // join invocations.
36
- var visited_arrays = new $Array();
36
+ var visited_arrays = new InternalArray();
37
37
 
38
38
 
39
39
  // Gets a sorted array of array keys. Useful for operations on sparse
@@ -73,7 +73,7 @@ function SparseJoin(array, len, convert) {
73
73
  var last_key = -1;
74
74
  var keys_length = keys.length;
75
75
 
76
- var elements = new $Array(keys_length);
76
+ var elements = new InternalArray(keys_length);
77
77
  var elements_length = 0;
78
78
 
79
79
  for (var i = 0; i < keys_length; i++) {
@@ -122,7 +122,7 @@ function Join(array, length, separator, convert) {
122
122
  }
123
123
 
124
124
  // Construct an array for the elements.
125
- var elements = new $Array(length);
125
+ var elements = new InternalArray(length);
126
126
 
127
127
  // We pull the empty separator check outside the loop for speed!
128
128
  if (separator.length == 0) {
@@ -140,7 +140,7 @@ function Join(array, length, separator, convert) {
140
140
  return %StringBuilderConcat(elements, elements_length, '');
141
141
  }
142
142
  // Non-empty separator case.
143
- // If the first element is a number then use the heuristic that the
143
+ // If the first element is a number then use the heuristic that the
144
144
  // remaining elements are also likely to be numbers.
145
145
  if (!IS_NUMBER(array[0])) {
146
146
  for (var i = 0; i < length; i++) {
@@ -148,7 +148,7 @@ function Join(array, length, separator, convert) {
148
148
  if (!IS_STRING(e)) e = convert(e);
149
149
  elements[i] = e;
150
150
  }
151
- } else {
151
+ } else {
152
152
  for (var i = 0; i < length; i++) {
153
153
  var e = array[i];
154
154
  if (IS_NUMBER(e)) elements[i] = %_NumberToString(e);
@@ -157,9 +157,9 @@ function Join(array, length, separator, convert) {
157
157
  elements[i] = e;
158
158
  }
159
159
  }
160
- }
160
+ }
161
161
  var result = %_FastAsciiArrayJoin(elements, separator);
162
- if (!IS_UNDEFINED(result)) return result;
162
+ if (!IS_UNDEFINED(result)) return result;
163
163
 
164
164
  return %StringBuilderJoin(elements, length, separator);
165
165
  } finally {
@@ -171,7 +171,7 @@ function Join(array, length, separator, convert) {
171
171
 
172
172
 
173
173
  function ConvertToString(x) {
174
- // Assumes x is a non-string.
174
+ // Assumes x is a non-string.
175
175
  if (IS_NUMBER(x)) return %_NumberToString(x);
176
176
  if (IS_BOOLEAN(x)) return x ? 'true' : 'false';
177
177
  return (IS_NULL_OR_UNDEFINED(x)) ? '' : %ToString(%DefaultString(x));
@@ -241,7 +241,7 @@ function SmartSlice(array, start_i, del_count, len, deleted_elements) {
241
241
  // special array operations to handle sparse arrays in a sensible fashion.
242
242
  function SmartMove(array, start_i, del_count, len, num_additional_args) {
243
243
  // Move data to new array.
244
- var new_array = new $Array(len - del_count + num_additional_args);
244
+ var new_array = new InternalArray(len - del_count + num_additional_args);
245
245
  var intervals = %GetArrayKeys(array, len);
246
246
  var length = intervals.length;
247
247
  for (var k = 0; k < length; k++) {
@@ -418,9 +418,8 @@ function ArrayPush() {
418
418
 
419
419
 
420
420
  function ArrayConcat(arg1) { // length == 1
421
- // TODO: can we just use arguments?
422
421
  var arg_count = %_ArgumentsLength();
423
- var arrays = new $Array(1 + arg_count);
422
+ var arrays = new InternalArray(1 + arg_count);
424
423
  arrays[0] = this;
425
424
  for (var i = 0; i < arg_count; i++) {
426
425
  arrays[i + 1] = %_Arguments(i);
@@ -926,7 +925,9 @@ function ArrayFilter(f, receiver) {
926
925
  for (var i = 0; i < length; i++) {
927
926
  var current = this[i];
928
927
  if (!IS_UNDEFINED(current) || i in this) {
929
- if (f.call(receiver, current, i, this)) result[result_length++] = current;
928
+ if (f.call(receiver, current, i, this)) {
929
+ result[result_length++] = current;
930
+ }
930
931
  }
931
932
  }
932
933
  return result;
@@ -991,13 +992,15 @@ function ArrayMap(f, receiver) {
991
992
  // Pull out the length so that modifications to the length in the
992
993
  // loop will not affect the looping.
993
994
  var length = TO_UINT32(this.length);
994
- var result = new $Array(length);
995
+ var result = new $Array();
996
+ var accumulator = new InternalArray(length);
995
997
  for (var i = 0; i < length; i++) {
996
998
  var current = this[i];
997
999
  if (!IS_UNDEFINED(current) || i in this) {
998
- result[i] = f.call(receiver, current, i, this);
1000
+ accumulator[i] = f.call(receiver, current, i, this);
999
1001
  }
1000
1002
  }
1003
+ %MoveArrayContents(accumulator, result);
1001
1004
  return result;
1002
1005
  }
1003
1006
 
@@ -1018,13 +1021,13 @@ function ArrayIndexOf(element, index) {
1018
1021
  }
1019
1022
  var min = index;
1020
1023
  var max = length;
1021
- if (UseSparseVariant(this, length, true)) {
1024
+ if (UseSparseVariant(this, length, IS_ARRAY(this))) {
1022
1025
  var intervals = %GetArrayKeys(this, length);
1023
1026
  if (intervals.length == 2 && intervals[0] < 0) {
1024
1027
  // A single interval.
1025
1028
  var intervalMin = -(intervals[0] + 1);
1026
1029
  var intervalMax = intervalMin + intervals[1];
1027
- min = MAX(min, intervalMin);
1030
+ if (min < intervalMin) min = intervalMin;
1028
1031
  max = intervalMax; // Capped by length already.
1029
1032
  // Fall through to loop below.
1030
1033
  } else {
@@ -1074,13 +1077,13 @@ function ArrayLastIndexOf(element, index) {
1074
1077
  }
1075
1078
  var min = 0;
1076
1079
  var max = index;
1077
- if (UseSparseVariant(this, length, true)) {
1080
+ if (UseSparseVariant(this, length, IS_ARRAY(this))) {
1078
1081
  var intervals = %GetArrayKeys(this, index + 1);
1079
1082
  if (intervals.length == 2 && intervals[0] < 0) {
1080
1083
  // A single interval.
1081
1084
  var intervalMin = -(intervals[0] + 1);
1082
1085
  var intervalMax = intervalMin + intervals[1];
1083
- min = MAX(min, intervalMin);
1086
+ if (min < intervalMin) min = intervalMin;
1084
1087
  max = intervalMax; // Capped by index already.
1085
1088
  // Fall through to loop below.
1086
1089
  } else {
@@ -1226,6 +1229,20 @@ function SetupArray() {
1226
1229
  ));
1227
1230
 
1228
1231
  %FinishArrayPrototypeSetup($Array.prototype);
1232
+
1233
+ // The internal Array prototype doesn't need to be fancy, since it's never
1234
+ // exposed to user code, so no hidden prototypes or DONT_ENUM attributes
1235
+ // are necessary.
1236
+ // The null __proto__ ensures that we never inherit any user created
1237
+ // getters or setters from, e.g., Object.prototype.
1238
+ InternalArray.prototype.__proto__ = null;
1239
+ // Adding only the functions that are actually used, and a toString.
1240
+ InternalArray.prototype.join = getFunction("join", ArrayJoin);
1241
+ InternalArray.prototype.pop = getFunction("pop", ArrayPop);
1242
+ InternalArray.prototype.push = getFunction("push", ArrayPush);
1243
+ InternalArray.prototype.toString = function() {
1244
+ return "Internal Array, length " + this.length;
1245
+ };
1229
1246
  }
1230
1247
 
1231
1248
 
@@ -55,6 +55,8 @@
55
55
  #include "x64/regexp-macro-assembler-x64.h"
56
56
  #elif V8_TARGET_ARCH_ARM
57
57
  #include "arm/regexp-macro-assembler-arm.h"
58
+ #elif V8_TARGET_ARCH_MIPS
59
+ #include "mips/regexp-macro-assembler-mips.h"
58
60
  #else // Unknown architecture.
59
61
  #error "Unknown architecture."
60
62
  #endif // Target architecture.
@@ -67,6 +69,7 @@ namespace internal {
67
69
  const double DoubleConstant::min_int = kMinInt;
68
70
  const double DoubleConstant::one_half = 0.5;
69
71
  const double DoubleConstant::minus_zero = -0.0;
72
+ const double DoubleConstant::nan = OS::nan_value();
70
73
  const double DoubleConstant::negative_infinity = -V8_INFINITY;
71
74
  const char* RelocInfo::kFillerCommentString = "DEOPTIMIZATION PADDING";
72
75
 
@@ -139,6 +142,7 @@ const int kPCJumpTag = (1 << kExtraTagBits) - 1;
139
142
 
140
143
  const int kSmallPCDeltaBits = kBitsPerByte - kTagBits;
141
144
  const int kSmallPCDeltaMask = (1 << kSmallPCDeltaBits) - 1;
145
+ const int RelocInfo::kMaxSmallPCDelta = kSmallPCDeltaMask;
142
146
 
143
147
  const int kVariableLengthPCJumpTopTag = 1;
144
148
  const int kChunkBits = 7;
@@ -216,7 +220,6 @@ void RelocInfoWriter::Write(const RelocInfo* rinfo) {
216
220
  #ifdef DEBUG
217
221
  byte* begin_pos = pos_;
218
222
  #endif
219
- Counters::reloc_info_count.Increment();
220
223
  ASSERT(rinfo->pc() - last_pc_ >= 0);
221
224
  ASSERT(RelocInfo::NUMBER_OF_MODES <= kMaxRelocModes);
222
225
  // Use unsigned delta-encoding for pc.
@@ -252,7 +255,7 @@ void RelocInfoWriter::Write(const RelocInfo* rinfo) {
252
255
  WriteExtraTaggedPC(pc_delta, kPCJumpTag);
253
256
  WriteExtraTaggedData(rinfo->data() - last_data_, kCommentTag);
254
257
  last_data_ = rinfo->data();
255
- ASSERT(begin_pos - pos_ == RelocInfo::kRelocCommentSize);
258
+ ASSERT(begin_pos - pos_ >= RelocInfo::kMinRelocCommentSize);
256
259
  } else {
257
260
  // For all other modes we simply use the mode as the extra tag.
258
261
  // None of these modes need a data component.
@@ -525,7 +528,7 @@ void RelocInfo::Verify() {
525
528
  ASSERT(addr != NULL);
526
529
  // Check that we can find the right code object.
527
530
  Code* code = Code::GetCodeFromTargetAddress(addr);
528
- Object* found = Heap::FindCodeObject(addr);
531
+ Object* found = HEAP->FindCodeObject(addr);
529
532
  ASSERT(found->IsCode());
530
533
  ASSERT(code->address() == HeapObject::cast(found)->address());
531
534
  break;
@@ -551,153 +554,184 @@ void RelocInfo::Verify() {
551
554
  // -----------------------------------------------------------------------------
552
555
  // Implementation of ExternalReference
553
556
 
554
- ExternalReference::ExternalReference(Builtins::CFunctionId id)
555
- : address_(Redirect(Builtins::c_function_address(id))) {}
557
+ ExternalReference::ExternalReference(Builtins::CFunctionId id, Isolate* isolate)
558
+ : address_(Redirect(isolate, Builtins::c_function_address(id))) {}
556
559
 
557
560
 
558
561
  ExternalReference::ExternalReference(
559
- ApiFunction* fun, Type type = ExternalReference::BUILTIN_CALL)
560
- : address_(Redirect(fun->address(), type)) {}
562
+ ApiFunction* fun,
563
+ Type type = ExternalReference::BUILTIN_CALL,
564
+ Isolate* isolate = NULL)
565
+ : address_(Redirect(isolate, fun->address(), type)) {}
561
566
 
562
567
 
563
- ExternalReference::ExternalReference(Builtins::Name name)
564
- : address_(Builtins::builtin_address(name)) {}
568
+ ExternalReference::ExternalReference(Builtins::Name name, Isolate* isolate)
569
+ : address_(isolate->builtins()->builtin_address(name)) {}
565
570
 
566
571
 
567
- ExternalReference::ExternalReference(Runtime::FunctionId id)
568
- : address_(Redirect(Runtime::FunctionForId(id)->entry)) {}
572
+ ExternalReference::ExternalReference(Runtime::FunctionId id,
573
+ Isolate* isolate)
574
+ : address_(Redirect(isolate, Runtime::FunctionForId(id)->entry)) {}
569
575
 
570
576
 
571
- ExternalReference::ExternalReference(Runtime::Function* f)
572
- : address_(Redirect(f->entry)) {}
577
+ ExternalReference::ExternalReference(const Runtime::Function* f,
578
+ Isolate* isolate)
579
+ : address_(Redirect(isolate, f->entry)) {}
573
580
 
574
581
 
575
- ExternalReference::ExternalReference(const IC_Utility& ic_utility)
576
- : address_(Redirect(ic_utility.address())) {}
582
+ ExternalReference ExternalReference::isolate_address() {
583
+ return ExternalReference(Isolate::Current());
584
+ }
585
+
586
+
587
+ ExternalReference::ExternalReference(const IC_Utility& ic_utility,
588
+ Isolate* isolate)
589
+ : address_(Redirect(isolate, ic_utility.address())) {}
577
590
 
578
591
  #ifdef ENABLE_DEBUGGER_SUPPORT
579
- ExternalReference::ExternalReference(const Debug_Address& debug_address)
580
- : address_(debug_address.address()) {}
592
+ ExternalReference::ExternalReference(const Debug_Address& debug_address,
593
+ Isolate* isolate)
594
+ : address_(debug_address.address(isolate)) {}
581
595
  #endif
582
596
 
583
597
  ExternalReference::ExternalReference(StatsCounter* counter)
584
598
  : address_(reinterpret_cast<Address>(counter->GetInternalPointer())) {}
585
599
 
586
600
 
587
- ExternalReference::ExternalReference(Top::AddressId id)
588
- : address_(Top::get_address_from_id(id)) {}
601
+ ExternalReference::ExternalReference(Isolate::AddressId id, Isolate* isolate)
602
+ : address_(isolate->get_address_from_id(id)) {}
589
603
 
590
604
 
591
605
  ExternalReference::ExternalReference(const SCTableReference& table_ref)
592
606
  : address_(table_ref.address()) {}
593
607
 
594
608
 
595
- ExternalReference ExternalReference::perform_gc_function() {
596
- return ExternalReference(Redirect(FUNCTION_ADDR(Runtime::PerformGC)));
609
+ ExternalReference ExternalReference::perform_gc_function(Isolate* isolate) {
610
+ return ExternalReference(Redirect(isolate,
611
+ FUNCTION_ADDR(Runtime::PerformGC)));
597
612
  }
598
613
 
599
614
 
600
- ExternalReference ExternalReference::fill_heap_number_with_random_function() {
601
- return
602
- ExternalReference(Redirect(FUNCTION_ADDR(V8::FillHeapNumberWithRandom)));
615
+ ExternalReference ExternalReference::fill_heap_number_with_random_function(
616
+ Isolate* isolate) {
617
+ return ExternalReference(Redirect(
618
+ isolate,
619
+ FUNCTION_ADDR(V8::FillHeapNumberWithRandom)));
603
620
  }
604
621
 
605
622
 
606
- ExternalReference ExternalReference::delete_handle_scope_extensions() {
607
- return ExternalReference(Redirect(FUNCTION_ADDR(
608
- HandleScope::DeleteExtensions)));
623
+ ExternalReference ExternalReference::delete_handle_scope_extensions(
624
+ Isolate* isolate) {
625
+ return ExternalReference(Redirect(
626
+ isolate,
627
+ FUNCTION_ADDR(HandleScope::DeleteExtensions)));
609
628
  }
610
629
 
611
630
 
612
- ExternalReference ExternalReference::random_uint32_function() {
613
- return ExternalReference(Redirect(FUNCTION_ADDR(V8::Random)));
631
+ ExternalReference ExternalReference::random_uint32_function(
632
+ Isolate* isolate) {
633
+ return ExternalReference(Redirect(isolate, FUNCTION_ADDR(V8::Random)));
614
634
  }
615
635
 
616
636
 
617
- ExternalReference ExternalReference::transcendental_cache_array_address() {
618
- return ExternalReference(TranscendentalCache::cache_array_address());
637
+ ExternalReference ExternalReference::transcendental_cache_array_address(
638
+ Isolate* isolate) {
639
+ return ExternalReference(
640
+ isolate->transcendental_cache()->cache_array_address());
619
641
  }
620
642
 
621
643
 
622
- ExternalReference ExternalReference::new_deoptimizer_function() {
644
+ ExternalReference ExternalReference::new_deoptimizer_function(
645
+ Isolate* isolate) {
623
646
  return ExternalReference(
624
- Redirect(FUNCTION_ADDR(Deoptimizer::New)));
647
+ Redirect(isolate, FUNCTION_ADDR(Deoptimizer::New)));
625
648
  }
626
649
 
627
650
 
628
- ExternalReference ExternalReference::compute_output_frames_function() {
651
+ ExternalReference ExternalReference::compute_output_frames_function(
652
+ Isolate* isolate) {
629
653
  return ExternalReference(
630
- Redirect(FUNCTION_ADDR(Deoptimizer::ComputeOutputFrames)));
654
+ Redirect(isolate, FUNCTION_ADDR(Deoptimizer::ComputeOutputFrames)));
631
655
  }
632
656
 
633
657
 
634
- ExternalReference ExternalReference::global_contexts_list() {
635
- return ExternalReference(Heap::global_contexts_list_address());
658
+ ExternalReference ExternalReference::global_contexts_list(Isolate* isolate) {
659
+ return ExternalReference(isolate->heap()->global_contexts_list_address());
636
660
  }
637
661
 
638
662
 
639
- ExternalReference ExternalReference::keyed_lookup_cache_keys() {
640
- return ExternalReference(KeyedLookupCache::keys_address());
663
+ ExternalReference ExternalReference::keyed_lookup_cache_keys(Isolate* isolate) {
664
+ return ExternalReference(isolate->keyed_lookup_cache()->keys_address());
641
665
  }
642
666
 
643
667
 
644
- ExternalReference ExternalReference::keyed_lookup_cache_field_offsets() {
645
- return ExternalReference(KeyedLookupCache::field_offsets_address());
668
+ ExternalReference ExternalReference::keyed_lookup_cache_field_offsets(
669
+ Isolate* isolate) {
670
+ return ExternalReference(
671
+ isolate->keyed_lookup_cache()->field_offsets_address());
646
672
  }
647
673
 
648
674
 
649
- ExternalReference ExternalReference::the_hole_value_location() {
650
- return ExternalReference(Factory::the_hole_value().location());
675
+ ExternalReference ExternalReference::the_hole_value_location(Isolate* isolate) {
676
+ return ExternalReference(isolate->factory()->the_hole_value().location());
651
677
  }
652
678
 
653
679
 
654
- ExternalReference ExternalReference::arguments_marker_location() {
655
- return ExternalReference(Factory::arguments_marker().location());
680
+ ExternalReference ExternalReference::arguments_marker_location(
681
+ Isolate* isolate) {
682
+ return ExternalReference(isolate->factory()->arguments_marker().location());
656
683
  }
657
684
 
658
685
 
659
- ExternalReference ExternalReference::roots_address() {
660
- return ExternalReference(Heap::roots_address());
686
+ ExternalReference ExternalReference::roots_address(Isolate* isolate) {
687
+ return ExternalReference(isolate->heap()->roots_address());
661
688
  }
662
689
 
663
690
 
664
- ExternalReference ExternalReference::address_of_stack_limit() {
665
- return ExternalReference(StackGuard::address_of_jslimit());
691
+ ExternalReference ExternalReference::address_of_stack_limit(Isolate* isolate) {
692
+ return ExternalReference(isolate->stack_guard()->address_of_jslimit());
666
693
  }
667
694
 
668
695
 
669
- ExternalReference ExternalReference::address_of_real_stack_limit() {
670
- return ExternalReference(StackGuard::address_of_real_jslimit());
696
+ ExternalReference ExternalReference::address_of_real_stack_limit(
697
+ Isolate* isolate) {
698
+ return ExternalReference(isolate->stack_guard()->address_of_real_jslimit());
671
699
  }
672
700
 
673
701
 
674
- ExternalReference ExternalReference::address_of_regexp_stack_limit() {
675
- return ExternalReference(RegExpStack::limit_address());
702
+ ExternalReference ExternalReference::address_of_regexp_stack_limit(
703
+ Isolate* isolate) {
704
+ return ExternalReference(isolate->regexp_stack()->limit_address());
676
705
  }
677
706
 
678
707
 
679
- ExternalReference ExternalReference::new_space_start() {
680
- return ExternalReference(Heap::NewSpaceStart());
708
+ ExternalReference ExternalReference::new_space_start(Isolate* isolate) {
709
+ return ExternalReference(isolate->heap()->NewSpaceStart());
681
710
  }
682
711
 
683
712
 
684
- ExternalReference ExternalReference::new_space_mask() {
685
- return ExternalReference(reinterpret_cast<Address>(Heap::NewSpaceMask()));
713
+ ExternalReference ExternalReference::new_space_mask(Isolate* isolate) {
714
+ Address mask = reinterpret_cast<Address>(isolate->heap()->NewSpaceMask());
715
+ return ExternalReference(mask);
686
716
  }
687
717
 
688
718
 
689
- ExternalReference ExternalReference::new_space_allocation_top_address() {
690
- return ExternalReference(Heap::NewSpaceAllocationTopAddress());
719
+ ExternalReference ExternalReference::new_space_allocation_top_address(
720
+ Isolate* isolate) {
721
+ return ExternalReference(isolate->heap()->NewSpaceAllocationTopAddress());
691
722
  }
692
723
 
693
724
 
694
- ExternalReference ExternalReference::heap_always_allocate_scope_depth() {
695
- return ExternalReference(Heap::always_allocate_scope_depth_address());
725
+ ExternalReference ExternalReference::heap_always_allocate_scope_depth(
726
+ Isolate* isolate) {
727
+ Heap* heap = isolate->heap();
728
+ return ExternalReference(heap->always_allocate_scope_depth_address());
696
729
  }
697
730
 
698
731
 
699
- ExternalReference ExternalReference::new_space_allocation_limit_address() {
700
- return ExternalReference(Heap::NewSpaceAllocationLimitAddress());
732
+ ExternalReference ExternalReference::new_space_allocation_limit_address(
733
+ Isolate* isolate) {
734
+ return ExternalReference(isolate->heap()->NewSpaceAllocationLimitAddress());
701
735
  }
702
736
 
703
737
 
@@ -716,8 +750,9 @@ ExternalReference ExternalReference::handle_scope_limit_address() {
716
750
  }
717
751
 
718
752
 
719
- ExternalReference ExternalReference::scheduled_exception_address() {
720
- return ExternalReference(Top::scheduled_exception_address());
753
+ ExternalReference ExternalReference::scheduled_exception_address(
754
+ Isolate* isolate) {
755
+ return ExternalReference(isolate->scheduled_exception_address());
721
756
  }
722
757
 
723
758
 
@@ -745,9 +780,16 @@ ExternalReference ExternalReference::address_of_negative_infinity() {
745
780
  }
746
781
 
747
782
 
783
+ ExternalReference ExternalReference::address_of_nan() {
784
+ return ExternalReference(reinterpret_cast<void*>(
785
+ const_cast<double*>(&DoubleConstant::nan)));
786
+ }
787
+
788
+
748
789
  #ifndef V8_INTERPRETED_REGEXP
749
790
 
750
- ExternalReference ExternalReference::re_check_stack_guard_state() {
791
+ ExternalReference ExternalReference::re_check_stack_guard_state(
792
+ Isolate* isolate) {
751
793
  Address function;
752
794
  #ifdef V8_TARGET_ARCH_X64
753
795
  function = FUNCTION_ADDR(RegExpMacroAssemblerX64::CheckStackGuardState);
@@ -755,19 +797,23 @@ ExternalReference ExternalReference::re_check_stack_guard_state() {
755
797
  function = FUNCTION_ADDR(RegExpMacroAssemblerIA32::CheckStackGuardState);
756
798
  #elif V8_TARGET_ARCH_ARM
757
799
  function = FUNCTION_ADDR(RegExpMacroAssemblerARM::CheckStackGuardState);
800
+ #elif V8_TARGET_ARCH_MIPS
801
+ function = FUNCTION_ADDR(RegExpMacroAssemblerMIPS::CheckStackGuardState);
758
802
  #else
759
803
  UNREACHABLE();
760
804
  #endif
761
- return ExternalReference(Redirect(function));
805
+ return ExternalReference(Redirect(isolate, function));
762
806
  }
763
807
 
764
- ExternalReference ExternalReference::re_grow_stack() {
808
+ ExternalReference ExternalReference::re_grow_stack(Isolate* isolate) {
765
809
  return ExternalReference(
766
- Redirect(FUNCTION_ADDR(NativeRegExpMacroAssembler::GrowStack)));
810
+ Redirect(isolate, FUNCTION_ADDR(NativeRegExpMacroAssembler::GrowStack)));
767
811
  }
768
812
 
769
- ExternalReference ExternalReference::re_case_insensitive_compare_uc16() {
813
+ ExternalReference ExternalReference::re_case_insensitive_compare_uc16(
814
+ Isolate* isolate) {
770
815
  return ExternalReference(Redirect(
816
+ isolate,
771
817
  FUNCTION_ADDR(NativeRegExpMacroAssembler::CaseInsensitiveCompareUC16)));
772
818
  }
773
819
 
@@ -776,16 +822,21 @@ ExternalReference ExternalReference::re_word_character_map() {
776
822
  NativeRegExpMacroAssembler::word_character_map_address());
777
823
  }
778
824
 
779
- ExternalReference ExternalReference::address_of_static_offsets_vector() {
780
- return ExternalReference(OffsetsVector::static_offsets_vector_address());
825
+ ExternalReference ExternalReference::address_of_static_offsets_vector(
826
+ Isolate* isolate) {
827
+ return ExternalReference(
828
+ OffsetsVector::static_offsets_vector_address(isolate));
781
829
  }
782
830
 
783
- ExternalReference ExternalReference::address_of_regexp_stack_memory_address() {
784
- return ExternalReference(RegExpStack::memory_address());
831
+ ExternalReference ExternalReference::address_of_regexp_stack_memory_address(
832
+ Isolate* isolate) {
833
+ return ExternalReference(
834
+ isolate->regexp_stack()->memory_address());
785
835
  }
786
836
 
787
- ExternalReference ExternalReference::address_of_regexp_stack_memory_size() {
788
- return ExternalReference(RegExpStack::memory_size_address());
837
+ ExternalReference ExternalReference::address_of_regexp_stack_memory_size(
838
+ Isolate* isolate) {
839
+ return ExternalReference(isolate->regexp_stack()->memory_size_address());
789
840
  }
790
841
 
791
842
  #endif // V8_INTERPRETED_REGEXP
@@ -816,6 +867,45 @@ static double mod_two_doubles(double x, double y) {
816
867
  }
817
868
 
818
869
 
870
+ static double math_sin_double(double x) {
871
+ return sin(x);
872
+ }
873
+
874
+
875
+ static double math_cos_double(double x) {
876
+ return cos(x);
877
+ }
878
+
879
+
880
+ static double math_log_double(double x) {
881
+ return log(x);
882
+ }
883
+
884
+
885
+ ExternalReference ExternalReference::math_sin_double_function(
886
+ Isolate* isolate) {
887
+ return ExternalReference(Redirect(isolate,
888
+ FUNCTION_ADDR(math_sin_double),
889
+ FP_RETURN_CALL));
890
+ }
891
+
892
+
893
+ ExternalReference ExternalReference::math_cos_double_function(
894
+ Isolate* isolate) {
895
+ return ExternalReference(Redirect(isolate,
896
+ FUNCTION_ADDR(math_cos_double),
897
+ FP_RETURN_CALL));
898
+ }
899
+
900
+
901
+ ExternalReference ExternalReference::math_log_double_function(
902
+ Isolate* isolate) {
903
+ return ExternalReference(Redirect(isolate,
904
+ FUNCTION_ADDR(math_log_double),
905
+ FP_RETURN_CALL));
906
+ }
907
+
908
+
819
909
  // Helper function to compute x^y, where y is known to be an
820
910
  // integer. Uses binary decomposition to limit the number of
821
911
  // multiplications; see the discussion in "Hacker's Delight" by Henry
@@ -851,14 +941,18 @@ double power_double_double(double x, double y) {
851
941
  }
852
942
 
853
943
 
854
- ExternalReference ExternalReference::power_double_double_function() {
855
- return ExternalReference(Redirect(FUNCTION_ADDR(power_double_double),
944
+ ExternalReference ExternalReference::power_double_double_function(
945
+ Isolate* isolate) {
946
+ return ExternalReference(Redirect(isolate,
947
+ FUNCTION_ADDR(power_double_double),
856
948
  FP_RETURN_CALL));
857
949
  }
858
950
 
859
951
 
860
- ExternalReference ExternalReference::power_double_int_function() {
861
- return ExternalReference(Redirect(FUNCTION_ADDR(power_double_int),
952
+ ExternalReference ExternalReference::power_double_int_function(
953
+ Isolate* isolate) {
954
+ return ExternalReference(Redirect(isolate,
955
+ FUNCTION_ADDR(power_double_int),
862
956
  FP_RETURN_CALL));
863
957
  }
864
958
 
@@ -870,7 +964,7 @@ static int native_compare_doubles(double y, double x) {
870
964
 
871
965
 
872
966
  ExternalReference ExternalReference::double_fp_operation(
873
- Token::Value operation) {
967
+ Token::Value operation, Isolate* isolate) {
874
968
  typedef double BinaryFPOperation(double x, double y);
875
969
  BinaryFPOperation* function = NULL;
876
970
  switch (operation) {
@@ -893,28 +987,28 @@ ExternalReference ExternalReference::double_fp_operation(
893
987
  UNREACHABLE();
894
988
  }
895
989
  // Passing true as 2nd parameter indicates that they return an fp value.
896
- return ExternalReference(Redirect(FUNCTION_ADDR(function), FP_RETURN_CALL));
990
+ return ExternalReference(Redirect(isolate,
991
+ FUNCTION_ADDR(function),
992
+ FP_RETURN_CALL));
897
993
  }
898
994
 
899
995
 
900
- ExternalReference ExternalReference::compare_doubles() {
901
- return ExternalReference(Redirect(FUNCTION_ADDR(native_compare_doubles),
996
+ ExternalReference ExternalReference::compare_doubles(Isolate* isolate) {
997
+ return ExternalReference(Redirect(isolate,
998
+ FUNCTION_ADDR(native_compare_doubles),
902
999
  BUILTIN_CALL));
903
1000
  }
904
1001
 
905
1002
 
906
- ExternalReference::ExternalReferenceRedirector*
907
- ExternalReference::redirector_ = NULL;
908
-
909
-
910
1003
  #ifdef ENABLE_DEBUGGER_SUPPORT
911
- ExternalReference ExternalReference::debug_break() {
912
- return ExternalReference(Redirect(FUNCTION_ADDR(Debug::Break)));
1004
+ ExternalReference ExternalReference::debug_break(Isolate* isolate) {
1005
+ return ExternalReference(Redirect(isolate, FUNCTION_ADDR(Debug_Break)));
913
1006
  }
914
1007
 
915
1008
 
916
- ExternalReference ExternalReference::debug_step_in_fp_address() {
917
- return ExternalReference(Debug::step_in_fp_addr());
1009
+ ExternalReference ExternalReference::debug_step_in_fp_address(
1010
+ Isolate* isolate) {
1011
+ return ExternalReference(isolate->debug()->step_in_fp_addr());
918
1012
  }
919
1013
  #endif
920
1014