libv8 3.3.10.4 → 3.5.10.beta1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (538) hide show
  1. data/lib/libv8/scons/CHANGES.txt +24 -231
  2. data/lib/libv8/scons/LICENSE.txt +1 -1
  3. data/lib/libv8/scons/MANIFEST +0 -1
  4. data/lib/libv8/scons/PKG-INFO +1 -1
  5. data/lib/libv8/scons/README.txt +9 -9
  6. data/lib/libv8/scons/RELEASE.txt +75 -77
  7. data/lib/libv8/scons/engine/SCons/Action.py +6 -22
  8. data/lib/libv8/scons/engine/SCons/Builder.py +2 -2
  9. data/lib/libv8/scons/engine/SCons/CacheDir.py +2 -2
  10. data/lib/libv8/scons/engine/SCons/Debug.py +2 -2
  11. data/lib/libv8/scons/engine/SCons/Defaults.py +10 -24
  12. data/lib/libv8/scons/engine/SCons/Environment.py +19 -118
  13. data/lib/libv8/scons/engine/SCons/Errors.py +2 -2
  14. data/lib/libv8/scons/engine/SCons/Executor.py +2 -2
  15. data/lib/libv8/scons/engine/SCons/Job.py +2 -2
  16. data/lib/libv8/scons/engine/SCons/Memoize.py +2 -2
  17. data/lib/libv8/scons/engine/SCons/Node/Alias.py +2 -2
  18. data/lib/libv8/scons/engine/SCons/Node/FS.py +121 -281
  19. data/lib/libv8/scons/engine/SCons/Node/Python.py +2 -2
  20. data/lib/libv8/scons/engine/SCons/Node/__init__.py +5 -6
  21. data/lib/libv8/scons/engine/SCons/Options/BoolOption.py +2 -2
  22. data/lib/libv8/scons/engine/SCons/Options/EnumOption.py +2 -2
  23. data/lib/libv8/scons/engine/SCons/Options/ListOption.py +2 -2
  24. data/lib/libv8/scons/engine/SCons/Options/PackageOption.py +2 -2
  25. data/lib/libv8/scons/engine/SCons/Options/PathOption.py +2 -2
  26. data/lib/libv8/scons/engine/SCons/Options/__init__.py +2 -2
  27. data/lib/libv8/scons/engine/SCons/PathList.py +2 -2
  28. data/lib/libv8/scons/engine/SCons/Platform/__init__.py +2 -2
  29. data/lib/libv8/scons/engine/SCons/Platform/aix.py +2 -2
  30. data/lib/libv8/scons/engine/SCons/Platform/cygwin.py +2 -2
  31. data/lib/libv8/scons/engine/SCons/Platform/darwin.py +3 -27
  32. data/lib/libv8/scons/engine/SCons/Platform/hpux.py +2 -2
  33. data/lib/libv8/scons/engine/SCons/Platform/irix.py +2 -2
  34. data/lib/libv8/scons/engine/SCons/Platform/os2.py +2 -2
  35. data/lib/libv8/scons/engine/SCons/Platform/posix.py +2 -2
  36. data/lib/libv8/scons/engine/SCons/Platform/sunos.py +2 -2
  37. data/lib/libv8/scons/engine/SCons/Platform/win32.py +2 -2
  38. data/lib/libv8/scons/engine/SCons/SConf.py +2 -2
  39. data/lib/libv8/scons/engine/SCons/SConsign.py +3 -9
  40. data/lib/libv8/scons/engine/SCons/Scanner/C.py +2 -2
  41. data/lib/libv8/scons/engine/SCons/Scanner/D.py +2 -2
  42. data/lib/libv8/scons/engine/SCons/Scanner/Dir.py +2 -2
  43. data/lib/libv8/scons/engine/SCons/Scanner/Fortran.py +2 -2
  44. data/lib/libv8/scons/engine/SCons/Scanner/IDL.py +2 -2
  45. data/lib/libv8/scons/engine/SCons/Scanner/LaTeX.py +2 -5
  46. data/lib/libv8/scons/engine/SCons/Scanner/Prog.py +2 -2
  47. data/lib/libv8/scons/engine/SCons/Scanner/RC.py +3 -3
  48. data/lib/libv8/scons/engine/SCons/Scanner/__init__.py +2 -2
  49. data/lib/libv8/scons/engine/SCons/Script/Interactive.py +2 -2
  50. data/lib/libv8/scons/engine/SCons/Script/Main.py +11 -82
  51. data/lib/libv8/scons/engine/SCons/Script/SConsOptions.py +5 -5
  52. data/lib/libv8/scons/engine/SCons/Script/SConscript.py +2 -2
  53. data/lib/libv8/scons/engine/SCons/Script/__init__.py +2 -2
  54. data/lib/libv8/scons/engine/SCons/Sig.py +2 -2
  55. data/lib/libv8/scons/engine/SCons/Subst.py +2 -2
  56. data/lib/libv8/scons/engine/SCons/Taskmaster.py +2 -10
  57. data/lib/libv8/scons/engine/SCons/Tool/386asm.py +2 -2
  58. data/lib/libv8/scons/engine/SCons/Tool/BitKeeper.py +2 -2
  59. data/lib/libv8/scons/engine/SCons/Tool/CVS.py +2 -2
  60. data/lib/libv8/scons/engine/SCons/Tool/FortranCommon.py +2 -19
  61. data/lib/libv8/scons/engine/SCons/Tool/JavaCommon.py +2 -2
  62. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/__init__.py +2 -2
  63. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/arch.py +2 -2
  64. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/common.py +2 -2
  65. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/netframework.py +2 -2
  66. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/sdk.py +2 -2
  67. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/vc.py +6 -9
  68. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/vs.py +2 -29
  69. data/lib/libv8/scons/engine/SCons/Tool/Perforce.py +2 -2
  70. data/lib/libv8/scons/engine/SCons/Tool/PharLapCommon.py +2 -2
  71. data/lib/libv8/scons/engine/SCons/Tool/RCS.py +2 -2
  72. data/lib/libv8/scons/engine/SCons/Tool/SCCS.py +2 -2
  73. data/lib/libv8/scons/engine/SCons/Tool/Subversion.py +2 -2
  74. data/lib/libv8/scons/engine/SCons/Tool/__init__.py +3 -3
  75. data/lib/libv8/scons/engine/SCons/Tool/aixc++.py +2 -2
  76. data/lib/libv8/scons/engine/SCons/Tool/aixcc.py +2 -2
  77. data/lib/libv8/scons/engine/SCons/Tool/aixf77.py +2 -2
  78. data/lib/libv8/scons/engine/SCons/Tool/aixlink.py +2 -2
  79. data/lib/libv8/scons/engine/SCons/Tool/applelink.py +2 -2
  80. data/lib/libv8/scons/engine/SCons/Tool/ar.py +2 -2
  81. data/lib/libv8/scons/engine/SCons/Tool/as.py +2 -2
  82. data/lib/libv8/scons/engine/SCons/Tool/bcc32.py +2 -2
  83. data/lib/libv8/scons/engine/SCons/Tool/c++.py +2 -2
  84. data/lib/libv8/scons/engine/SCons/Tool/cc.py +2 -2
  85. data/lib/libv8/scons/engine/SCons/Tool/cvf.py +2 -2
  86. data/lib/libv8/scons/engine/SCons/Tool/default.py +2 -2
  87. data/lib/libv8/scons/engine/SCons/Tool/dmd.py +7 -24
  88. data/lib/libv8/scons/engine/SCons/Tool/dvi.py +2 -2
  89. data/lib/libv8/scons/engine/SCons/Tool/dvipdf.py +2 -3
  90. data/lib/libv8/scons/engine/SCons/Tool/dvips.py +2 -3
  91. data/lib/libv8/scons/engine/SCons/Tool/f77.py +2 -2
  92. data/lib/libv8/scons/engine/SCons/Tool/f90.py +2 -2
  93. data/lib/libv8/scons/engine/SCons/Tool/f95.py +2 -2
  94. data/lib/libv8/scons/engine/SCons/Tool/filesystem.py +2 -2
  95. data/lib/libv8/scons/engine/SCons/Tool/fortran.py +2 -2
  96. data/lib/libv8/scons/engine/SCons/Tool/g++.py +2 -2
  97. data/lib/libv8/scons/engine/SCons/Tool/g77.py +2 -2
  98. data/lib/libv8/scons/engine/SCons/Tool/gas.py +2 -2
  99. data/lib/libv8/scons/engine/SCons/Tool/gcc.py +2 -2
  100. data/lib/libv8/scons/engine/SCons/Tool/gfortran.py +3 -3
  101. data/lib/libv8/scons/engine/SCons/Tool/gnulink.py +3 -2
  102. data/lib/libv8/scons/engine/SCons/Tool/gs.py +2 -2
  103. data/lib/libv8/scons/engine/SCons/Tool/hpc++.py +2 -2
  104. data/lib/libv8/scons/engine/SCons/Tool/hpcc.py +2 -2
  105. data/lib/libv8/scons/engine/SCons/Tool/hplink.py +2 -2
  106. data/lib/libv8/scons/engine/SCons/Tool/icc.py +2 -2
  107. data/lib/libv8/scons/engine/SCons/Tool/icl.py +2 -2
  108. data/lib/libv8/scons/engine/SCons/Tool/ifl.py +2 -2
  109. data/lib/libv8/scons/engine/SCons/Tool/ifort.py +2 -2
  110. data/lib/libv8/scons/engine/SCons/Tool/ilink.py +2 -2
  111. data/lib/libv8/scons/engine/SCons/Tool/ilink32.py +2 -2
  112. data/lib/libv8/scons/engine/SCons/Tool/install.py +3 -57
  113. data/lib/libv8/scons/engine/SCons/Tool/intelc.py +25 -65
  114. data/lib/libv8/scons/engine/SCons/Tool/ipkg.py +2 -2
  115. data/lib/libv8/scons/engine/SCons/Tool/jar.py +3 -9
  116. data/lib/libv8/scons/engine/SCons/Tool/javac.py +2 -2
  117. data/lib/libv8/scons/engine/SCons/Tool/javah.py +2 -2
  118. data/lib/libv8/scons/engine/SCons/Tool/latex.py +2 -3
  119. data/lib/libv8/scons/engine/SCons/Tool/lex.py +2 -2
  120. data/lib/libv8/scons/engine/SCons/Tool/link.py +5 -6
  121. data/lib/libv8/scons/engine/SCons/Tool/linkloc.py +2 -2
  122. data/lib/libv8/scons/engine/SCons/Tool/m4.py +2 -2
  123. data/lib/libv8/scons/engine/SCons/Tool/masm.py +2 -2
  124. data/lib/libv8/scons/engine/SCons/Tool/midl.py +2 -2
  125. data/lib/libv8/scons/engine/SCons/Tool/mingw.py +10 -31
  126. data/lib/libv8/scons/engine/SCons/Tool/mslib.py +2 -2
  127. data/lib/libv8/scons/engine/SCons/Tool/mslink.py +9 -61
  128. data/lib/libv8/scons/engine/SCons/Tool/mssdk.py +2 -2
  129. data/lib/libv8/scons/engine/SCons/Tool/msvc.py +11 -21
  130. data/lib/libv8/scons/engine/SCons/Tool/msvs.py +59 -477
  131. data/lib/libv8/scons/engine/SCons/Tool/mwcc.py +2 -2
  132. data/lib/libv8/scons/engine/SCons/Tool/mwld.py +2 -2
  133. data/lib/libv8/scons/engine/SCons/Tool/nasm.py +2 -2
  134. data/lib/libv8/scons/engine/SCons/Tool/packaging/__init__.py +2 -2
  135. data/lib/libv8/scons/engine/SCons/Tool/packaging/ipk.py +2 -2
  136. data/lib/libv8/scons/engine/SCons/Tool/packaging/msi.py +2 -2
  137. data/lib/libv8/scons/engine/SCons/Tool/packaging/rpm.py +2 -2
  138. data/lib/libv8/scons/engine/SCons/Tool/packaging/src_tarbz2.py +2 -2
  139. data/lib/libv8/scons/engine/SCons/Tool/packaging/src_targz.py +2 -2
  140. data/lib/libv8/scons/engine/SCons/Tool/packaging/src_zip.py +2 -2
  141. data/lib/libv8/scons/engine/SCons/Tool/packaging/tarbz2.py +2 -2
  142. data/lib/libv8/scons/engine/SCons/Tool/packaging/targz.py +2 -2
  143. data/lib/libv8/scons/engine/SCons/Tool/packaging/zip.py +2 -2
  144. data/lib/libv8/scons/engine/SCons/Tool/pdf.py +2 -2
  145. data/lib/libv8/scons/engine/SCons/Tool/pdflatex.py +2 -3
  146. data/lib/libv8/scons/engine/SCons/Tool/pdftex.py +2 -3
  147. data/lib/libv8/scons/engine/SCons/Tool/qt.py +2 -2
  148. data/lib/libv8/scons/engine/SCons/Tool/rmic.py +3 -9
  149. data/lib/libv8/scons/engine/SCons/Tool/rpcgen.py +2 -2
  150. data/lib/libv8/scons/engine/SCons/Tool/rpm.py +2 -2
  151. data/lib/libv8/scons/engine/SCons/Tool/sgiar.py +2 -2
  152. data/lib/libv8/scons/engine/SCons/Tool/sgic++.py +2 -2
  153. data/lib/libv8/scons/engine/SCons/Tool/sgicc.py +2 -2
  154. data/lib/libv8/scons/engine/SCons/Tool/sgilink.py +3 -2
  155. data/lib/libv8/scons/engine/SCons/Tool/sunar.py +2 -2
  156. data/lib/libv8/scons/engine/SCons/Tool/sunc++.py +2 -2
  157. data/lib/libv8/scons/engine/SCons/Tool/suncc.py +2 -2
  158. data/lib/libv8/scons/engine/SCons/Tool/sunf77.py +2 -2
  159. data/lib/libv8/scons/engine/SCons/Tool/sunf90.py +2 -2
  160. data/lib/libv8/scons/engine/SCons/Tool/sunf95.py +2 -2
  161. data/lib/libv8/scons/engine/SCons/Tool/sunlink.py +3 -2
  162. data/lib/libv8/scons/engine/SCons/Tool/swig.py +5 -6
  163. data/lib/libv8/scons/engine/SCons/Tool/tar.py +2 -2
  164. data/lib/libv8/scons/engine/SCons/Tool/tex.py +43 -96
  165. data/lib/libv8/scons/engine/SCons/Tool/textfile.py +2 -2
  166. data/lib/libv8/scons/engine/SCons/Tool/tlib.py +2 -2
  167. data/lib/libv8/scons/engine/SCons/Tool/wix.py +2 -2
  168. data/lib/libv8/scons/engine/SCons/Tool/yacc.py +2 -12
  169. data/lib/libv8/scons/engine/SCons/Tool/zip.py +2 -2
  170. data/lib/libv8/scons/engine/SCons/Util.py +3 -3
  171. data/lib/libv8/scons/engine/SCons/Variables/BoolVariable.py +2 -2
  172. data/lib/libv8/scons/engine/SCons/Variables/EnumVariable.py +3 -3
  173. data/lib/libv8/scons/engine/SCons/Variables/ListVariable.py +2 -2
  174. data/lib/libv8/scons/engine/SCons/Variables/PackageVariable.py +2 -2
  175. data/lib/libv8/scons/engine/SCons/Variables/PathVariable.py +2 -2
  176. data/lib/libv8/scons/engine/SCons/Variables/__init__.py +2 -2
  177. data/lib/libv8/scons/engine/SCons/Warnings.py +2 -2
  178. data/lib/libv8/scons/engine/SCons/__init__.py +6 -6
  179. data/lib/libv8/scons/engine/SCons/compat/__init__.py +2 -2
  180. data/lib/libv8/scons/engine/SCons/compat/_scons_builtins.py +2 -2
  181. data/lib/libv8/scons/engine/SCons/compat/_scons_collections.py +2 -2
  182. data/lib/libv8/scons/engine/SCons/compat/_scons_dbm.py +2 -2
  183. data/lib/libv8/scons/engine/SCons/compat/_scons_hashlib.py +2 -2
  184. data/lib/libv8/scons/engine/SCons/compat/_scons_io.py +2 -2
  185. data/lib/libv8/scons/engine/SCons/cpp.py +2 -2
  186. data/lib/libv8/scons/engine/SCons/dblite.py +1 -4
  187. data/lib/libv8/scons/engine/SCons/exitfuncs.py +2 -2
  188. data/lib/libv8/scons/scons-time.1 +3 -3
  189. data/lib/libv8/scons/scons.1 +1164 -1170
  190. data/lib/libv8/scons/sconsign.1 +3 -3
  191. data/lib/libv8/scons/script/scons +22 -22
  192. data/lib/libv8/scons/script/scons-time +2 -2
  193. data/lib/libv8/scons/script/scons.bat +4 -7
  194. data/lib/libv8/scons/script/sconsign +20 -21
  195. data/lib/libv8/scons/setup.cfg +1 -0
  196. data/lib/libv8/scons/setup.py +40 -38
  197. data/lib/libv8/v8/.gitignore +1 -1
  198. data/lib/libv8/v8/AUTHORS +2 -0
  199. data/lib/libv8/v8/ChangeLog +387 -0
  200. data/lib/libv8/v8/Makefile +171 -0
  201. data/lib/libv8/v8/SConstruct +124 -51
  202. data/lib/libv8/v8/build/README.txt +31 -14
  203. data/lib/libv8/v8/build/all.gyp +11 -4
  204. data/lib/libv8/v8/build/armu.gypi +6 -2
  205. data/lib/libv8/v8/build/common.gypi +240 -94
  206. data/lib/libv8/v8/build/gyp_v8 +32 -4
  207. data/lib/libv8/v8/build/standalone.gypi +200 -0
  208. data/lib/libv8/v8/include/v8-debug.h +0 -0
  209. data/lib/libv8/v8/include/v8-profiler.h +8 -11
  210. data/lib/libv8/v8/include/v8.h +191 -108
  211. data/lib/libv8/v8/preparser/SConscript +2 -2
  212. data/lib/libv8/v8/preparser/preparser-process.cc +3 -3
  213. data/lib/libv8/v8/preparser/preparser.gyp +42 -0
  214. data/lib/libv8/v8/src/SConscript +33 -8
  215. data/lib/libv8/v8/src/accessors.cc +77 -43
  216. data/lib/libv8/v8/src/api.cc +393 -191
  217. data/lib/libv8/v8/src/api.h +4 -8
  218. data/lib/libv8/v8/src/apinatives.js +15 -3
  219. data/lib/libv8/v8/src/arguments.h +8 -0
  220. data/lib/libv8/v8/src/arm/assembler-arm.cc +120 -120
  221. data/lib/libv8/v8/src/arm/assembler-arm.h +92 -43
  222. data/lib/libv8/v8/src/arm/builtins-arm.cc +32 -39
  223. data/lib/libv8/v8/src/arm/code-stubs-arm.cc +572 -351
  224. data/lib/libv8/v8/src/arm/code-stubs-arm.h +8 -77
  225. data/lib/libv8/v8/src/arm/codegen-arm.h +0 -2
  226. data/lib/libv8/v8/src/arm/deoptimizer-arm.cc +50 -30
  227. data/lib/libv8/v8/src/arm/disasm-arm.cc +1 -1
  228. data/lib/libv8/v8/src/arm/frames-arm.h +9 -5
  229. data/lib/libv8/v8/src/arm/full-codegen-arm.cc +331 -432
  230. data/lib/libv8/v8/src/arm/ic-arm.cc +192 -124
  231. data/lib/libv8/v8/src/arm/lithium-arm.cc +216 -232
  232. data/lib/libv8/v8/src/arm/lithium-arm.h +106 -259
  233. data/lib/libv8/v8/src/arm/lithium-codegen-arm.cc +633 -642
  234. data/lib/libv8/v8/src/arm/lithium-codegen-arm.h +4 -4
  235. data/lib/libv8/v8/src/arm/lithium-gap-resolver-arm.cc +1 -3
  236. data/lib/libv8/v8/src/arm/macro-assembler-arm.cc +260 -185
  237. data/lib/libv8/v8/src/arm/macro-assembler-arm.h +45 -25
  238. data/lib/libv8/v8/src/arm/regexp-macro-assembler-arm.cc +25 -13
  239. data/lib/libv8/v8/src/arm/regexp-macro-assembler-arm.h +3 -0
  240. data/lib/libv8/v8/src/arm/stub-cache-arm.cc +413 -226
  241. data/lib/libv8/v8/src/array.js +38 -18
  242. data/lib/libv8/v8/src/assembler.cc +12 -5
  243. data/lib/libv8/v8/src/assembler.h +15 -9
  244. data/lib/libv8/v8/src/ast-inl.h +34 -25
  245. data/lib/libv8/v8/src/ast.cc +141 -72
  246. data/lib/libv8/v8/src/ast.h +255 -181
  247. data/lib/libv8/v8/src/bignum.cc +3 -4
  248. data/lib/libv8/v8/src/bootstrapper.cc +55 -11
  249. data/lib/libv8/v8/src/bootstrapper.h +3 -2
  250. data/lib/libv8/v8/src/builtins.cc +8 -2
  251. data/lib/libv8/v8/src/builtins.h +4 -0
  252. data/lib/libv8/v8/src/cached-powers.cc +8 -4
  253. data/lib/libv8/v8/src/checks.h +3 -3
  254. data/lib/libv8/v8/src/code-stubs.cc +173 -28
  255. data/lib/libv8/v8/src/code-stubs.h +104 -148
  256. data/lib/libv8/v8/src/codegen.cc +8 -8
  257. data/lib/libv8/v8/src/compilation-cache.cc +2 -47
  258. data/lib/libv8/v8/src/compilation-cache.h +0 -10
  259. data/lib/libv8/v8/src/compiler.cc +27 -16
  260. data/lib/libv8/v8/src/compiler.h +13 -18
  261. data/lib/libv8/v8/src/contexts.cc +107 -72
  262. data/lib/libv8/v8/src/contexts.h +70 -34
  263. data/lib/libv8/v8/src/conversions-inl.h +572 -14
  264. data/lib/libv8/v8/src/conversions.cc +9 -707
  265. data/lib/libv8/v8/src/conversions.h +23 -12
  266. data/lib/libv8/v8/src/cpu-profiler-inl.h +2 -19
  267. data/lib/libv8/v8/src/cpu-profiler.cc +4 -21
  268. data/lib/libv8/v8/src/cpu-profiler.h +8 -17
  269. data/lib/libv8/v8/src/d8-debug.cc +5 -3
  270. data/lib/libv8/v8/src/d8-debug.h +6 -7
  271. data/lib/libv8/v8/src/d8-posix.cc +1 -10
  272. data/lib/libv8/v8/src/d8.cc +721 -219
  273. data/lib/libv8/v8/src/d8.gyp +37 -12
  274. data/lib/libv8/v8/src/d8.h +141 -19
  275. data/lib/libv8/v8/src/d8.js +17 -8
  276. data/lib/libv8/v8/src/date.js +16 -5
  277. data/lib/libv8/v8/src/dateparser-inl.h +242 -39
  278. data/lib/libv8/v8/src/dateparser.cc +38 -4
  279. data/lib/libv8/v8/src/dateparser.h +170 -28
  280. data/lib/libv8/v8/src/debug-agent.cc +5 -3
  281. data/lib/libv8/v8/src/debug-agent.h +11 -7
  282. data/lib/libv8/v8/src/debug-debugger.js +65 -34
  283. data/lib/libv8/v8/src/debug.cc +30 -60
  284. data/lib/libv8/v8/src/debug.h +5 -3
  285. data/lib/libv8/v8/src/deoptimizer.cc +227 -10
  286. data/lib/libv8/v8/src/deoptimizer.h +133 -9
  287. data/lib/libv8/v8/src/disassembler.cc +22 -14
  288. data/lib/libv8/v8/src/diy-fp.cc +4 -3
  289. data/lib/libv8/v8/src/diy-fp.h +3 -3
  290. data/lib/libv8/v8/src/elements.cc +634 -0
  291. data/lib/libv8/v8/src/elements.h +95 -0
  292. data/lib/libv8/v8/src/execution.cc +5 -21
  293. data/lib/libv8/v8/src/extensions/experimental/break-iterator.cc +3 -1
  294. data/lib/libv8/v8/src/extensions/experimental/break-iterator.h +1 -1
  295. data/lib/libv8/v8/src/extensions/experimental/collator.cc +6 -2
  296. data/lib/libv8/v8/src/extensions/experimental/collator.h +1 -2
  297. data/lib/libv8/v8/src/extensions/experimental/datetime-format.cc +384 -0
  298. data/lib/libv8/v8/src/extensions/experimental/datetime-format.h +83 -0
  299. data/lib/libv8/v8/src/extensions/experimental/experimental.gyp +18 -7
  300. data/lib/libv8/v8/src/extensions/experimental/i18n-extension.cc +12 -16
  301. data/lib/libv8/v8/src/extensions/experimental/i18n-extension.h +1 -1
  302. data/lib/libv8/v8/src/extensions/experimental/i18n-js2c.py +126 -0
  303. data/lib/libv8/v8/src/extensions/experimental/i18n-locale.cc +3 -4
  304. data/lib/libv8/v8/src/extensions/experimental/i18n-locale.h +1 -1
  305. data/lib/libv8/v8/src/{shell.h → extensions/experimental/i18n-natives.h} +8 -20
  306. data/lib/libv8/v8/src/extensions/experimental/i18n-utils.cc +45 -1
  307. data/lib/libv8/v8/src/extensions/experimental/i18n-utils.h +21 -1
  308. data/lib/libv8/v8/src/extensions/experimental/i18n.js +211 -11
  309. data/lib/libv8/v8/src/extensions/experimental/language-matcher.cc +4 -3
  310. data/lib/libv8/v8/src/extensions/experimental/language-matcher.h +1 -1
  311. data/lib/libv8/v8/src/extensions/experimental/number-format.cc +374 -0
  312. data/lib/libv8/v8/src/extensions/experimental/number-format.h +71 -0
  313. data/lib/libv8/v8/src/factory.cc +89 -18
  314. data/lib/libv8/v8/src/factory.h +36 -8
  315. data/lib/libv8/v8/src/flag-definitions.h +11 -44
  316. data/lib/libv8/v8/src/frames-inl.h +8 -1
  317. data/lib/libv8/v8/src/frames.cc +39 -3
  318. data/lib/libv8/v8/src/frames.h +10 -3
  319. data/lib/libv8/v8/src/full-codegen.cc +311 -293
  320. data/lib/libv8/v8/src/full-codegen.h +183 -143
  321. data/lib/libv8/v8/src/func-name-inferrer.cc +29 -15
  322. data/lib/libv8/v8/src/func-name-inferrer.h +19 -9
  323. data/lib/libv8/v8/src/gdb-jit.cc +658 -55
  324. data/lib/libv8/v8/src/gdb-jit.h +6 -2
  325. data/lib/libv8/v8/src/global-handles.cc +368 -312
  326. data/lib/libv8/v8/src/global-handles.h +29 -36
  327. data/lib/libv8/v8/src/globals.h +3 -1
  328. data/lib/libv8/v8/src/handles.cc +43 -69
  329. data/lib/libv8/v8/src/handles.h +21 -16
  330. data/lib/libv8/v8/src/heap-inl.h +11 -13
  331. data/lib/libv8/v8/src/heap-profiler.cc +0 -999
  332. data/lib/libv8/v8/src/heap-profiler.h +0 -303
  333. data/lib/libv8/v8/src/heap.cc +366 -141
  334. data/lib/libv8/v8/src/heap.h +87 -26
  335. data/lib/libv8/v8/src/hydrogen-instructions.cc +192 -81
  336. data/lib/libv8/v8/src/hydrogen-instructions.h +711 -482
  337. data/lib/libv8/v8/src/hydrogen.cc +1146 -629
  338. data/lib/libv8/v8/src/hydrogen.h +100 -64
  339. data/lib/libv8/v8/src/ia32/assembler-ia32.cc +19 -0
  340. data/lib/libv8/v8/src/ia32/assembler-ia32.h +15 -2
  341. data/lib/libv8/v8/src/ia32/builtins-ia32.cc +34 -39
  342. data/lib/libv8/v8/src/ia32/code-stubs-ia32.cc +675 -377
  343. data/lib/libv8/v8/src/ia32/code-stubs-ia32.h +8 -69
  344. data/lib/libv8/v8/src/ia32/codegen-ia32.cc +1 -0
  345. data/lib/libv8/v8/src/ia32/codegen-ia32.h +0 -2
  346. data/lib/libv8/v8/src/ia32/cpu-ia32.cc +3 -2
  347. data/lib/libv8/v8/src/ia32/deoptimizer-ia32.cc +28 -3
  348. data/lib/libv8/v8/src/ia32/disasm-ia32.cc +21 -10
  349. data/lib/libv8/v8/src/ia32/frames-ia32.h +6 -5
  350. data/lib/libv8/v8/src/ia32/full-codegen-ia32.cc +459 -465
  351. data/lib/libv8/v8/src/ia32/ic-ia32.cc +196 -147
  352. data/lib/libv8/v8/src/ia32/lithium-codegen-ia32.cc +575 -650
  353. data/lib/libv8/v8/src/ia32/lithium-codegen-ia32.h +19 -21
  354. data/lib/libv8/v8/src/ia32/lithium-gap-resolver-ia32.cc +7 -2
  355. data/lib/libv8/v8/src/ia32/lithium-ia32.cc +261 -256
  356. data/lib/libv8/v8/src/ia32/lithium-ia32.h +234 -335
  357. data/lib/libv8/v8/src/ia32/macro-assembler-ia32.cc +224 -67
  358. data/lib/libv8/v8/src/ia32/macro-assembler-ia32.h +63 -19
  359. data/lib/libv8/v8/src/ia32/regexp-macro-assembler-ia32.cc +22 -8
  360. data/lib/libv8/v8/src/ia32/regexp-macro-assembler-ia32.h +3 -0
  361. data/lib/libv8/v8/src/ia32/stub-cache-ia32.cc +380 -239
  362. data/lib/libv8/v8/src/ic.cc +198 -234
  363. data/lib/libv8/v8/src/ic.h +32 -30
  364. data/lib/libv8/v8/src/interpreter-irregexp.cc +6 -4
  365. data/lib/libv8/v8/src/isolate.cc +112 -95
  366. data/lib/libv8/v8/src/isolate.h +55 -71
  367. data/lib/libv8/v8/src/json-parser.h +486 -48
  368. data/lib/libv8/v8/src/json.js +28 -23
  369. data/lib/libv8/v8/src/jsregexp.cc +163 -208
  370. data/lib/libv8/v8/src/jsregexp.h +0 -1
  371. data/lib/libv8/v8/src/lithium-allocator-inl.h +29 -27
  372. data/lib/libv8/v8/src/lithium-allocator.cc +22 -17
  373. data/lib/libv8/v8/src/lithium-allocator.h +8 -8
  374. data/lib/libv8/v8/src/lithium.cc +16 -11
  375. data/lib/libv8/v8/src/lithium.h +31 -34
  376. data/lib/libv8/v8/src/liveedit.cc +111 -15
  377. data/lib/libv8/v8/src/liveedit.h +3 -4
  378. data/lib/libv8/v8/src/liveobjectlist.cc +116 -80
  379. data/lib/libv8/v8/src/liveobjectlist.h +2 -2
  380. data/lib/libv8/v8/src/log-inl.h +0 -4
  381. data/lib/libv8/v8/src/log-utils.cc +25 -143
  382. data/lib/libv8/v8/src/log-utils.h +13 -92
  383. data/lib/libv8/v8/src/log.cc +26 -249
  384. data/lib/libv8/v8/src/log.h +6 -17
  385. data/lib/libv8/v8/src/macros.py +9 -6
  386. data/lib/libv8/v8/src/mark-compact.cc +276 -56
  387. data/lib/libv8/v8/src/mark-compact.h +20 -0
  388. data/lib/libv8/v8/src/messages.js +93 -39
  389. data/lib/libv8/v8/src/mips/assembler-mips-inl.h +9 -3
  390. data/lib/libv8/v8/src/mips/assembler-mips.cc +297 -189
  391. data/lib/libv8/v8/src/mips/assembler-mips.h +121 -54
  392. data/lib/libv8/v8/src/mips/builtins-mips.cc +23 -24
  393. data/lib/libv8/v8/src/mips/code-stubs-mips.cc +484 -263
  394. data/lib/libv8/v8/src/mips/code-stubs-mips.h +8 -83
  395. data/lib/libv8/v8/src/mips/codegen-mips.h +0 -2
  396. data/lib/libv8/v8/src/mips/constants-mips.h +37 -11
  397. data/lib/libv8/v8/src/mips/deoptimizer-mips.cc +6 -1
  398. data/lib/libv8/v8/src/mips/frames-mips.h +8 -7
  399. data/lib/libv8/v8/src/mips/full-codegen-mips.cc +258 -419
  400. data/lib/libv8/v8/src/mips/ic-mips.cc +181 -121
  401. data/lib/libv8/v8/src/mips/macro-assembler-mips.cc +640 -382
  402. data/lib/libv8/v8/src/mips/macro-assembler-mips.h +94 -89
  403. data/lib/libv8/v8/src/mips/regexp-macro-assembler-mips.cc +23 -10
  404. data/lib/libv8/v8/src/mips/regexp-macro-assembler-mips.h +6 -1
  405. data/lib/libv8/v8/src/mips/simulator-mips.cc +249 -49
  406. data/lib/libv8/v8/src/mips/simulator-mips.h +25 -1
  407. data/lib/libv8/v8/src/mips/stub-cache-mips.cc +373 -161
  408. data/lib/libv8/v8/src/mirror-debugger.js +55 -8
  409. data/lib/libv8/v8/src/misc-intrinsics.h +89 -0
  410. data/lib/libv8/v8/src/mksnapshot.cc +36 -4
  411. data/lib/libv8/v8/src/natives.h +5 -2
  412. data/lib/libv8/v8/src/objects-debug.cc +73 -6
  413. data/lib/libv8/v8/src/objects-inl.h +529 -164
  414. data/lib/libv8/v8/src/objects-printer.cc +67 -12
  415. data/lib/libv8/v8/src/objects-visiting.cc +13 -2
  416. data/lib/libv8/v8/src/objects-visiting.h +41 -1
  417. data/lib/libv8/v8/src/objects.cc +2200 -1177
  418. data/lib/libv8/v8/src/objects.h +912 -283
  419. data/lib/libv8/v8/src/parser.cc +566 -371
  420. data/lib/libv8/v8/src/parser.h +35 -33
  421. data/lib/libv8/v8/src/platform-cygwin.cc +10 -25
  422. data/lib/libv8/v8/src/platform-freebsd.cc +4 -29
  423. data/lib/libv8/v8/src/platform-linux.cc +60 -57
  424. data/lib/libv8/v8/src/platform-macos.cc +4 -27
  425. data/lib/libv8/v8/src/platform-nullos.cc +3 -16
  426. data/lib/libv8/v8/src/platform-openbsd.cc +247 -85
  427. data/lib/libv8/v8/src/platform-posix.cc +43 -1
  428. data/lib/libv8/v8/src/platform-solaris.cc +151 -112
  429. data/lib/libv8/v8/src/platform-tls.h +1 -1
  430. data/lib/libv8/v8/src/platform-win32.cc +65 -39
  431. data/lib/libv8/v8/src/platform.h +17 -14
  432. data/lib/libv8/v8/src/preparse-data-format.h +2 -2
  433. data/lib/libv8/v8/src/preparse-data.h +8 -2
  434. data/lib/libv8/v8/src/preparser-api.cc +2 -18
  435. data/lib/libv8/v8/src/preparser.cc +106 -65
  436. data/lib/libv8/v8/src/preparser.h +26 -5
  437. data/lib/libv8/v8/src/prettyprinter.cc +25 -43
  438. data/lib/libv8/v8/src/profile-generator-inl.h +0 -4
  439. data/lib/libv8/v8/src/profile-generator.cc +213 -34
  440. data/lib/libv8/v8/src/profile-generator.h +9 -9
  441. data/lib/libv8/v8/src/property.h +1 -0
  442. data/lib/libv8/v8/src/proxy.js +74 -4
  443. data/lib/libv8/v8/src/regexp-macro-assembler.cc +10 -6
  444. data/lib/libv8/v8/src/regexp.js +16 -11
  445. data/lib/libv8/v8/src/rewriter.cc +24 -133
  446. data/lib/libv8/v8/src/runtime-profiler.cc +27 -151
  447. data/lib/libv8/v8/src/runtime-profiler.h +5 -31
  448. data/lib/libv8/v8/src/runtime.cc +1450 -681
  449. data/lib/libv8/v8/src/runtime.h +47 -31
  450. data/lib/libv8/v8/src/runtime.js +2 -1
  451. data/lib/libv8/v8/src/scanner-base.cc +358 -220
  452. data/lib/libv8/v8/src/scanner-base.h +30 -138
  453. data/lib/libv8/v8/src/scanner.cc +0 -18
  454. data/lib/libv8/v8/src/scanner.h +0 -15
  455. data/lib/libv8/v8/src/scopeinfo.cc +3 -1
  456. data/lib/libv8/v8/src/scopeinfo.h +1 -6
  457. data/lib/libv8/v8/src/scopes.cc +243 -253
  458. data/lib/libv8/v8/src/scopes.h +58 -109
  459. data/lib/libv8/v8/src/serialize.cc +12 -54
  460. data/lib/libv8/v8/src/serialize.h +47 -0
  461. data/lib/libv8/v8/src/small-pointer-list.h +25 -0
  462. data/lib/libv8/v8/src/spaces-inl.h +4 -50
  463. data/lib/libv8/v8/src/spaces.cc +64 -131
  464. data/lib/libv8/v8/src/spaces.h +19 -70
  465. data/lib/libv8/v8/src/string-stream.cc +3 -1
  466. data/lib/libv8/v8/src/string.js +10 -6
  467. data/lib/libv8/v8/src/strtod.cc +7 -3
  468. data/lib/libv8/v8/src/stub-cache.cc +59 -129
  469. data/lib/libv8/v8/src/stub-cache.h +42 -54
  470. data/lib/libv8/v8/src/third_party/valgrind/valgrind.h +1447 -1339
  471. data/lib/libv8/v8/src/token.cc +4 -4
  472. data/lib/libv8/v8/src/token.h +6 -5
  473. data/lib/libv8/v8/src/type-info.cc +173 -129
  474. data/lib/libv8/v8/src/type-info.h +40 -22
  475. data/lib/libv8/v8/src/utils.cc +25 -304
  476. data/lib/libv8/v8/src/utils.h +118 -3
  477. data/lib/libv8/v8/src/v8-counters.h +3 -6
  478. data/lib/libv8/v8/src/v8.cc +34 -27
  479. data/lib/libv8/v8/src/v8.h +7 -7
  480. data/lib/libv8/v8/src/v8conversions.cc +129 -0
  481. data/lib/libv8/v8/src/v8conversions.h +60 -0
  482. data/lib/libv8/v8/src/v8globals.h +15 -6
  483. data/lib/libv8/v8/src/v8natives.js +300 -78
  484. data/lib/libv8/v8/src/v8threads.cc +14 -6
  485. data/lib/libv8/v8/src/v8threads.h +4 -1
  486. data/lib/libv8/v8/src/v8utils.cc +360 -0
  487. data/lib/libv8/v8/src/v8utils.h +17 -66
  488. data/lib/libv8/v8/src/variables.cc +7 -12
  489. data/lib/libv8/v8/src/variables.h +12 -10
  490. data/lib/libv8/v8/src/version.cc +2 -2
  491. data/lib/libv8/v8/src/vm-state-inl.h +0 -41
  492. data/lib/libv8/v8/src/vm-state.h +0 -11
  493. data/lib/libv8/v8/src/weakmap.js +103 -0
  494. data/lib/libv8/v8/src/x64/assembler-x64.h +6 -3
  495. data/lib/libv8/v8/src/x64/builtins-x64.cc +25 -22
  496. data/lib/libv8/v8/src/x64/code-stubs-x64.cc +523 -250
  497. data/lib/libv8/v8/src/x64/code-stubs-x64.h +8 -71
  498. data/lib/libv8/v8/src/x64/codegen-x64.cc +1 -0
  499. data/lib/libv8/v8/src/x64/codegen-x64.h +0 -2
  500. data/lib/libv8/v8/src/x64/cpu-x64.cc +2 -1
  501. data/lib/libv8/v8/src/x64/deoptimizer-x64.cc +40 -8
  502. data/lib/libv8/v8/src/x64/disasm-x64.cc +12 -10
  503. data/lib/libv8/v8/src/x64/frames-x64.h +7 -6
  504. data/lib/libv8/v8/src/x64/full-codegen-x64.cc +310 -415
  505. data/lib/libv8/v8/src/x64/ic-x64.cc +180 -117
  506. data/lib/libv8/v8/src/x64/lithium-codegen-x64.cc +411 -523
  507. data/lib/libv8/v8/src/x64/lithium-codegen-x64.h +11 -6
  508. data/lib/libv8/v8/src/x64/lithium-x64.cc +191 -216
  509. data/lib/libv8/v8/src/x64/lithium-x64.h +112 -263
  510. data/lib/libv8/v8/src/x64/macro-assembler-x64.cc +177 -61
  511. data/lib/libv8/v8/src/x64/macro-assembler-x64.h +23 -7
  512. data/lib/libv8/v8/src/x64/regexp-macro-assembler-x64.cc +21 -9
  513. data/lib/libv8/v8/src/x64/regexp-macro-assembler-x64.h +6 -0
  514. data/lib/libv8/v8/src/x64/stub-cache-x64.cc +273 -107
  515. data/lib/libv8/v8/src/zone.cc +31 -22
  516. data/lib/libv8/v8/src/zone.h +12 -6
  517. data/lib/libv8/v8/tools/codemap.js +8 -0
  518. data/lib/libv8/v8/tools/gcmole/Makefile +43 -0
  519. data/lib/libv8/v8/tools/gcmole/gcmole.lua +0 -2
  520. data/lib/libv8/v8/tools/gdb-v8-support.py +154 -0
  521. data/lib/libv8/v8/tools/grokdump.py +44 -35
  522. data/lib/libv8/v8/tools/gyp/v8.gyp +94 -248
  523. data/lib/libv8/v8/tools/js2c.py +83 -52
  524. data/lib/libv8/v8/tools/linux-tick-processor +4 -6
  525. data/lib/libv8/v8/tools/ll_prof.py +3 -3
  526. data/lib/libv8/v8/tools/oom_dump/README +3 -1
  527. data/lib/libv8/v8/tools/presubmit.py +11 -4
  528. data/lib/libv8/v8/tools/profile.js +46 -2
  529. data/lib/libv8/v8/tools/splaytree.js +11 -0
  530. data/lib/libv8/v8/tools/stats-viewer.py +15 -11
  531. data/lib/libv8/v8/tools/test-wrapper-gypbuild.py +227 -0
  532. data/lib/libv8/v8/tools/test.py +28 -8
  533. data/lib/libv8/v8/tools/tickprocessor.js +0 -16
  534. data/lib/libv8/version.rb +1 -1
  535. data/libv8.gemspec +2 -2
  536. metadata +31 -19
  537. data/lib/libv8/scons/engine/SCons/Tool/f03.py +0 -63
  538. data/lib/libv8/v8/src/json-parser.cc +0 -504
@@ -28,693 +28,15 @@
28
28
  #include <stdarg.h>
29
29
  #include <limits.h>
30
30
 
31
- #include "v8.h"
32
-
33
31
  #include "conversions-inl.h"
34
32
  #include "dtoa.h"
35
- #include "factory.h"
36
33
  #include "scanner-base.h"
37
34
  #include "strtod.h"
35
+ #include "utils.h"
38
36
 
39
37
  namespace v8 {
40
38
  namespace internal {
41
39
 
42
- namespace {
43
-
44
- // C++-style iterator adaptor for StringInputBuffer
45
- // (unlike C++ iterators the end-marker has different type).
46
- class StringInputBufferIterator {
47
- public:
48
- class EndMarker {};
49
-
50
- explicit StringInputBufferIterator(StringInputBuffer* buffer);
51
-
52
- int operator*() const;
53
- void operator++();
54
- bool operator==(EndMarker const&) const { return end_; }
55
- bool operator!=(EndMarker const& m) const { return !end_; }
56
-
57
- private:
58
- StringInputBuffer* const buffer_;
59
- int current_;
60
- bool end_;
61
- };
62
-
63
-
64
- StringInputBufferIterator::StringInputBufferIterator(
65
- StringInputBuffer* buffer) : buffer_(buffer) {
66
- ++(*this);
67
- }
68
-
69
- int StringInputBufferIterator::operator*() const {
70
- return current_;
71
- }
72
-
73
-
74
- void StringInputBufferIterator::operator++() {
75
- end_ = !buffer_->has_more();
76
- if (!end_) {
77
- current_ = buffer_->GetNext();
78
- }
79
- }
80
- }
81
-
82
-
83
- template <class Iterator, class EndMark>
84
- static bool SubStringEquals(Iterator* current,
85
- EndMark end,
86
- const char* substring) {
87
- ASSERT(**current == *substring);
88
- for (substring++; *substring != '\0'; substring++) {
89
- ++*current;
90
- if (*current == end || **current != *substring) return false;
91
- }
92
- ++*current;
93
- return true;
94
- }
95
-
96
-
97
- // Maximum number of significant digits in decimal representation.
98
- // The longest possible double in decimal representation is
99
- // (2^53 - 1) * 2 ^ -1074 that is (2 ^ 53 - 1) * 5 ^ 1074 / 10 ^ 1074
100
- // (768 digits). If we parse a number whose first digits are equal to a
101
- // mean of 2 adjacent doubles (that could have up to 769 digits) the result
102
- // must be rounded to the bigger one unless the tail consists of zeros, so
103
- // we don't need to preserve all the digits.
104
- const int kMaxSignificantDigits = 772;
105
-
106
-
107
- static const double JUNK_STRING_VALUE = OS::nan_value();
108
-
109
-
110
- // Returns true if a nonspace found and false if the end has reached.
111
- template <class Iterator, class EndMark>
112
- static inline bool AdvanceToNonspace(UnicodeCache* unicode_cache,
113
- Iterator* current,
114
- EndMark end) {
115
- while (*current != end) {
116
- if (!unicode_cache->IsWhiteSpace(**current)) return true;
117
- ++*current;
118
- }
119
- return false;
120
- }
121
-
122
-
123
- static bool isDigit(int x, int radix) {
124
- return (x >= '0' && x <= '9' && x < '0' + radix)
125
- || (radix > 10 && x >= 'a' && x < 'a' + radix - 10)
126
- || (radix > 10 && x >= 'A' && x < 'A' + radix - 10);
127
- }
128
-
129
-
130
- static double SignedZero(bool negative) {
131
- return negative ? -0.0 : 0.0;
132
- }
133
-
134
-
135
- // Parsing integers with radix 2, 4, 8, 16, 32. Assumes current != end.
136
- template <int radix_log_2, class Iterator, class EndMark>
137
- static double InternalStringToIntDouble(UnicodeCache* unicode_cache,
138
- Iterator current,
139
- EndMark end,
140
- bool negative,
141
- bool allow_trailing_junk) {
142
- ASSERT(current != end);
143
-
144
- // Skip leading 0s.
145
- while (*current == '0') {
146
- ++current;
147
- if (current == end) return SignedZero(negative);
148
- }
149
-
150
- int64_t number = 0;
151
- int exponent = 0;
152
- const int radix = (1 << radix_log_2);
153
-
154
- do {
155
- int digit;
156
- if (*current >= '0' && *current <= '9' && *current < '0' + radix) {
157
- digit = static_cast<char>(*current) - '0';
158
- } else if (radix > 10 && *current >= 'a' && *current < 'a' + radix - 10) {
159
- digit = static_cast<char>(*current) - 'a' + 10;
160
- } else if (radix > 10 && *current >= 'A' && *current < 'A' + radix - 10) {
161
- digit = static_cast<char>(*current) - 'A' + 10;
162
- } else {
163
- if (allow_trailing_junk ||
164
- !AdvanceToNonspace(unicode_cache, &current, end)) {
165
- break;
166
- } else {
167
- return JUNK_STRING_VALUE;
168
- }
169
- }
170
-
171
- number = number * radix + digit;
172
- int overflow = static_cast<int>(number >> 53);
173
- if (overflow != 0) {
174
- // Overflow occurred. Need to determine which direction to round the
175
- // result.
176
- int overflow_bits_count = 1;
177
- while (overflow > 1) {
178
- overflow_bits_count++;
179
- overflow >>= 1;
180
- }
181
-
182
- int dropped_bits_mask = ((1 << overflow_bits_count) - 1);
183
- int dropped_bits = static_cast<int>(number) & dropped_bits_mask;
184
- number >>= overflow_bits_count;
185
- exponent = overflow_bits_count;
186
-
187
- bool zero_tail = true;
188
- while (true) {
189
- ++current;
190
- if (current == end || !isDigit(*current, radix)) break;
191
- zero_tail = zero_tail && *current == '0';
192
- exponent += radix_log_2;
193
- }
194
-
195
- if (!allow_trailing_junk &&
196
- AdvanceToNonspace(unicode_cache, &current, end)) {
197
- return JUNK_STRING_VALUE;
198
- }
199
-
200
- int middle_value = (1 << (overflow_bits_count - 1));
201
- if (dropped_bits > middle_value) {
202
- number++; // Rounding up.
203
- } else if (dropped_bits == middle_value) {
204
- // Rounding to even to consistency with decimals: half-way case rounds
205
- // up if significant part is odd and down otherwise.
206
- if ((number & 1) != 0 || !zero_tail) {
207
- number++; // Rounding up.
208
- }
209
- }
210
-
211
- // Rounding up may cause overflow.
212
- if ((number & ((int64_t)1 << 53)) != 0) {
213
- exponent++;
214
- number >>= 1;
215
- }
216
- break;
217
- }
218
- ++current;
219
- } while (current != end);
220
-
221
- ASSERT(number < ((int64_t)1 << 53));
222
- ASSERT(static_cast<int64_t>(static_cast<double>(number)) == number);
223
-
224
- if (exponent == 0) {
225
- if (negative) {
226
- if (number == 0) return -0.0;
227
- number = -number;
228
- }
229
- return static_cast<double>(number);
230
- }
231
-
232
- ASSERT(number != 0);
233
- // The double could be constructed faster from number (mantissa), exponent
234
- // and sign. Assuming it's a rare case more simple code is used.
235
- return static_cast<double>(negative ? -number : number) * pow(2.0, exponent);
236
- }
237
-
238
-
239
- template <class Iterator, class EndMark>
240
- static double InternalStringToInt(UnicodeCache* unicode_cache,
241
- Iterator current,
242
- EndMark end,
243
- int radix) {
244
- const bool allow_trailing_junk = true;
245
- const double empty_string_val = JUNK_STRING_VALUE;
246
-
247
- if (!AdvanceToNonspace(unicode_cache, &current, end)) {
248
- return empty_string_val;
249
- }
250
-
251
- bool negative = false;
252
- bool leading_zero = false;
253
-
254
- if (*current == '+') {
255
- // Ignore leading sign; skip following spaces.
256
- ++current;
257
- if (current == end) {
258
- return JUNK_STRING_VALUE;
259
- }
260
- } else if (*current == '-') {
261
- ++current;
262
- if (current == end) {
263
- return JUNK_STRING_VALUE;
264
- }
265
- negative = true;
266
- }
267
-
268
- if (radix == 0) {
269
- // Radix detection.
270
- if (*current == '0') {
271
- ++current;
272
- if (current == end) return SignedZero(negative);
273
- if (*current == 'x' || *current == 'X') {
274
- radix = 16;
275
- ++current;
276
- if (current == end) return JUNK_STRING_VALUE;
277
- } else {
278
- radix = 8;
279
- leading_zero = true;
280
- }
281
- } else {
282
- radix = 10;
283
- }
284
- } else if (radix == 16) {
285
- if (*current == '0') {
286
- // Allow "0x" prefix.
287
- ++current;
288
- if (current == end) return SignedZero(negative);
289
- if (*current == 'x' || *current == 'X') {
290
- ++current;
291
- if (current == end) return JUNK_STRING_VALUE;
292
- } else {
293
- leading_zero = true;
294
- }
295
- }
296
- }
297
-
298
- if (radix < 2 || radix > 36) return JUNK_STRING_VALUE;
299
-
300
- // Skip leading zeros.
301
- while (*current == '0') {
302
- leading_zero = true;
303
- ++current;
304
- if (current == end) return SignedZero(negative);
305
- }
306
-
307
- if (!leading_zero && !isDigit(*current, radix)) {
308
- return JUNK_STRING_VALUE;
309
- }
310
-
311
- if (IsPowerOf2(radix)) {
312
- switch (radix) {
313
- case 2:
314
- return InternalStringToIntDouble<1>(
315
- unicode_cache, current, end, negative, allow_trailing_junk);
316
- case 4:
317
- return InternalStringToIntDouble<2>(
318
- unicode_cache, current, end, negative, allow_trailing_junk);
319
- case 8:
320
- return InternalStringToIntDouble<3>(
321
- unicode_cache, current, end, negative, allow_trailing_junk);
322
-
323
- case 16:
324
- return InternalStringToIntDouble<4>(
325
- unicode_cache, current, end, negative, allow_trailing_junk);
326
-
327
- case 32:
328
- return InternalStringToIntDouble<5>(
329
- unicode_cache, current, end, negative, allow_trailing_junk);
330
- default:
331
- UNREACHABLE();
332
- }
333
- }
334
-
335
- if (radix == 10) {
336
- // Parsing with strtod.
337
- const int kMaxSignificantDigits = 309; // Doubles are less than 1.8e308.
338
- // The buffer may contain up to kMaxSignificantDigits + 1 digits and a zero
339
- // end.
340
- const int kBufferSize = kMaxSignificantDigits + 2;
341
- char buffer[kBufferSize];
342
- int buffer_pos = 0;
343
- while (*current >= '0' && *current <= '9') {
344
- if (buffer_pos <= kMaxSignificantDigits) {
345
- // If the number has more than kMaxSignificantDigits it will be parsed
346
- // as infinity.
347
- ASSERT(buffer_pos < kBufferSize);
348
- buffer[buffer_pos++] = static_cast<char>(*current);
349
- }
350
- ++current;
351
- if (current == end) break;
352
- }
353
-
354
- if (!allow_trailing_junk &&
355
- AdvanceToNonspace(unicode_cache, &current, end)) {
356
- return JUNK_STRING_VALUE;
357
- }
358
-
359
- ASSERT(buffer_pos < kBufferSize);
360
- buffer[buffer_pos] = '\0';
361
- Vector<const char> buffer_vector(buffer, buffer_pos);
362
- return negative ? -Strtod(buffer_vector, 0) : Strtod(buffer_vector, 0);
363
- }
364
-
365
- // The following code causes accumulating rounding error for numbers greater
366
- // than ~2^56. It's explicitly allowed in the spec: "if R is not 2, 4, 8, 10,
367
- // 16, or 32, then mathInt may be an implementation-dependent approximation to
368
- // the mathematical integer value" (15.1.2.2).
369
-
370
- int lim_0 = '0' + (radix < 10 ? radix : 10);
371
- int lim_a = 'a' + (radix - 10);
372
- int lim_A = 'A' + (radix - 10);
373
-
374
- // NOTE: The code for computing the value may seem a bit complex at
375
- // first glance. It is structured to use 32-bit multiply-and-add
376
- // loops as long as possible to avoid loosing precision.
377
-
378
- double v = 0.0;
379
- bool done = false;
380
- do {
381
- // Parse the longest part of the string starting at index j
382
- // possible while keeping the multiplier, and thus the part
383
- // itself, within 32 bits.
384
- unsigned int part = 0, multiplier = 1;
385
- while (true) {
386
- int d;
387
- if (*current >= '0' && *current < lim_0) {
388
- d = *current - '0';
389
- } else if (*current >= 'a' && *current < lim_a) {
390
- d = *current - 'a' + 10;
391
- } else if (*current >= 'A' && *current < lim_A) {
392
- d = *current - 'A' + 10;
393
- } else {
394
- done = true;
395
- break;
396
- }
397
-
398
- // Update the value of the part as long as the multiplier fits
399
- // in 32 bits. When we can't guarantee that the next iteration
400
- // will not overflow the multiplier, we stop parsing the part
401
- // by leaving the loop.
402
- const unsigned int kMaximumMultiplier = 0xffffffffU / 36;
403
- uint32_t m = multiplier * radix;
404
- if (m > kMaximumMultiplier) break;
405
- part = part * radix + d;
406
- multiplier = m;
407
- ASSERT(multiplier > part);
408
-
409
- ++current;
410
- if (current == end) {
411
- done = true;
412
- break;
413
- }
414
- }
415
-
416
- // Update the value and skip the part in the string.
417
- v = v * multiplier + part;
418
- } while (!done);
419
-
420
- if (!allow_trailing_junk &&
421
- AdvanceToNonspace(unicode_cache, &current, end)) {
422
- return JUNK_STRING_VALUE;
423
- }
424
-
425
- return negative ? -v : v;
426
- }
427
-
428
-
429
- // Converts a string to a double value. Assumes the Iterator supports
430
- // the following operations:
431
- // 1. current == end (other ops are not allowed), current != end.
432
- // 2. *current - gets the current character in the sequence.
433
- // 3. ++current (advances the position).
434
- template <class Iterator, class EndMark>
435
- static double InternalStringToDouble(UnicodeCache* unicode_cache,
436
- Iterator current,
437
- EndMark end,
438
- int flags,
439
- double empty_string_val) {
440
- // To make sure that iterator dereferencing is valid the following
441
- // convention is used:
442
- // 1. Each '++current' statement is followed by check for equality to 'end'.
443
- // 2. If AdvanceToNonspace returned false then current == end.
444
- // 3. If 'current' becomes be equal to 'end' the function returns or goes to
445
- // 'parsing_done'.
446
- // 4. 'current' is not dereferenced after the 'parsing_done' label.
447
- // 5. Code before 'parsing_done' may rely on 'current != end'.
448
- if (!AdvanceToNonspace(unicode_cache, &current, end)) {
449
- return empty_string_val;
450
- }
451
-
452
- const bool allow_trailing_junk = (flags & ALLOW_TRAILING_JUNK) != 0;
453
-
454
- // The longest form of simplified number is: "-<significant digits>'.1eXXX\0".
455
- const int kBufferSize = kMaxSignificantDigits + 10;
456
- char buffer[kBufferSize]; // NOLINT: size is known at compile time.
457
- int buffer_pos = 0;
458
-
459
- // Exponent will be adjusted if insignificant digits of the integer part
460
- // or insignificant leading zeros of the fractional part are dropped.
461
- int exponent = 0;
462
- int significant_digits = 0;
463
- int insignificant_digits = 0;
464
- bool nonzero_digit_dropped = false;
465
- bool fractional_part = false;
466
-
467
- bool negative = false;
468
-
469
- if (*current == '+') {
470
- // Ignore leading sign.
471
- ++current;
472
- if (current == end) return JUNK_STRING_VALUE;
473
- } else if (*current == '-') {
474
- ++current;
475
- if (current == end) return JUNK_STRING_VALUE;
476
- negative = true;
477
- }
478
-
479
- static const char kInfinitySymbol[] = "Infinity";
480
- if (*current == kInfinitySymbol[0]) {
481
- if (!SubStringEquals(&current, end, kInfinitySymbol)) {
482
- return JUNK_STRING_VALUE;
483
- }
484
-
485
- if (!allow_trailing_junk &&
486
- AdvanceToNonspace(unicode_cache, &current, end)) {
487
- return JUNK_STRING_VALUE;
488
- }
489
-
490
- ASSERT(buffer_pos == 0);
491
- return negative ? -V8_INFINITY : V8_INFINITY;
492
- }
493
-
494
- bool leading_zero = false;
495
- if (*current == '0') {
496
- ++current;
497
- if (current == end) return SignedZero(negative);
498
-
499
- leading_zero = true;
500
-
501
- // It could be hexadecimal value.
502
- if ((flags & ALLOW_HEX) && (*current == 'x' || *current == 'X')) {
503
- ++current;
504
- if (current == end || !isDigit(*current, 16)) {
505
- return JUNK_STRING_VALUE; // "0x".
506
- }
507
-
508
- return InternalStringToIntDouble<4>(unicode_cache,
509
- current,
510
- end,
511
- negative,
512
- allow_trailing_junk);
513
- }
514
-
515
- // Ignore leading zeros in the integer part.
516
- while (*current == '0') {
517
- ++current;
518
- if (current == end) return SignedZero(negative);
519
- }
520
- }
521
-
522
- bool octal = leading_zero && (flags & ALLOW_OCTALS) != 0;
523
-
524
- // Copy significant digits of the integer part (if any) to the buffer.
525
- while (*current >= '0' && *current <= '9') {
526
- if (significant_digits < kMaxSignificantDigits) {
527
- ASSERT(buffer_pos < kBufferSize);
528
- buffer[buffer_pos++] = static_cast<char>(*current);
529
- significant_digits++;
530
- // Will later check if it's an octal in the buffer.
531
- } else {
532
- insignificant_digits++; // Move the digit into the exponential part.
533
- nonzero_digit_dropped = nonzero_digit_dropped || *current != '0';
534
- }
535
- octal = octal && *current < '8';
536
- ++current;
537
- if (current == end) goto parsing_done;
538
- }
539
-
540
- if (significant_digits == 0) {
541
- octal = false;
542
- }
543
-
544
- if (*current == '.') {
545
- if (octal && !allow_trailing_junk) return JUNK_STRING_VALUE;
546
- if (octal) goto parsing_done;
547
-
548
- ++current;
549
- if (current == end) {
550
- if (significant_digits == 0 && !leading_zero) {
551
- return JUNK_STRING_VALUE;
552
- } else {
553
- goto parsing_done;
554
- }
555
- }
556
-
557
- if (significant_digits == 0) {
558
- // octal = false;
559
- // Integer part consists of 0 or is absent. Significant digits start after
560
- // leading zeros (if any).
561
- while (*current == '0') {
562
- ++current;
563
- if (current == end) return SignedZero(negative);
564
- exponent--; // Move this 0 into the exponent.
565
- }
566
- }
567
-
568
- // We don't emit a '.', but adjust the exponent instead.
569
- fractional_part = true;
570
-
571
- // There is a fractional part.
572
- while (*current >= '0' && *current <= '9') {
573
- if (significant_digits < kMaxSignificantDigits) {
574
- ASSERT(buffer_pos < kBufferSize);
575
- buffer[buffer_pos++] = static_cast<char>(*current);
576
- significant_digits++;
577
- exponent--;
578
- } else {
579
- // Ignore insignificant digits in the fractional part.
580
- nonzero_digit_dropped = nonzero_digit_dropped || *current != '0';
581
- }
582
- ++current;
583
- if (current == end) goto parsing_done;
584
- }
585
- }
586
-
587
- if (!leading_zero && exponent == 0 && significant_digits == 0) {
588
- // If leading_zeros is true then the string contains zeros.
589
- // If exponent < 0 then string was [+-]\.0*...
590
- // If significant_digits != 0 the string is not equal to 0.
591
- // Otherwise there are no digits in the string.
592
- return JUNK_STRING_VALUE;
593
- }
594
-
595
- // Parse exponential part.
596
- if (*current == 'e' || *current == 'E') {
597
- if (octal) return JUNK_STRING_VALUE;
598
- ++current;
599
- if (current == end) {
600
- if (allow_trailing_junk) {
601
- goto parsing_done;
602
- } else {
603
- return JUNK_STRING_VALUE;
604
- }
605
- }
606
- char sign = '+';
607
- if (*current == '+' || *current == '-') {
608
- sign = static_cast<char>(*current);
609
- ++current;
610
- if (current == end) {
611
- if (allow_trailing_junk) {
612
- goto parsing_done;
613
- } else {
614
- return JUNK_STRING_VALUE;
615
- }
616
- }
617
- }
618
-
619
- if (current == end || *current < '0' || *current > '9') {
620
- if (allow_trailing_junk) {
621
- goto parsing_done;
622
- } else {
623
- return JUNK_STRING_VALUE;
624
- }
625
- }
626
-
627
- const int max_exponent = INT_MAX / 2;
628
- ASSERT(-max_exponent / 2 <= exponent && exponent <= max_exponent / 2);
629
- int num = 0;
630
- do {
631
- // Check overflow.
632
- int digit = *current - '0';
633
- if (num >= max_exponent / 10
634
- && !(num == max_exponent / 10 && digit <= max_exponent % 10)) {
635
- num = max_exponent;
636
- } else {
637
- num = num * 10 + digit;
638
- }
639
- ++current;
640
- } while (current != end && *current >= '0' && *current <= '9');
641
-
642
- exponent += (sign == '-' ? -num : num);
643
- }
644
-
645
- if (!allow_trailing_junk &&
646
- AdvanceToNonspace(unicode_cache, &current, end)) {
647
- return JUNK_STRING_VALUE;
648
- }
649
-
650
- parsing_done:
651
- exponent += insignificant_digits;
652
-
653
- if (octal) {
654
- return InternalStringToIntDouble<3>(unicode_cache,
655
- buffer,
656
- buffer + buffer_pos,
657
- negative,
658
- allow_trailing_junk);
659
- }
660
-
661
- if (nonzero_digit_dropped) {
662
- buffer[buffer_pos++] = '1';
663
- exponent--;
664
- }
665
-
666
- ASSERT(buffer_pos < kBufferSize);
667
- buffer[buffer_pos] = '\0';
668
-
669
- double converted = Strtod(Vector<const char>(buffer, buffer_pos), exponent);
670
- return negative ? -converted : converted;
671
- }
672
-
673
-
674
- double StringToDouble(UnicodeCache* unicode_cache,
675
- String* str, int flags, double empty_string_val) {
676
- StringShape shape(str);
677
- if (shape.IsSequentialAscii()) {
678
- const char* begin = SeqAsciiString::cast(str)->GetChars();
679
- const char* end = begin + str->length();
680
- return InternalStringToDouble(unicode_cache, begin, end, flags,
681
- empty_string_val);
682
- } else if (shape.IsSequentialTwoByte()) {
683
- const uc16* begin = SeqTwoByteString::cast(str)->GetChars();
684
- const uc16* end = begin + str->length();
685
- return InternalStringToDouble(unicode_cache, begin, end, flags,
686
- empty_string_val);
687
- } else {
688
- StringInputBuffer buffer(str);
689
- return InternalStringToDouble(unicode_cache,
690
- StringInputBufferIterator(&buffer),
691
- StringInputBufferIterator::EndMarker(),
692
- flags,
693
- empty_string_val);
694
- }
695
- }
696
-
697
-
698
- double StringToInt(UnicodeCache* unicode_cache,
699
- String* str,
700
- int radix) {
701
- StringShape shape(str);
702
- if (shape.IsSequentialAscii()) {
703
- const char* begin = SeqAsciiString::cast(str)->GetChars();
704
- const char* end = begin + str->length();
705
- return InternalStringToInt(unicode_cache, begin, end, radix);
706
- } else if (shape.IsSequentialTwoByte()) {
707
- const uc16* begin = SeqTwoByteString::cast(str)->GetChars();
708
- const uc16* end = begin + str->length();
709
- return InternalStringToInt(unicode_cache, begin, end, radix);
710
- } else {
711
- StringInputBuffer buffer(str);
712
- return InternalStringToInt(unicode_cache,
713
- StringInputBufferIterator(&buffer),
714
- StringInputBufferIterator::EndMarker(),
715
- radix);
716
- }
717
- }
718
40
 
719
41
 
720
42
  double StringToDouble(UnicodeCache* unicode_cache,
@@ -750,7 +72,7 @@ const char* DoubleToCString(double v, Vector<char> buffer) {
750
72
  case FP_INFINITE: return (v < 0.0 ? "-Infinity" : "Infinity");
751
73
  case FP_ZERO: return "0";
752
74
  default: {
753
- StringBuilder builder(buffer.start(), buffer.length());
75
+ SimpleStringBuilder builder(buffer.start(), buffer.length());
754
76
  int decimal_point;
755
77
  int sign;
756
78
  const int kV8DtoaBufferCapacity = kBase10MaximalLength + 1;
@@ -791,7 +113,7 @@ const char* DoubleToCString(double v, Vector<char> buffer) {
791
113
  builder.AddCharacter((decimal_point >= 0) ? '+' : '-');
792
114
  int exponent = decimal_point - 1;
793
115
  if (exponent < 0) exponent = -exponent;
794
- builder.AddFormatted("%d", exponent);
116
+ builder.AddDecimalInteger(exponent);
795
117
  }
796
118
  return builder.Finalize();
797
119
  }
@@ -869,7 +191,7 @@ char* DoubleToFixedCString(double value, int f) {
869
191
 
870
192
  unsigned rep_length =
871
193
  zero_prefix_length + decimal_rep_length + zero_postfix_length;
872
- StringBuilder rep_builder(rep_length + 1);
194
+ SimpleStringBuilder rep_builder(rep_length + 1);
873
195
  rep_builder.AddPadding('0', zero_prefix_length);
874
196
  rep_builder.AddString(decimal_rep);
875
197
  rep_builder.AddPadding('0', zero_postfix_length);
@@ -878,7 +200,7 @@ char* DoubleToFixedCString(double value, int f) {
878
200
  // Create the result string by appending a minus and putting in a
879
201
  // decimal point if needed.
880
202
  unsigned result_size = decimal_point + f + 2;
881
- StringBuilder builder(result_size + 1);
203
+ SimpleStringBuilder builder(result_size + 1);
882
204
  if (negative) builder.AddCharacter('-');
883
205
  builder.AddSubstring(rep, decimal_point);
884
206
  if (f > 0) {
@@ -904,7 +226,7 @@ static char* CreateExponentialRepresentation(char* decimal_rep,
904
226
  // letter 'e', a minus or a plus depending on the exponent, and a
905
227
  // three digit exponent.
906
228
  unsigned result_size = significant_digits + 7;
907
- StringBuilder builder(result_size + 1);
229
+ SimpleStringBuilder builder(result_size + 1);
908
230
 
909
231
  if (negative) builder.AddCharacter('-');
910
232
  builder.AddCharacter(decimal_rep[0]);
@@ -917,7 +239,7 @@ static char* CreateExponentialRepresentation(char* decimal_rep,
917
239
 
918
240
  builder.AddCharacter('e');
919
241
  builder.AddCharacter(negative_exponent ? '-' : '+');
920
- builder.AddFormatted("%d", exponent);
242
+ builder.AddDecimalInteger(exponent);
921
243
  return builder.Finalize();
922
244
  }
923
245
 
@@ -1009,7 +331,7 @@ char* DoubleToPrecisionCString(double value, int p) {
1009
331
  unsigned result_size = (decimal_point <= 0)
1010
332
  ? -decimal_point + p + 3
1011
333
  : p + 2;
1012
- StringBuilder builder(result_size + 1);
334
+ SimpleStringBuilder builder(result_size + 1);
1013
335
  if (negative) builder.AddCharacter('-');
1014
336
  if (decimal_point <= 0) {
1015
337
  builder.AddString("0.");
@@ -1101,31 +423,11 @@ char* DoubleToRadixCString(double value, int radix) {
1101
423
  // If the number has a decimal part, leave room for the period.
1102
424
  if (decimal_pos > 0) result_size++;
1103
425
  // Allocate result and fill in the parts.
1104
- StringBuilder builder(result_size + 1);
426
+ SimpleStringBuilder builder(result_size + 1);
1105
427
  builder.AddSubstring(integer_buffer + integer_pos + 1, integer_part_size);
1106
428
  if (decimal_pos > 0) builder.AddCharacter('.');
1107
429
  builder.AddSubstring(decimal_buffer, decimal_pos);
1108
430
  return builder.Finalize();
1109
431
  }
1110
432
 
1111
-
1112
- static Mutex* dtoa_lock_one = OS::CreateMutex();
1113
- static Mutex* dtoa_lock_zero = OS::CreateMutex();
1114
-
1115
-
1116
433
  } } // namespace v8::internal
1117
-
1118
-
1119
- extern "C" {
1120
- void ACQUIRE_DTOA_LOCK(int n) {
1121
- ASSERT(n == 0 || n == 1);
1122
- (n == 0 ? v8::internal::dtoa_lock_zero : v8::internal::dtoa_lock_one)->Lock();
1123
- }
1124
-
1125
-
1126
- void FREE_DTOA_LOCK(int n) {
1127
- ASSERT(n == 0 || n == 1);
1128
- (n == 0 ? v8::internal::dtoa_lock_zero : v8::internal::dtoa_lock_one)->
1129
- Unlock();
1130
- }
1131
- }