libv8-freebsd 3.3.10.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (703) hide show
  1. data/.gitignore +9 -0
  2. data/.gitmodules +3 -0
  3. data/Gemfile +4 -0
  4. data/README.md +75 -0
  5. data/Rakefile +115 -0
  6. data/ext/libv8/extconf.rb +27 -0
  7. data/lib/libv8.rb +15 -0
  8. data/lib/libv8/Makefile +39 -0
  9. data/lib/libv8/detect_cpu.rb +27 -0
  10. data/lib/libv8/fpic-on-freebsd-amd64.patch +16 -0
  11. data/lib/libv8/fpic-on-linux-amd64.patch +13 -0
  12. data/lib/libv8/scons/CHANGES.txt +5541 -0
  13. data/lib/libv8/scons/LICENSE.txt +20 -0
  14. data/lib/libv8/scons/MANIFEST +200 -0
  15. data/lib/libv8/scons/PKG-INFO +13 -0
  16. data/lib/libv8/scons/README.txt +243 -0
  17. data/lib/libv8/scons/RELEASE.txt +100 -0
  18. data/lib/libv8/scons/engine/SCons/Action.py +1257 -0
  19. data/lib/libv8/scons/engine/SCons/Builder.py +877 -0
  20. data/lib/libv8/scons/engine/SCons/CacheDir.py +216 -0
  21. data/lib/libv8/scons/engine/SCons/Conftest.py +793 -0
  22. data/lib/libv8/scons/engine/SCons/Debug.py +220 -0
  23. data/lib/libv8/scons/engine/SCons/Defaults.py +494 -0
  24. data/lib/libv8/scons/engine/SCons/Environment.py +2417 -0
  25. data/lib/libv8/scons/engine/SCons/Errors.py +205 -0
  26. data/lib/libv8/scons/engine/SCons/Executor.py +633 -0
  27. data/lib/libv8/scons/engine/SCons/Job.py +435 -0
  28. data/lib/libv8/scons/engine/SCons/Memoize.py +244 -0
  29. data/lib/libv8/scons/engine/SCons/Node/Alias.py +152 -0
  30. data/lib/libv8/scons/engine/SCons/Node/FS.py +3302 -0
  31. data/lib/libv8/scons/engine/SCons/Node/Python.py +128 -0
  32. data/lib/libv8/scons/engine/SCons/Node/__init__.py +1329 -0
  33. data/lib/libv8/scons/engine/SCons/Options/BoolOption.py +50 -0
  34. data/lib/libv8/scons/engine/SCons/Options/EnumOption.py +50 -0
  35. data/lib/libv8/scons/engine/SCons/Options/ListOption.py +50 -0
  36. data/lib/libv8/scons/engine/SCons/Options/PackageOption.py +50 -0
  37. data/lib/libv8/scons/engine/SCons/Options/PathOption.py +76 -0
  38. data/lib/libv8/scons/engine/SCons/Options/__init__.py +67 -0
  39. data/lib/libv8/scons/engine/SCons/PathList.py +231 -0
  40. data/lib/libv8/scons/engine/SCons/Platform/__init__.py +241 -0
  41. data/lib/libv8/scons/engine/SCons/Platform/aix.py +69 -0
  42. data/lib/libv8/scons/engine/SCons/Platform/cygwin.py +55 -0
  43. data/lib/libv8/scons/engine/SCons/Platform/darwin.py +70 -0
  44. data/lib/libv8/scons/engine/SCons/Platform/hpux.py +46 -0
  45. data/lib/libv8/scons/engine/SCons/Platform/irix.py +44 -0
  46. data/lib/libv8/scons/engine/SCons/Platform/os2.py +58 -0
  47. data/lib/libv8/scons/engine/SCons/Platform/posix.py +263 -0
  48. data/lib/libv8/scons/engine/SCons/Platform/sunos.py +50 -0
  49. data/lib/libv8/scons/engine/SCons/Platform/win32.py +385 -0
  50. data/lib/libv8/scons/engine/SCons/SConf.py +1030 -0
  51. data/lib/libv8/scons/engine/SCons/SConsign.py +389 -0
  52. data/lib/libv8/scons/engine/SCons/Scanner/C.py +132 -0
  53. data/lib/libv8/scons/engine/SCons/Scanner/D.py +73 -0
  54. data/lib/libv8/scons/engine/SCons/Scanner/Dir.py +109 -0
  55. data/lib/libv8/scons/engine/SCons/Scanner/Fortran.py +316 -0
  56. data/lib/libv8/scons/engine/SCons/Scanner/IDL.py +48 -0
  57. data/lib/libv8/scons/engine/SCons/Scanner/LaTeX.py +387 -0
  58. data/lib/libv8/scons/engine/SCons/Scanner/Prog.py +101 -0
  59. data/lib/libv8/scons/engine/SCons/Scanner/RC.py +55 -0
  60. data/lib/libv8/scons/engine/SCons/Scanner/__init__.py +413 -0
  61. data/lib/libv8/scons/engine/SCons/Script/Interactive.py +384 -0
  62. data/lib/libv8/scons/engine/SCons/Script/Main.py +1405 -0
  63. data/lib/libv8/scons/engine/SCons/Script/SConsOptions.py +939 -0
  64. data/lib/libv8/scons/engine/SCons/Script/SConscript.py +640 -0
  65. data/lib/libv8/scons/engine/SCons/Script/__init__.py +412 -0
  66. data/lib/libv8/scons/engine/SCons/Sig.py +63 -0
  67. data/lib/libv8/scons/engine/SCons/Subst.py +904 -0
  68. data/lib/libv8/scons/engine/SCons/Taskmaster.py +1025 -0
  69. data/lib/libv8/scons/engine/SCons/Tool/386asm.py +61 -0
  70. data/lib/libv8/scons/engine/SCons/Tool/BitKeeper.py +67 -0
  71. data/lib/libv8/scons/engine/SCons/Tool/CVS.py +73 -0
  72. data/lib/libv8/scons/engine/SCons/Tool/FortranCommon.py +263 -0
  73. data/lib/libv8/scons/engine/SCons/Tool/JavaCommon.py +323 -0
  74. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/__init__.py +56 -0
  75. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/arch.py +61 -0
  76. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/common.py +240 -0
  77. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/netframework.py +82 -0
  78. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/sdk.py +391 -0
  79. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/vc.py +459 -0
  80. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/vs.py +526 -0
  81. data/lib/libv8/scons/engine/SCons/Tool/Perforce.py +103 -0
  82. data/lib/libv8/scons/engine/SCons/Tool/PharLapCommon.py +137 -0
  83. data/lib/libv8/scons/engine/SCons/Tool/RCS.py +64 -0
  84. data/lib/libv8/scons/engine/SCons/Tool/SCCS.py +64 -0
  85. data/lib/libv8/scons/engine/SCons/Tool/Subversion.py +71 -0
  86. data/lib/libv8/scons/engine/SCons/Tool/__init__.py +681 -0
  87. data/lib/libv8/scons/engine/SCons/Tool/aixc++.py +82 -0
  88. data/lib/libv8/scons/engine/SCons/Tool/aixcc.py +74 -0
  89. data/lib/libv8/scons/engine/SCons/Tool/aixf77.py +80 -0
  90. data/lib/libv8/scons/engine/SCons/Tool/aixlink.py +76 -0
  91. data/lib/libv8/scons/engine/SCons/Tool/applelink.py +71 -0
  92. data/lib/libv8/scons/engine/SCons/Tool/ar.py +63 -0
  93. data/lib/libv8/scons/engine/SCons/Tool/as.py +78 -0
  94. data/lib/libv8/scons/engine/SCons/Tool/bcc32.py +81 -0
  95. data/lib/libv8/scons/engine/SCons/Tool/c++.py +99 -0
  96. data/lib/libv8/scons/engine/SCons/Tool/cc.py +102 -0
  97. data/lib/libv8/scons/engine/SCons/Tool/cvf.py +58 -0
  98. data/lib/libv8/scons/engine/SCons/Tool/default.py +50 -0
  99. data/lib/libv8/scons/engine/SCons/Tool/dmd.py +240 -0
  100. data/lib/libv8/scons/engine/SCons/Tool/dvi.py +64 -0
  101. data/lib/libv8/scons/engine/SCons/Tool/dvipdf.py +125 -0
  102. data/lib/libv8/scons/engine/SCons/Tool/dvips.py +95 -0
  103. data/lib/libv8/scons/engine/SCons/Tool/f03.py +63 -0
  104. data/lib/libv8/scons/engine/SCons/Tool/f77.py +62 -0
  105. data/lib/libv8/scons/engine/SCons/Tool/f90.py +62 -0
  106. data/lib/libv8/scons/engine/SCons/Tool/f95.py +63 -0
  107. data/lib/libv8/scons/engine/SCons/Tool/filesystem.py +98 -0
  108. data/lib/libv8/scons/engine/SCons/Tool/fortran.py +62 -0
  109. data/lib/libv8/scons/engine/SCons/Tool/g++.py +90 -0
  110. data/lib/libv8/scons/engine/SCons/Tool/g77.py +73 -0
  111. data/lib/libv8/scons/engine/SCons/Tool/gas.py +53 -0
  112. data/lib/libv8/scons/engine/SCons/Tool/gcc.py +80 -0
  113. data/lib/libv8/scons/engine/SCons/Tool/gfortran.py +64 -0
  114. data/lib/libv8/scons/engine/SCons/Tool/gnulink.py +62 -0
  115. data/lib/libv8/scons/engine/SCons/Tool/gs.py +81 -0
  116. data/lib/libv8/scons/engine/SCons/Tool/hpc++.py +84 -0
  117. data/lib/libv8/scons/engine/SCons/Tool/hpcc.py +53 -0
  118. data/lib/libv8/scons/engine/SCons/Tool/hplink.py +77 -0
  119. data/lib/libv8/scons/engine/SCons/Tool/icc.py +59 -0
  120. data/lib/libv8/scons/engine/SCons/Tool/icl.py +52 -0
  121. data/lib/libv8/scons/engine/SCons/Tool/ifl.py +72 -0
  122. data/lib/libv8/scons/engine/SCons/Tool/ifort.py +88 -0
  123. data/lib/libv8/scons/engine/SCons/Tool/ilink.py +59 -0
  124. data/lib/libv8/scons/engine/SCons/Tool/ilink32.py +60 -0
  125. data/lib/libv8/scons/engine/SCons/Tool/install.py +283 -0
  126. data/lib/libv8/scons/engine/SCons/Tool/intelc.py +522 -0
  127. data/lib/libv8/scons/engine/SCons/Tool/ipkg.py +67 -0
  128. data/lib/libv8/scons/engine/SCons/Tool/jar.py +116 -0
  129. data/lib/libv8/scons/engine/SCons/Tool/javac.py +230 -0
  130. data/lib/libv8/scons/engine/SCons/Tool/javah.py +137 -0
  131. data/lib/libv8/scons/engine/SCons/Tool/latex.py +80 -0
  132. data/lib/libv8/scons/engine/SCons/Tool/lex.py +97 -0
  133. data/lib/libv8/scons/engine/SCons/Tool/link.py +122 -0
  134. data/lib/libv8/scons/engine/SCons/Tool/linkloc.py +112 -0
  135. data/lib/libv8/scons/engine/SCons/Tool/m4.py +63 -0
  136. data/lib/libv8/scons/engine/SCons/Tool/masm.py +77 -0
  137. data/lib/libv8/scons/engine/SCons/Tool/midl.py +88 -0
  138. data/lib/libv8/scons/engine/SCons/Tool/mingw.py +179 -0
  139. data/lib/libv8/scons/engine/SCons/Tool/mslib.py +64 -0
  140. data/lib/libv8/scons/engine/SCons/Tool/mslink.py +318 -0
  141. data/lib/libv8/scons/engine/SCons/Tool/mssdk.py +50 -0
  142. data/lib/libv8/scons/engine/SCons/Tool/msvc.py +278 -0
  143. data/lib/libv8/scons/engine/SCons/Tool/msvs.py +1806 -0
  144. data/lib/libv8/scons/engine/SCons/Tool/mwcc.py +207 -0
  145. data/lib/libv8/scons/engine/SCons/Tool/mwld.py +107 -0
  146. data/lib/libv8/scons/engine/SCons/Tool/nasm.py +72 -0
  147. data/lib/libv8/scons/engine/SCons/Tool/packaging/__init__.py +312 -0
  148. data/lib/libv8/scons/engine/SCons/Tool/packaging/ipk.py +185 -0
  149. data/lib/libv8/scons/engine/SCons/Tool/packaging/msi.py +527 -0
  150. data/lib/libv8/scons/engine/SCons/Tool/packaging/rpm.py +365 -0
  151. data/lib/libv8/scons/engine/SCons/Tool/packaging/src_tarbz2.py +43 -0
  152. data/lib/libv8/scons/engine/SCons/Tool/packaging/src_targz.py +43 -0
  153. data/lib/libv8/scons/engine/SCons/Tool/packaging/src_zip.py +43 -0
  154. data/lib/libv8/scons/engine/SCons/Tool/packaging/tarbz2.py +44 -0
  155. data/lib/libv8/scons/engine/SCons/Tool/packaging/targz.py +44 -0
  156. data/lib/libv8/scons/engine/SCons/Tool/packaging/zip.py +44 -0
  157. data/lib/libv8/scons/engine/SCons/Tool/pdf.py +78 -0
  158. data/lib/libv8/scons/engine/SCons/Tool/pdflatex.py +84 -0
  159. data/lib/libv8/scons/engine/SCons/Tool/pdftex.py +109 -0
  160. data/lib/libv8/scons/engine/SCons/Tool/qt.py +336 -0
  161. data/lib/libv8/scons/engine/SCons/Tool/rmic.py +126 -0
  162. data/lib/libv8/scons/engine/SCons/Tool/rpcgen.py +70 -0
  163. data/lib/libv8/scons/engine/SCons/Tool/rpm.py +132 -0
  164. data/lib/libv8/scons/engine/SCons/Tool/sgiar.py +68 -0
  165. data/lib/libv8/scons/engine/SCons/Tool/sgic++.py +58 -0
  166. data/lib/libv8/scons/engine/SCons/Tool/sgicc.py +53 -0
  167. data/lib/libv8/scons/engine/SCons/Tool/sgilink.py +62 -0
  168. data/lib/libv8/scons/engine/SCons/Tool/sunar.py +67 -0
  169. data/lib/libv8/scons/engine/SCons/Tool/sunc++.py +142 -0
  170. data/lib/libv8/scons/engine/SCons/Tool/suncc.py +58 -0
  171. data/lib/libv8/scons/engine/SCons/Tool/sunf77.py +63 -0
  172. data/lib/libv8/scons/engine/SCons/Tool/sunf90.py +64 -0
  173. data/lib/libv8/scons/engine/SCons/Tool/sunf95.py +64 -0
  174. data/lib/libv8/scons/engine/SCons/Tool/sunlink.py +76 -0
  175. data/lib/libv8/scons/engine/SCons/Tool/swig.py +183 -0
  176. data/lib/libv8/scons/engine/SCons/Tool/tar.py +73 -0
  177. data/lib/libv8/scons/engine/SCons/Tool/tex.py +866 -0
  178. data/lib/libv8/scons/engine/SCons/Tool/textfile.py +175 -0
  179. data/lib/libv8/scons/engine/SCons/Tool/tlib.py +53 -0
  180. data/lib/libv8/scons/engine/SCons/Tool/wix.py +99 -0
  181. data/lib/libv8/scons/engine/SCons/Tool/yacc.py +140 -0
  182. data/lib/libv8/scons/engine/SCons/Tool/zip.py +99 -0
  183. data/lib/libv8/scons/engine/SCons/Util.py +1492 -0
  184. data/lib/libv8/scons/engine/SCons/Variables/BoolVariable.py +89 -0
  185. data/lib/libv8/scons/engine/SCons/Variables/EnumVariable.py +103 -0
  186. data/lib/libv8/scons/engine/SCons/Variables/ListVariable.py +135 -0
  187. data/lib/libv8/scons/engine/SCons/Variables/PackageVariable.py +106 -0
  188. data/lib/libv8/scons/engine/SCons/Variables/PathVariable.py +147 -0
  189. data/lib/libv8/scons/engine/SCons/Variables/__init__.py +312 -0
  190. data/lib/libv8/scons/engine/SCons/Warnings.py +246 -0
  191. data/lib/libv8/scons/engine/SCons/__init__.py +49 -0
  192. data/lib/libv8/scons/engine/SCons/compat/__init__.py +237 -0
  193. data/lib/libv8/scons/engine/SCons/compat/_scons_builtins.py +150 -0
  194. data/lib/libv8/scons/engine/SCons/compat/_scons_collections.py +45 -0
  195. data/lib/libv8/scons/engine/SCons/compat/_scons_dbm.py +45 -0
  196. data/lib/libv8/scons/engine/SCons/compat/_scons_hashlib.py +76 -0
  197. data/lib/libv8/scons/engine/SCons/compat/_scons_io.py +45 -0
  198. data/lib/libv8/scons/engine/SCons/compat/_scons_sets.py +563 -0
  199. data/lib/libv8/scons/engine/SCons/compat/_scons_subprocess.py +1281 -0
  200. data/lib/libv8/scons/engine/SCons/cpp.py +589 -0
  201. data/lib/libv8/scons/engine/SCons/dblite.py +254 -0
  202. data/lib/libv8/scons/engine/SCons/exitfuncs.py +77 -0
  203. data/lib/libv8/scons/os_spawnv_fix.diff +83 -0
  204. data/lib/libv8/scons/scons-time.1 +1017 -0
  205. data/lib/libv8/scons/scons.1 +15225 -0
  206. data/lib/libv8/scons/sconsign.1 +208 -0
  207. data/lib/libv8/scons/script/scons +196 -0
  208. data/lib/libv8/scons/script/scons-time +1544 -0
  209. data/lib/libv8/scons/script/scons.bat +34 -0
  210. data/lib/libv8/scons/script/sconsign +514 -0
  211. data/lib/libv8/scons/setup.cfg +5 -0
  212. data/lib/libv8/scons/setup.py +423 -0
  213. data/lib/libv8/v8/.gitignore +35 -0
  214. data/lib/libv8/v8/AUTHORS +44 -0
  215. data/lib/libv8/v8/ChangeLog +2839 -0
  216. data/lib/libv8/v8/LICENSE +52 -0
  217. data/lib/libv8/v8/LICENSE.strongtalk +29 -0
  218. data/lib/libv8/v8/LICENSE.v8 +26 -0
  219. data/lib/libv8/v8/LICENSE.valgrind +45 -0
  220. data/lib/libv8/v8/SConstruct +1478 -0
  221. data/lib/libv8/v8/build/README.txt +49 -0
  222. data/lib/libv8/v8/build/all.gyp +18 -0
  223. data/lib/libv8/v8/build/armu.gypi +32 -0
  224. data/lib/libv8/v8/build/common.gypi +144 -0
  225. data/lib/libv8/v8/build/gyp_v8 +145 -0
  226. data/lib/libv8/v8/include/v8-debug.h +395 -0
  227. data/lib/libv8/v8/include/v8-preparser.h +117 -0
  228. data/lib/libv8/v8/include/v8-profiler.h +505 -0
  229. data/lib/libv8/v8/include/v8-testing.h +104 -0
  230. data/lib/libv8/v8/include/v8.h +4124 -0
  231. data/lib/libv8/v8/include/v8stdint.h +53 -0
  232. data/lib/libv8/v8/preparser/SConscript +38 -0
  233. data/lib/libv8/v8/preparser/preparser-process.cc +379 -0
  234. data/lib/libv8/v8/src/SConscript +368 -0
  235. data/lib/libv8/v8/src/accessors.cc +767 -0
  236. data/lib/libv8/v8/src/accessors.h +123 -0
  237. data/lib/libv8/v8/src/allocation-inl.h +49 -0
  238. data/lib/libv8/v8/src/allocation.cc +122 -0
  239. data/lib/libv8/v8/src/allocation.h +143 -0
  240. data/lib/libv8/v8/src/api.cc +5845 -0
  241. data/lib/libv8/v8/src/api.h +574 -0
  242. data/lib/libv8/v8/src/apinatives.js +110 -0
  243. data/lib/libv8/v8/src/apiutils.h +73 -0
  244. data/lib/libv8/v8/src/arguments.h +118 -0
  245. data/lib/libv8/v8/src/arm/assembler-arm-inl.h +353 -0
  246. data/lib/libv8/v8/src/arm/assembler-arm.cc +2661 -0
  247. data/lib/libv8/v8/src/arm/assembler-arm.h +1375 -0
  248. data/lib/libv8/v8/src/arm/builtins-arm.cc +1658 -0
  249. data/lib/libv8/v8/src/arm/code-stubs-arm.cc +6398 -0
  250. data/lib/libv8/v8/src/arm/code-stubs-arm.h +673 -0
  251. data/lib/libv8/v8/src/arm/codegen-arm.cc +52 -0
  252. data/lib/libv8/v8/src/arm/codegen-arm.h +91 -0
  253. data/lib/libv8/v8/src/arm/constants-arm.cc +152 -0
  254. data/lib/libv8/v8/src/arm/constants-arm.h +775 -0
  255. data/lib/libv8/v8/src/arm/cpu-arm.cc +120 -0
  256. data/lib/libv8/v8/src/arm/debug-arm.cc +317 -0
  257. data/lib/libv8/v8/src/arm/deoptimizer-arm.cc +754 -0
  258. data/lib/libv8/v8/src/arm/disasm-arm.cc +1506 -0
  259. data/lib/libv8/v8/src/arm/frames-arm.cc +45 -0
  260. data/lib/libv8/v8/src/arm/frames-arm.h +168 -0
  261. data/lib/libv8/v8/src/arm/full-codegen-arm.cc +4375 -0
  262. data/lib/libv8/v8/src/arm/ic-arm.cc +1562 -0
  263. data/lib/libv8/v8/src/arm/lithium-arm.cc +2206 -0
  264. data/lib/libv8/v8/src/arm/lithium-arm.h +2348 -0
  265. data/lib/libv8/v8/src/arm/lithium-codegen-arm.cc +4526 -0
  266. data/lib/libv8/v8/src/arm/lithium-codegen-arm.h +403 -0
  267. data/lib/libv8/v8/src/arm/lithium-gap-resolver-arm.cc +305 -0
  268. data/lib/libv8/v8/src/arm/lithium-gap-resolver-arm.h +84 -0
  269. data/lib/libv8/v8/src/arm/macro-assembler-arm.cc +3163 -0
  270. data/lib/libv8/v8/src/arm/macro-assembler-arm.h +1126 -0
  271. data/lib/libv8/v8/src/arm/regexp-macro-assembler-arm.cc +1287 -0
  272. data/lib/libv8/v8/src/arm/regexp-macro-assembler-arm.h +253 -0
  273. data/lib/libv8/v8/src/arm/simulator-arm.cc +3424 -0
  274. data/lib/libv8/v8/src/arm/simulator-arm.h +431 -0
  275. data/lib/libv8/v8/src/arm/stub-cache-arm.cc +4243 -0
  276. data/lib/libv8/v8/src/array.js +1366 -0
  277. data/lib/libv8/v8/src/assembler.cc +1207 -0
  278. data/lib/libv8/v8/src/assembler.h +858 -0
  279. data/lib/libv8/v8/src/ast-inl.h +112 -0
  280. data/lib/libv8/v8/src/ast.cc +1146 -0
  281. data/lib/libv8/v8/src/ast.h +2188 -0
  282. data/lib/libv8/v8/src/atomicops.h +167 -0
  283. data/lib/libv8/v8/src/atomicops_internals_arm_gcc.h +145 -0
  284. data/lib/libv8/v8/src/atomicops_internals_mips_gcc.h +169 -0
  285. data/lib/libv8/v8/src/atomicops_internals_x86_gcc.cc +133 -0
  286. data/lib/libv8/v8/src/atomicops_internals_x86_gcc.h +287 -0
  287. data/lib/libv8/v8/src/atomicops_internals_x86_macosx.h +301 -0
  288. data/lib/libv8/v8/src/atomicops_internals_x86_msvc.h +203 -0
  289. data/lib/libv8/v8/src/bignum-dtoa.cc +655 -0
  290. data/lib/libv8/v8/src/bignum-dtoa.h +81 -0
  291. data/lib/libv8/v8/src/bignum.cc +768 -0
  292. data/lib/libv8/v8/src/bignum.h +140 -0
  293. data/lib/libv8/v8/src/bootstrapper.cc +2184 -0
  294. data/lib/libv8/v8/src/bootstrapper.h +188 -0
  295. data/lib/libv8/v8/src/builtins.cc +1707 -0
  296. data/lib/libv8/v8/src/builtins.h +371 -0
  297. data/lib/libv8/v8/src/bytecodes-irregexp.h +105 -0
  298. data/lib/libv8/v8/src/cached-powers.cc +177 -0
  299. data/lib/libv8/v8/src/cached-powers.h +65 -0
  300. data/lib/libv8/v8/src/char-predicates-inl.h +94 -0
  301. data/lib/libv8/v8/src/char-predicates.h +67 -0
  302. data/lib/libv8/v8/src/checks.cc +110 -0
  303. data/lib/libv8/v8/src/checks.h +296 -0
  304. data/lib/libv8/v8/src/circular-queue-inl.h +53 -0
  305. data/lib/libv8/v8/src/circular-queue.cc +122 -0
  306. data/lib/libv8/v8/src/circular-queue.h +103 -0
  307. data/lib/libv8/v8/src/code-stubs.cc +267 -0
  308. data/lib/libv8/v8/src/code-stubs.h +1011 -0
  309. data/lib/libv8/v8/src/code.h +70 -0
  310. data/lib/libv8/v8/src/codegen.cc +231 -0
  311. data/lib/libv8/v8/src/codegen.h +84 -0
  312. data/lib/libv8/v8/src/compilation-cache.cc +540 -0
  313. data/lib/libv8/v8/src/compilation-cache.h +287 -0
  314. data/lib/libv8/v8/src/compiler.cc +786 -0
  315. data/lib/libv8/v8/src/compiler.h +312 -0
  316. data/lib/libv8/v8/src/contexts.cc +347 -0
  317. data/lib/libv8/v8/src/contexts.h +391 -0
  318. data/lib/libv8/v8/src/conversions-inl.h +106 -0
  319. data/lib/libv8/v8/src/conversions.cc +1131 -0
  320. data/lib/libv8/v8/src/conversions.h +135 -0
  321. data/lib/libv8/v8/src/counters.cc +93 -0
  322. data/lib/libv8/v8/src/counters.h +254 -0
  323. data/lib/libv8/v8/src/cpu-profiler-inl.h +101 -0
  324. data/lib/libv8/v8/src/cpu-profiler.cc +609 -0
  325. data/lib/libv8/v8/src/cpu-profiler.h +302 -0
  326. data/lib/libv8/v8/src/cpu.h +69 -0
  327. data/lib/libv8/v8/src/d8-debug.cc +367 -0
  328. data/lib/libv8/v8/src/d8-debug.h +158 -0
  329. data/lib/libv8/v8/src/d8-posix.cc +695 -0
  330. data/lib/libv8/v8/src/d8-readline.cc +130 -0
  331. data/lib/libv8/v8/src/d8-windows.cc +42 -0
  332. data/lib/libv8/v8/src/d8.cc +803 -0
  333. data/lib/libv8/v8/src/d8.gyp +91 -0
  334. data/lib/libv8/v8/src/d8.h +235 -0
  335. data/lib/libv8/v8/src/d8.js +2798 -0
  336. data/lib/libv8/v8/src/data-flow.cc +66 -0
  337. data/lib/libv8/v8/src/data-flow.h +205 -0
  338. data/lib/libv8/v8/src/date.js +1103 -0
  339. data/lib/libv8/v8/src/dateparser-inl.h +127 -0
  340. data/lib/libv8/v8/src/dateparser.cc +178 -0
  341. data/lib/libv8/v8/src/dateparser.h +266 -0
  342. data/lib/libv8/v8/src/debug-agent.cc +447 -0
  343. data/lib/libv8/v8/src/debug-agent.h +129 -0
  344. data/lib/libv8/v8/src/debug-debugger.js +2569 -0
  345. data/lib/libv8/v8/src/debug.cc +3165 -0
  346. data/lib/libv8/v8/src/debug.h +1057 -0
  347. data/lib/libv8/v8/src/deoptimizer.cc +1256 -0
  348. data/lib/libv8/v8/src/deoptimizer.h +602 -0
  349. data/lib/libv8/v8/src/disasm.h +80 -0
  350. data/lib/libv8/v8/src/disassembler.cc +343 -0
  351. data/lib/libv8/v8/src/disassembler.h +58 -0
  352. data/lib/libv8/v8/src/diy-fp.cc +58 -0
  353. data/lib/libv8/v8/src/diy-fp.h +117 -0
  354. data/lib/libv8/v8/src/double.h +238 -0
  355. data/lib/libv8/v8/src/dtoa.cc +103 -0
  356. data/lib/libv8/v8/src/dtoa.h +85 -0
  357. data/lib/libv8/v8/src/execution.cc +849 -0
  358. data/lib/libv8/v8/src/execution.h +297 -0
  359. data/lib/libv8/v8/src/extensions/experimental/break-iterator.cc +250 -0
  360. data/lib/libv8/v8/src/extensions/experimental/break-iterator.h +89 -0
  361. data/lib/libv8/v8/src/extensions/experimental/collator.cc +218 -0
  362. data/lib/libv8/v8/src/extensions/experimental/collator.h +69 -0
  363. data/lib/libv8/v8/src/extensions/experimental/experimental.gyp +94 -0
  364. data/lib/libv8/v8/src/extensions/experimental/i18n-extension.cc +78 -0
  365. data/lib/libv8/v8/src/extensions/experimental/i18n-extension.h +54 -0
  366. data/lib/libv8/v8/src/extensions/experimental/i18n-locale.cc +112 -0
  367. data/lib/libv8/v8/src/extensions/experimental/i18n-locale.h +60 -0
  368. data/lib/libv8/v8/src/extensions/experimental/i18n-utils.cc +43 -0
  369. data/lib/libv8/v8/src/extensions/experimental/i18n-utils.h +49 -0
  370. data/lib/libv8/v8/src/extensions/experimental/i18n.js +180 -0
  371. data/lib/libv8/v8/src/extensions/experimental/language-matcher.cc +251 -0
  372. data/lib/libv8/v8/src/extensions/experimental/language-matcher.h +95 -0
  373. data/lib/libv8/v8/src/extensions/externalize-string-extension.cc +141 -0
  374. data/lib/libv8/v8/src/extensions/externalize-string-extension.h +50 -0
  375. data/lib/libv8/v8/src/extensions/gc-extension.cc +58 -0
  376. data/lib/libv8/v8/src/extensions/gc-extension.h +49 -0
  377. data/lib/libv8/v8/src/factory.cc +1222 -0
  378. data/lib/libv8/v8/src/factory.h +442 -0
  379. data/lib/libv8/v8/src/fast-dtoa.cc +736 -0
  380. data/lib/libv8/v8/src/fast-dtoa.h +83 -0
  381. data/lib/libv8/v8/src/fixed-dtoa.cc +405 -0
  382. data/lib/libv8/v8/src/fixed-dtoa.h +55 -0
  383. data/lib/libv8/v8/src/flag-definitions.h +560 -0
  384. data/lib/libv8/v8/src/flags.cc +551 -0
  385. data/lib/libv8/v8/src/flags.h +79 -0
  386. data/lib/libv8/v8/src/frames-inl.h +247 -0
  387. data/lib/libv8/v8/src/frames.cc +1243 -0
  388. data/lib/libv8/v8/src/frames.h +870 -0
  389. data/lib/libv8/v8/src/full-codegen.cc +1374 -0
  390. data/lib/libv8/v8/src/full-codegen.h +771 -0
  391. data/lib/libv8/v8/src/func-name-inferrer.cc +92 -0
  392. data/lib/libv8/v8/src/func-name-inferrer.h +111 -0
  393. data/lib/libv8/v8/src/gdb-jit.cc +1555 -0
  394. data/lib/libv8/v8/src/gdb-jit.h +143 -0
  395. data/lib/libv8/v8/src/global-handles.cc +665 -0
  396. data/lib/libv8/v8/src/global-handles.h +284 -0
  397. data/lib/libv8/v8/src/globals.h +325 -0
  398. data/lib/libv8/v8/src/handles-inl.h +177 -0
  399. data/lib/libv8/v8/src/handles.cc +987 -0
  400. data/lib/libv8/v8/src/handles.h +382 -0
  401. data/lib/libv8/v8/src/hashmap.cc +230 -0
  402. data/lib/libv8/v8/src/hashmap.h +123 -0
  403. data/lib/libv8/v8/src/heap-inl.h +704 -0
  404. data/lib/libv8/v8/src/heap-profiler.cc +1173 -0
  405. data/lib/libv8/v8/src/heap-profiler.h +397 -0
  406. data/lib/libv8/v8/src/heap.cc +5930 -0
  407. data/lib/libv8/v8/src/heap.h +2268 -0
  408. data/lib/libv8/v8/src/hydrogen-instructions.cc +1769 -0
  409. data/lib/libv8/v8/src/hydrogen-instructions.h +3971 -0
  410. data/lib/libv8/v8/src/hydrogen.cc +6239 -0
  411. data/lib/libv8/v8/src/hydrogen.h +1202 -0
  412. data/lib/libv8/v8/src/ia32/assembler-ia32-inl.h +446 -0
  413. data/lib/libv8/v8/src/ia32/assembler-ia32.cc +2487 -0
  414. data/lib/libv8/v8/src/ia32/assembler-ia32.h +1144 -0
  415. data/lib/libv8/v8/src/ia32/builtins-ia32.cc +1621 -0
  416. data/lib/libv8/v8/src/ia32/code-stubs-ia32.cc +6198 -0
  417. data/lib/libv8/v8/src/ia32/code-stubs-ia32.h +517 -0
  418. data/lib/libv8/v8/src/ia32/codegen-ia32.cc +265 -0
  419. data/lib/libv8/v8/src/ia32/codegen-ia32.h +79 -0
  420. data/lib/libv8/v8/src/ia32/cpu-ia32.cc +88 -0
  421. data/lib/libv8/v8/src/ia32/debug-ia32.cc +312 -0
  422. data/lib/libv8/v8/src/ia32/deoptimizer-ia32.cc +774 -0
  423. data/lib/libv8/v8/src/ia32/disasm-ia32.cc +1628 -0
  424. data/lib/libv8/v8/src/ia32/frames-ia32.cc +45 -0
  425. data/lib/libv8/v8/src/ia32/frames-ia32.h +142 -0
  426. data/lib/libv8/v8/src/ia32/full-codegen-ia32.cc +4338 -0
  427. data/lib/libv8/v8/src/ia32/ic-ia32.cc +1597 -0
  428. data/lib/libv8/v8/src/ia32/lithium-codegen-ia32.cc +4461 -0
  429. data/lib/libv8/v8/src/ia32/lithium-codegen-ia32.h +375 -0
  430. data/lib/libv8/v8/src/ia32/lithium-gap-resolver-ia32.cc +475 -0
  431. data/lib/libv8/v8/src/ia32/lithium-gap-resolver-ia32.h +110 -0
  432. data/lib/libv8/v8/src/ia32/lithium-ia32.cc +2261 -0
  433. data/lib/libv8/v8/src/ia32/lithium-ia32.h +2396 -0
  434. data/lib/libv8/v8/src/ia32/macro-assembler-ia32.cc +2136 -0
  435. data/lib/libv8/v8/src/ia32/macro-assembler-ia32.h +775 -0
  436. data/lib/libv8/v8/src/ia32/regexp-macro-assembler-ia32.cc +1263 -0
  437. data/lib/libv8/v8/src/ia32/regexp-macro-assembler-ia32.h +216 -0
  438. data/lib/libv8/v8/src/ia32/simulator-ia32.cc +30 -0
  439. data/lib/libv8/v8/src/ia32/simulator-ia32.h +74 -0
  440. data/lib/libv8/v8/src/ia32/stub-cache-ia32.cc +3847 -0
  441. data/lib/libv8/v8/src/ic-inl.h +130 -0
  442. data/lib/libv8/v8/src/ic.cc +2577 -0
  443. data/lib/libv8/v8/src/ic.h +736 -0
  444. data/lib/libv8/v8/src/inspector.cc +63 -0
  445. data/lib/libv8/v8/src/inspector.h +62 -0
  446. data/lib/libv8/v8/src/interpreter-irregexp.cc +659 -0
  447. data/lib/libv8/v8/src/interpreter-irregexp.h +49 -0
  448. data/lib/libv8/v8/src/isolate-inl.h +50 -0
  449. data/lib/libv8/v8/src/isolate.cc +1869 -0
  450. data/lib/libv8/v8/src/isolate.h +1382 -0
  451. data/lib/libv8/v8/src/json-parser.cc +504 -0
  452. data/lib/libv8/v8/src/json-parser.h +161 -0
  453. data/lib/libv8/v8/src/json.js +342 -0
  454. data/lib/libv8/v8/src/jsregexp.cc +5385 -0
  455. data/lib/libv8/v8/src/jsregexp.h +1492 -0
  456. data/lib/libv8/v8/src/list-inl.h +212 -0
  457. data/lib/libv8/v8/src/list.h +174 -0
  458. data/lib/libv8/v8/src/lithium-allocator-inl.h +142 -0
  459. data/lib/libv8/v8/src/lithium-allocator.cc +2123 -0
  460. data/lib/libv8/v8/src/lithium-allocator.h +630 -0
  461. data/lib/libv8/v8/src/lithium.cc +190 -0
  462. data/lib/libv8/v8/src/lithium.h +597 -0
  463. data/lib/libv8/v8/src/liveedit-debugger.js +1082 -0
  464. data/lib/libv8/v8/src/liveedit.cc +1691 -0
  465. data/lib/libv8/v8/src/liveedit.h +180 -0
  466. data/lib/libv8/v8/src/liveobjectlist-inl.h +126 -0
  467. data/lib/libv8/v8/src/liveobjectlist.cc +2589 -0
  468. data/lib/libv8/v8/src/liveobjectlist.h +322 -0
  469. data/lib/libv8/v8/src/log-inl.h +59 -0
  470. data/lib/libv8/v8/src/log-utils.cc +428 -0
  471. data/lib/libv8/v8/src/log-utils.h +231 -0
  472. data/lib/libv8/v8/src/log.cc +1993 -0
  473. data/lib/libv8/v8/src/log.h +476 -0
  474. data/lib/libv8/v8/src/macro-assembler.h +120 -0
  475. data/lib/libv8/v8/src/macros.py +178 -0
  476. data/lib/libv8/v8/src/mark-compact.cc +3143 -0
  477. data/lib/libv8/v8/src/mark-compact.h +506 -0
  478. data/lib/libv8/v8/src/math.js +264 -0
  479. data/lib/libv8/v8/src/messages.cc +179 -0
  480. data/lib/libv8/v8/src/messages.h +113 -0
  481. data/lib/libv8/v8/src/messages.js +1096 -0
  482. data/lib/libv8/v8/src/mips/assembler-mips-inl.h +312 -0
  483. data/lib/libv8/v8/src/mips/assembler-mips.cc +1960 -0
  484. data/lib/libv8/v8/src/mips/assembler-mips.h +1138 -0
  485. data/lib/libv8/v8/src/mips/builtins-mips.cc +1628 -0
  486. data/lib/libv8/v8/src/mips/code-stubs-mips.cc +6656 -0
  487. data/lib/libv8/v8/src/mips/code-stubs-mips.h +682 -0
  488. data/lib/libv8/v8/src/mips/codegen-mips.cc +52 -0
  489. data/lib/libv8/v8/src/mips/codegen-mips.h +98 -0
  490. data/lib/libv8/v8/src/mips/constants-mips.cc +352 -0
  491. data/lib/libv8/v8/src/mips/constants-mips.h +739 -0
  492. data/lib/libv8/v8/src/mips/cpu-mips.cc +96 -0
  493. data/lib/libv8/v8/src/mips/debug-mips.cc +308 -0
  494. data/lib/libv8/v8/src/mips/deoptimizer-mips.cc +91 -0
  495. data/lib/libv8/v8/src/mips/disasm-mips.cc +1050 -0
  496. data/lib/libv8/v8/src/mips/frames-mips.cc +47 -0
  497. data/lib/libv8/v8/src/mips/frames-mips.h +219 -0
  498. data/lib/libv8/v8/src/mips/full-codegen-mips.cc +4388 -0
  499. data/lib/libv8/v8/src/mips/ic-mips.cc +1580 -0
  500. data/lib/libv8/v8/src/mips/lithium-codegen-mips.h +65 -0
  501. data/lib/libv8/v8/src/mips/lithium-mips.h +307 -0
  502. data/lib/libv8/v8/src/mips/macro-assembler-mips.cc +4056 -0
  503. data/lib/libv8/v8/src/mips/macro-assembler-mips.h +1214 -0
  504. data/lib/libv8/v8/src/mips/regexp-macro-assembler-mips.cc +1251 -0
  505. data/lib/libv8/v8/src/mips/regexp-macro-assembler-mips.h +252 -0
  506. data/lib/libv8/v8/src/mips/simulator-mips.cc +2621 -0
  507. data/lib/libv8/v8/src/mips/simulator-mips.h +401 -0
  508. data/lib/libv8/v8/src/mips/stub-cache-mips.cc +4285 -0
  509. data/lib/libv8/v8/src/mirror-debugger.js +2382 -0
  510. data/lib/libv8/v8/src/mksnapshot.cc +328 -0
  511. data/lib/libv8/v8/src/natives.h +64 -0
  512. data/lib/libv8/v8/src/objects-debug.cc +738 -0
  513. data/lib/libv8/v8/src/objects-inl.h +4323 -0
  514. data/lib/libv8/v8/src/objects-printer.cc +829 -0
  515. data/lib/libv8/v8/src/objects-visiting.cc +148 -0
  516. data/lib/libv8/v8/src/objects-visiting.h +424 -0
  517. data/lib/libv8/v8/src/objects.cc +10585 -0
  518. data/lib/libv8/v8/src/objects.h +6838 -0
  519. data/lib/libv8/v8/src/parser.cc +4997 -0
  520. data/lib/libv8/v8/src/parser.h +765 -0
  521. data/lib/libv8/v8/src/platform-cygwin.cc +779 -0
  522. data/lib/libv8/v8/src/platform-freebsd.cc +826 -0
  523. data/lib/libv8/v8/src/platform-linux.cc +1149 -0
  524. data/lib/libv8/v8/src/platform-macos.cc +830 -0
  525. data/lib/libv8/v8/src/platform-nullos.cc +479 -0
  526. data/lib/libv8/v8/src/platform-openbsd.cc +640 -0
  527. data/lib/libv8/v8/src/platform-posix.cc +424 -0
  528. data/lib/libv8/v8/src/platform-solaris.cc +762 -0
  529. data/lib/libv8/v8/src/platform-tls-mac.h +62 -0
  530. data/lib/libv8/v8/src/platform-tls-win32.h +62 -0
  531. data/lib/libv8/v8/src/platform-tls.h +50 -0
  532. data/lib/libv8/v8/src/platform-win32.cc +2021 -0
  533. data/lib/libv8/v8/src/platform.h +667 -0
  534. data/lib/libv8/v8/src/preparse-data-format.h +62 -0
  535. data/lib/libv8/v8/src/preparse-data.cc +183 -0
  536. data/lib/libv8/v8/src/preparse-data.h +225 -0
  537. data/lib/libv8/v8/src/preparser-api.cc +220 -0
  538. data/lib/libv8/v8/src/preparser.cc +1450 -0
  539. data/lib/libv8/v8/src/preparser.h +493 -0
  540. data/lib/libv8/v8/src/prettyprinter.cc +1493 -0
  541. data/lib/libv8/v8/src/prettyprinter.h +223 -0
  542. data/lib/libv8/v8/src/profile-generator-inl.h +128 -0
  543. data/lib/libv8/v8/src/profile-generator.cc +3098 -0
  544. data/lib/libv8/v8/src/profile-generator.h +1126 -0
  545. data/lib/libv8/v8/src/property.cc +105 -0
  546. data/lib/libv8/v8/src/property.h +365 -0
  547. data/lib/libv8/v8/src/proxy.js +83 -0
  548. data/lib/libv8/v8/src/regexp-macro-assembler-irregexp-inl.h +78 -0
  549. data/lib/libv8/v8/src/regexp-macro-assembler-irregexp.cc +471 -0
  550. data/lib/libv8/v8/src/regexp-macro-assembler-irregexp.h +142 -0
  551. data/lib/libv8/v8/src/regexp-macro-assembler-tracer.cc +373 -0
  552. data/lib/libv8/v8/src/regexp-macro-assembler-tracer.h +104 -0
  553. data/lib/libv8/v8/src/regexp-macro-assembler.cc +267 -0
  554. data/lib/libv8/v8/src/regexp-macro-assembler.h +243 -0
  555. data/lib/libv8/v8/src/regexp-stack.cc +111 -0
  556. data/lib/libv8/v8/src/regexp-stack.h +147 -0
  557. data/lib/libv8/v8/src/regexp.js +483 -0
  558. data/lib/libv8/v8/src/rewriter.cc +360 -0
  559. data/lib/libv8/v8/src/rewriter.h +50 -0
  560. data/lib/libv8/v8/src/runtime-profiler.cc +489 -0
  561. data/lib/libv8/v8/src/runtime-profiler.h +201 -0
  562. data/lib/libv8/v8/src/runtime.cc +12227 -0
  563. data/lib/libv8/v8/src/runtime.h +652 -0
  564. data/lib/libv8/v8/src/runtime.js +649 -0
  565. data/lib/libv8/v8/src/safepoint-table.cc +256 -0
  566. data/lib/libv8/v8/src/safepoint-table.h +270 -0
  567. data/lib/libv8/v8/src/scanner-base.cc +952 -0
  568. data/lib/libv8/v8/src/scanner-base.h +670 -0
  569. data/lib/libv8/v8/src/scanner.cc +345 -0
  570. data/lib/libv8/v8/src/scanner.h +146 -0
  571. data/lib/libv8/v8/src/scopeinfo.cc +646 -0
  572. data/lib/libv8/v8/src/scopeinfo.h +254 -0
  573. data/lib/libv8/v8/src/scopes.cc +1150 -0
  574. data/lib/libv8/v8/src/scopes.h +507 -0
  575. data/lib/libv8/v8/src/serialize.cc +1574 -0
  576. data/lib/libv8/v8/src/serialize.h +589 -0
  577. data/lib/libv8/v8/src/shell.h +55 -0
  578. data/lib/libv8/v8/src/simulator.h +43 -0
  579. data/lib/libv8/v8/src/small-pointer-list.h +163 -0
  580. data/lib/libv8/v8/src/smart-pointer.h +109 -0
  581. data/lib/libv8/v8/src/snapshot-common.cc +83 -0
  582. data/lib/libv8/v8/src/snapshot-empty.cc +54 -0
  583. data/lib/libv8/v8/src/snapshot.h +91 -0
  584. data/lib/libv8/v8/src/spaces-inl.h +529 -0
  585. data/lib/libv8/v8/src/spaces.cc +3145 -0
  586. data/lib/libv8/v8/src/spaces.h +2369 -0
  587. data/lib/libv8/v8/src/splay-tree-inl.h +310 -0
  588. data/lib/libv8/v8/src/splay-tree.h +205 -0
  589. data/lib/libv8/v8/src/string-search.cc +41 -0
  590. data/lib/libv8/v8/src/string-search.h +568 -0
  591. data/lib/libv8/v8/src/string-stream.cc +592 -0
  592. data/lib/libv8/v8/src/string-stream.h +191 -0
  593. data/lib/libv8/v8/src/string.js +994 -0
  594. data/lib/libv8/v8/src/strtod.cc +440 -0
  595. data/lib/libv8/v8/src/strtod.h +40 -0
  596. data/lib/libv8/v8/src/stub-cache.cc +1965 -0
  597. data/lib/libv8/v8/src/stub-cache.h +924 -0
  598. data/lib/libv8/v8/src/third_party/valgrind/valgrind.h +3925 -0
  599. data/lib/libv8/v8/src/token.cc +63 -0
  600. data/lib/libv8/v8/src/token.h +288 -0
  601. data/lib/libv8/v8/src/type-info.cc +507 -0
  602. data/lib/libv8/v8/src/type-info.h +272 -0
  603. data/lib/libv8/v8/src/unbound-queue-inl.h +95 -0
  604. data/lib/libv8/v8/src/unbound-queue.h +69 -0
  605. data/lib/libv8/v8/src/unicode-inl.h +238 -0
  606. data/lib/libv8/v8/src/unicode.cc +1624 -0
  607. data/lib/libv8/v8/src/unicode.h +280 -0
  608. data/lib/libv8/v8/src/uri.js +408 -0
  609. data/lib/libv8/v8/src/utils-inl.h +48 -0
  610. data/lib/libv8/v8/src/utils.cc +371 -0
  611. data/lib/libv8/v8/src/utils.h +800 -0
  612. data/lib/libv8/v8/src/v8-counters.cc +62 -0
  613. data/lib/libv8/v8/src/v8-counters.h +314 -0
  614. data/lib/libv8/v8/src/v8.cc +213 -0
  615. data/lib/libv8/v8/src/v8.h +131 -0
  616. data/lib/libv8/v8/src/v8checks.h +64 -0
  617. data/lib/libv8/v8/src/v8dll-main.cc +44 -0
  618. data/lib/libv8/v8/src/v8globals.h +512 -0
  619. data/lib/libv8/v8/src/v8memory.h +82 -0
  620. data/lib/libv8/v8/src/v8natives.js +1310 -0
  621. data/lib/libv8/v8/src/v8preparserdll-main.cc +39 -0
  622. data/lib/libv8/v8/src/v8threads.cc +464 -0
  623. data/lib/libv8/v8/src/v8threads.h +165 -0
  624. data/lib/libv8/v8/src/v8utils.h +319 -0
  625. data/lib/libv8/v8/src/variables.cc +114 -0
  626. data/lib/libv8/v8/src/variables.h +167 -0
  627. data/lib/libv8/v8/src/version.cc +116 -0
  628. data/lib/libv8/v8/src/version.h +68 -0
  629. data/lib/libv8/v8/src/vm-state-inl.h +138 -0
  630. data/lib/libv8/v8/src/vm-state.h +71 -0
  631. data/lib/libv8/v8/src/win32-headers.h +96 -0
  632. data/lib/libv8/v8/src/x64/assembler-x64-inl.h +462 -0
  633. data/lib/libv8/v8/src/x64/assembler-x64.cc +3027 -0
  634. data/lib/libv8/v8/src/x64/assembler-x64.h +1633 -0
  635. data/lib/libv8/v8/src/x64/builtins-x64.cc +1520 -0
  636. data/lib/libv8/v8/src/x64/code-stubs-x64.cc +5132 -0
  637. data/lib/libv8/v8/src/x64/code-stubs-x64.h +514 -0
  638. data/lib/libv8/v8/src/x64/codegen-x64.cc +146 -0
  639. data/lib/libv8/v8/src/x64/codegen-x64.h +76 -0
  640. data/lib/libv8/v8/src/x64/cpu-x64.cc +88 -0
  641. data/lib/libv8/v8/src/x64/debug-x64.cc +319 -0
  642. data/lib/libv8/v8/src/x64/deoptimizer-x64.cc +815 -0
  643. data/lib/libv8/v8/src/x64/disasm-x64.cc +1832 -0
  644. data/lib/libv8/v8/src/x64/frames-x64.cc +45 -0
  645. data/lib/libv8/v8/src/x64/frames-x64.h +130 -0
  646. data/lib/libv8/v8/src/x64/full-codegen-x64.cc +4318 -0
  647. data/lib/libv8/v8/src/x64/ic-x64.cc +1608 -0
  648. data/lib/libv8/v8/src/x64/lithium-codegen-x64.cc +4267 -0
  649. data/lib/libv8/v8/src/x64/lithium-codegen-x64.h +367 -0
  650. data/lib/libv8/v8/src/x64/lithium-gap-resolver-x64.cc +320 -0
  651. data/lib/libv8/v8/src/x64/lithium-gap-resolver-x64.h +74 -0
  652. data/lib/libv8/v8/src/x64/lithium-x64.cc +2202 -0
  653. data/lib/libv8/v8/src/x64/lithium-x64.h +2333 -0
  654. data/lib/libv8/v8/src/x64/macro-assembler-x64.cc +3745 -0
  655. data/lib/libv8/v8/src/x64/macro-assembler-x64.h +1290 -0
  656. data/lib/libv8/v8/src/x64/regexp-macro-assembler-x64.cc +1398 -0
  657. data/lib/libv8/v8/src/x64/regexp-macro-assembler-x64.h +282 -0
  658. data/lib/libv8/v8/src/x64/simulator-x64.cc +27 -0
  659. data/lib/libv8/v8/src/x64/simulator-x64.h +72 -0
  660. data/lib/libv8/v8/src/x64/stub-cache-x64.cc +3610 -0
  661. data/lib/libv8/v8/src/zone-inl.h +140 -0
  662. data/lib/libv8/v8/src/zone.cc +196 -0
  663. data/lib/libv8/v8/src/zone.h +240 -0
  664. data/lib/libv8/v8/tools/codemap.js +265 -0
  665. data/lib/libv8/v8/tools/consarray.js +93 -0
  666. data/lib/libv8/v8/tools/csvparser.js +78 -0
  667. data/lib/libv8/v8/tools/disasm.py +92 -0
  668. data/lib/libv8/v8/tools/freebsd-tick-processor +10 -0
  669. data/lib/libv8/v8/tools/gc-nvp-trace-processor.py +342 -0
  670. data/lib/libv8/v8/tools/gcmole/README +62 -0
  671. data/lib/libv8/v8/tools/gcmole/gccause.lua +60 -0
  672. data/lib/libv8/v8/tools/gcmole/gcmole.cc +1261 -0
  673. data/lib/libv8/v8/tools/gcmole/gcmole.lua +378 -0
  674. data/lib/libv8/v8/tools/generate-ten-powers.scm +286 -0
  675. data/lib/libv8/v8/tools/grokdump.py +841 -0
  676. data/lib/libv8/v8/tools/gyp/v8.gyp +995 -0
  677. data/lib/libv8/v8/tools/js2c.py +364 -0
  678. data/lib/libv8/v8/tools/jsmin.py +280 -0
  679. data/lib/libv8/v8/tools/linux-tick-processor +35 -0
  680. data/lib/libv8/v8/tools/ll_prof.py +942 -0
  681. data/lib/libv8/v8/tools/logreader.js +185 -0
  682. data/lib/libv8/v8/tools/mac-nm +18 -0
  683. data/lib/libv8/v8/tools/mac-tick-processor +6 -0
  684. data/lib/libv8/v8/tools/oom_dump/README +31 -0
  685. data/lib/libv8/v8/tools/oom_dump/SConstruct +42 -0
  686. data/lib/libv8/v8/tools/oom_dump/oom_dump.cc +288 -0
  687. data/lib/libv8/v8/tools/presubmit.py +305 -0
  688. data/lib/libv8/v8/tools/process-heap-prof.py +120 -0
  689. data/lib/libv8/v8/tools/profile.js +751 -0
  690. data/lib/libv8/v8/tools/profile_view.js +219 -0
  691. data/lib/libv8/v8/tools/run-valgrind.py +77 -0
  692. data/lib/libv8/v8/tools/splaytree.js +316 -0
  693. data/lib/libv8/v8/tools/stats-viewer.py +468 -0
  694. data/lib/libv8/v8/tools/test.py +1510 -0
  695. data/lib/libv8/v8/tools/tickprocessor-driver.js +59 -0
  696. data/lib/libv8/v8/tools/tickprocessor.js +877 -0
  697. data/lib/libv8/v8/tools/utils.py +96 -0
  698. data/lib/libv8/v8/tools/visual_studio/README.txt +12 -0
  699. data/lib/libv8/v8/tools/windows-tick-processor.bat +30 -0
  700. data/lib/libv8/version.rb +6 -0
  701. data/libv8.gemspec +36 -0
  702. data/thefrontside.png +0 -0
  703. metadata +776 -0
@@ -0,0 +1,1025 @@
1
+ #
2
+ # Copyright (c) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 The SCons Foundation
3
+ #
4
+ # Permission is hereby granted, free of charge, to any person obtaining
5
+ # a copy of this software and associated documentation files (the
6
+ # "Software"), to deal in the Software without restriction, including
7
+ # without limitation the rights to use, copy, modify, merge, publish,
8
+ # distribute, sublicense, and/or sell copies of the Software, and to
9
+ # permit persons to whom the Software is furnished to do so, subject to
10
+ # the following conditions:
11
+ #
12
+ # The above copyright notice and this permission notice shall be included
13
+ # in all copies or substantial portions of the Software.
14
+ #
15
+ # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
16
+ # KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
17
+ # WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
18
+ # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
19
+ # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
20
+ # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
21
+ # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
22
+
23
+ __doc__ = """
24
+ Generic Taskmaster module for the SCons build engine.
25
+
26
+ This module contains the primary interface(s) between a wrapping user
27
+ interface and the SCons build engine. There are two key classes here:
28
+
29
+ Taskmaster
30
+ This is the main engine for walking the dependency graph and
31
+ calling things to decide what does or doesn't need to be built.
32
+
33
+ Task
34
+ This is the base class for allowing a wrapping interface to
35
+ decide what does or doesn't actually need to be done. The
36
+ intention is for a wrapping interface to subclass this as
37
+ appropriate for different types of behavior it may need.
38
+
39
+ The canonical example is the SCons native Python interface,
40
+ which has Task subclasses that handle its specific behavior,
41
+ like printing "`foo' is up to date" when a top-level target
42
+ doesn't need to be built, and handling the -c option by removing
43
+ targets as its "build" action. There is also a separate subclass
44
+ for suppressing this output when the -q option is used.
45
+
46
+ The Taskmaster instantiates a Task object for each (set of)
47
+ target(s) that it decides need to be evaluated and/or built.
48
+ """
49
+
50
+ __revision__ = "src/engine/SCons/Taskmaster.py 5357 2011/09/09 21:31:03 bdeegan"
51
+
52
+ from itertools import chain
53
+ import operator
54
+ import sys
55
+ import traceback
56
+
57
+ import SCons.Errors
58
+ import SCons.Node
59
+ import SCons.Warnings
60
+
61
+ StateString = SCons.Node.StateString
62
+ NODE_NO_STATE = SCons.Node.no_state
63
+ NODE_PENDING = SCons.Node.pending
64
+ NODE_EXECUTING = SCons.Node.executing
65
+ NODE_UP_TO_DATE = SCons.Node.up_to_date
66
+ NODE_EXECUTED = SCons.Node.executed
67
+ NODE_FAILED = SCons.Node.failed
68
+
69
+ print_prepare = 0 # set by option --debug=prepare
70
+
71
+ # A subsystem for recording stats about how different Nodes are handled by
72
+ # the main Taskmaster loop. There's no external control here (no need for
73
+ # a --debug= option); enable it by changing the value of CollectStats.
74
+
75
+ CollectStats = None
76
+
77
+ class Stats(object):
78
+ """
79
+ A simple class for holding statistics about the disposition of a
80
+ Node by the Taskmaster. If we're collecting statistics, each Node
81
+ processed by the Taskmaster gets one of these attached, in which case
82
+ the Taskmaster records its decision each time it processes the Node.
83
+ (Ideally, that's just once per Node.)
84
+ """
85
+ def __init__(self):
86
+ """
87
+ Instantiates a Taskmaster.Stats object, initializing all
88
+ appropriate counters to zero.
89
+ """
90
+ self.considered = 0
91
+ self.already_handled = 0
92
+ self.problem = 0
93
+ self.child_failed = 0
94
+ self.not_built = 0
95
+ self.side_effects = 0
96
+ self.build = 0
97
+
98
+ StatsNodes = []
99
+
100
+ fmt = "%(considered)3d "\
101
+ "%(already_handled)3d " \
102
+ "%(problem)3d " \
103
+ "%(child_failed)3d " \
104
+ "%(not_built)3d " \
105
+ "%(side_effects)3d " \
106
+ "%(build)3d "
107
+
108
+ def dump_stats():
109
+ for n in sorted(StatsNodes, key=lambda a: str(a)):
110
+ print (fmt % n.stats.__dict__) + str(n)
111
+
112
+
113
+
114
+ class Task(object):
115
+ """
116
+ Default SCons build engine task.
117
+
118
+ This controls the interaction of the actual building of node
119
+ and the rest of the engine.
120
+
121
+ This is expected to handle all of the normally-customizable
122
+ aspects of controlling a build, so any given application
123
+ *should* be able to do what it wants by sub-classing this
124
+ class and overriding methods as appropriate. If an application
125
+ needs to customze something by sub-classing Taskmaster (or
126
+ some other build engine class), we should first try to migrate
127
+ that functionality into this class.
128
+
129
+ Note that it's generally a good idea for sub-classes to call
130
+ these methods explicitly to update state, etc., rather than
131
+ roll their own interaction with Taskmaster from scratch.
132
+ """
133
+ def __init__(self, tm, targets, top, node):
134
+ self.tm = tm
135
+ self.targets = targets
136
+ self.top = top
137
+ self.node = node
138
+ self.exc_clear()
139
+
140
+ def trace_message(self, method, node, description='node'):
141
+ fmt = '%-20s %s %s\n'
142
+ return fmt % (method + ':', description, self.tm.trace_node(node))
143
+
144
+ def display(self, message):
145
+ """
146
+ Hook to allow the calling interface to display a message.
147
+
148
+ This hook gets called as part of preparing a task for execution
149
+ (that is, a Node to be built). As part of figuring out what Node
150
+ should be built next, the actually target list may be altered,
151
+ along with a message describing the alteration. The calling
152
+ interface can subclass Task and provide a concrete implementation
153
+ of this method to see those messages.
154
+ """
155
+ pass
156
+
157
+ def prepare(self):
158
+ """
159
+ Called just before the task is executed.
160
+
161
+ This is mainly intended to give the target Nodes a chance to
162
+ unlink underlying files and make all necessary directories before
163
+ the Action is actually called to build the targets.
164
+ """
165
+ global print_prepare
166
+ T = self.tm.trace
167
+ if T: T.write(self.trace_message(u'Task.prepare()', self.node))
168
+
169
+ # Now that it's the appropriate time, give the TaskMaster a
170
+ # chance to raise any exceptions it encountered while preparing
171
+ # this task.
172
+ self.exception_raise()
173
+
174
+ if self.tm.message:
175
+ self.display(self.tm.message)
176
+ self.tm.message = None
177
+
178
+ # Let the targets take care of any necessary preparations.
179
+ # This includes verifying that all of the necessary sources
180
+ # and dependencies exist, removing the target file(s), etc.
181
+ #
182
+ # As of April 2008, the get_executor().prepare() method makes
183
+ # sure that all of the aggregate sources necessary to build this
184
+ # Task's target(s) exist in one up-front check. The individual
185
+ # target t.prepare() methods check that each target's explicit
186
+ # or implicit dependencies exists, and also initialize the
187
+ # .sconsign info.
188
+ executor = self.targets[0].get_executor()
189
+ executor.prepare()
190
+ for t in executor.get_action_targets():
191
+ if print_prepare:
192
+ print "Preparing target %s..."%t
193
+ for s in t.side_effects:
194
+ print "...with side-effect %s..."%s
195
+ t.prepare()
196
+ for s in t.side_effects:
197
+ if print_prepare:
198
+ print "...Preparing side-effect %s..."%s
199
+ s.prepare()
200
+
201
+ def get_target(self):
202
+ """Fetch the target being built or updated by this task.
203
+ """
204
+ return self.node
205
+
206
+ def needs_execute(self):
207
+ # TODO(deprecate): "return True" is the old default behavior;
208
+ # change it to NotImplementedError (after running through the
209
+ # Deprecation Cycle) so the desired behavior is explicitly
210
+ # determined by which concrete subclass is used.
211
+ #raise NotImplementedError
212
+ msg = ('Taskmaster.Task is an abstract base class; instead of\n'
213
+ '\tusing it directly, '
214
+ 'derive from it and override the abstract methods.')
215
+ SCons.Warnings.warn(SCons.Warnings.TaskmasterNeedsExecuteWarning, msg)
216
+ return True
217
+
218
+ def execute(self):
219
+ """
220
+ Called to execute the task.
221
+
222
+ This method is called from multiple threads in a parallel build,
223
+ so only do thread safe stuff here. Do thread unsafe stuff in
224
+ prepare(), executed() or failed().
225
+ """
226
+ T = self.tm.trace
227
+ if T: T.write(self.trace_message(u'Task.execute()', self.node))
228
+
229
+ try:
230
+ everything_was_cached = 1
231
+ for t in self.targets:
232
+ if t.retrieve_from_cache():
233
+ # Call the .built() method without calling the
234
+ # .push_to_cache() method, since we just got the
235
+ # target from the cache and don't need to push
236
+ # it back there.
237
+ t.set_state(NODE_EXECUTED)
238
+ t.built()
239
+ else:
240
+ everything_was_cached = 0
241
+ break
242
+ if not everything_was_cached:
243
+ self.targets[0].build()
244
+ except SystemExit:
245
+ exc_value = sys.exc_info()[1]
246
+ raise SCons.Errors.ExplicitExit(self.targets[0], exc_value.code)
247
+ except SCons.Errors.UserError:
248
+ raise
249
+ except SCons.Errors.BuildError:
250
+ raise
251
+ except Exception, e:
252
+ buildError = SCons.Errors.convert_to_BuildError(e)
253
+ buildError.node = self.targets[0]
254
+ buildError.exc_info = sys.exc_info()
255
+ raise buildError
256
+
257
+ def executed_without_callbacks(self):
258
+ """
259
+ Called when the task has been successfully executed
260
+ and the Taskmaster instance doesn't want to call
261
+ the Node's callback methods.
262
+ """
263
+ T = self.tm.trace
264
+ if T: T.write(self.trace_message('Task.executed_without_callbacks()',
265
+ self.node))
266
+
267
+ for t in self.targets:
268
+ if t.get_state() == NODE_EXECUTING:
269
+ for side_effect in t.side_effects:
270
+ side_effect.set_state(NODE_NO_STATE)
271
+ t.set_state(NODE_EXECUTED)
272
+
273
+ def executed_with_callbacks(self):
274
+ """
275
+ Called when the task has been successfully executed and
276
+ the Taskmaster instance wants to call the Node's callback
277
+ methods.
278
+
279
+ This may have been a do-nothing operation (to preserve build
280
+ order), so we must check the node's state before deciding whether
281
+ it was "built", in which case we call the appropriate Node method.
282
+ In any event, we always call "visited()", which will handle any
283
+ post-visit actions that must take place regardless of whether
284
+ or not the target was an actual built target or a source Node.
285
+ """
286
+ T = self.tm.trace
287
+ if T: T.write(self.trace_message('Task.executed_with_callbacks()',
288
+ self.node))
289
+
290
+ for t in self.targets:
291
+ if t.get_state() == NODE_EXECUTING:
292
+ for side_effect in t.side_effects:
293
+ side_effect.set_state(NODE_NO_STATE)
294
+ t.set_state(NODE_EXECUTED)
295
+ t.push_to_cache()
296
+ t.built()
297
+ t.visited()
298
+
299
+ executed = executed_with_callbacks
300
+
301
+ def failed(self):
302
+ """
303
+ Default action when a task fails: stop the build.
304
+
305
+ Note: Although this function is normally invoked on nodes in
306
+ the executing state, it might also be invoked on up-to-date
307
+ nodes when using Configure().
308
+ """
309
+ self.fail_stop()
310
+
311
+ def fail_stop(self):
312
+ """
313
+ Explicit stop-the-build failure.
314
+
315
+ This sets failure status on the target nodes and all of
316
+ their dependent parent nodes.
317
+
318
+ Note: Although this function is normally invoked on nodes in
319
+ the executing state, it might also be invoked on up-to-date
320
+ nodes when using Configure().
321
+ """
322
+ T = self.tm.trace
323
+ if T: T.write(self.trace_message('Task.failed_stop()', self.node))
324
+
325
+ # Invoke will_not_build() to clean-up the pending children
326
+ # list.
327
+ self.tm.will_not_build(self.targets, lambda n: n.set_state(NODE_FAILED))
328
+
329
+ # Tell the taskmaster to not start any new tasks
330
+ self.tm.stop()
331
+
332
+ # We're stopping because of a build failure, but give the
333
+ # calling Task class a chance to postprocess() the top-level
334
+ # target under which the build failure occurred.
335
+ self.targets = [self.tm.current_top]
336
+ self.top = 1
337
+
338
+ def fail_continue(self):
339
+ """
340
+ Explicit continue-the-build failure.
341
+
342
+ This sets failure status on the target nodes and all of
343
+ their dependent parent nodes.
344
+
345
+ Note: Although this function is normally invoked on nodes in
346
+ the executing state, it might also be invoked on up-to-date
347
+ nodes when using Configure().
348
+ """
349
+ T = self.tm.trace
350
+ if T: T.write(self.trace_message('Task.failed_continue()', self.node))
351
+
352
+ self.tm.will_not_build(self.targets, lambda n: n.set_state(NODE_FAILED))
353
+
354
+ def make_ready_all(self):
355
+ """
356
+ Marks all targets in a task ready for execution.
357
+
358
+ This is used when the interface needs every target Node to be
359
+ visited--the canonical example being the "scons -c" option.
360
+ """
361
+ T = self.tm.trace
362
+ if T: T.write(self.trace_message('Task.make_ready_all()', self.node))
363
+
364
+ self.out_of_date = self.targets[:]
365
+ for t in self.targets:
366
+ t.disambiguate().set_state(NODE_EXECUTING)
367
+ for s in t.side_effects:
368
+ # add disambiguate here to mirror the call on targets above
369
+ s.disambiguate().set_state(NODE_EXECUTING)
370
+
371
+ def make_ready_current(self):
372
+ """
373
+ Marks all targets in a task ready for execution if any target
374
+ is not current.
375
+
376
+ This is the default behavior for building only what's necessary.
377
+ """
378
+ T = self.tm.trace
379
+ if T: T.write(self.trace_message(u'Task.make_ready_current()',
380
+ self.node))
381
+
382
+ self.out_of_date = []
383
+ needs_executing = False
384
+ for t in self.targets:
385
+ try:
386
+ t.disambiguate().make_ready()
387
+ is_up_to_date = not t.has_builder() or \
388
+ (not t.always_build and t.is_up_to_date())
389
+ except EnvironmentError, e:
390
+ raise SCons.Errors.BuildError(node=t, errstr=e.strerror, filename=e.filename)
391
+
392
+ if not is_up_to_date:
393
+ self.out_of_date.append(t)
394
+ needs_executing = True
395
+
396
+ if needs_executing:
397
+ for t in self.targets:
398
+ t.set_state(NODE_EXECUTING)
399
+ for s in t.side_effects:
400
+ # add disambiguate here to mirror the call on targets in first loop above
401
+ s.disambiguate().set_state(NODE_EXECUTING)
402
+ else:
403
+ for t in self.targets:
404
+ # We must invoke visited() to ensure that the node
405
+ # information has been computed before allowing the
406
+ # parent nodes to execute. (That could occur in a
407
+ # parallel build...)
408
+ t.visited()
409
+ t.set_state(NODE_UP_TO_DATE)
410
+
411
+ make_ready = make_ready_current
412
+
413
+ def postprocess(self):
414
+ """
415
+ Post-processes a task after it's been executed.
416
+
417
+ This examines all the targets just built (or not, we don't care
418
+ if the build was successful, or even if there was no build
419
+ because everything was up-to-date) to see if they have any
420
+ waiting parent Nodes, or Nodes waiting on a common side effect,
421
+ that can be put back on the candidates list.
422
+ """
423
+ T = self.tm.trace
424
+ if T: T.write(self.trace_message(u'Task.postprocess()', self.node))
425
+
426
+ # We may have built multiple targets, some of which may have
427
+ # common parents waiting for this build. Count up how many
428
+ # targets each parent was waiting for so we can subtract the
429
+ # values later, and so we *don't* put waiting side-effect Nodes
430
+ # back on the candidates list if the Node is also a waiting
431
+ # parent.
432
+
433
+ targets = set(self.targets)
434
+
435
+ pending_children = self.tm.pending_children
436
+ parents = {}
437
+ for t in targets:
438
+ # A node can only be in the pending_children set if it has
439
+ # some waiting_parents.
440
+ if t.waiting_parents:
441
+ if T: T.write(self.trace_message(u'Task.postprocess()',
442
+ t,
443
+ 'removing'))
444
+ pending_children.discard(t)
445
+ for p in t.waiting_parents:
446
+ parents[p] = parents.get(p, 0) + 1
447
+
448
+ for t in targets:
449
+ for s in t.side_effects:
450
+ if s.get_state() == NODE_EXECUTING:
451
+ s.set_state(NODE_NO_STATE)
452
+ for p in s.waiting_parents:
453
+ parents[p] = parents.get(p, 0) + 1
454
+ for p in s.waiting_s_e:
455
+ if p.ref_count == 0:
456
+ self.tm.candidates.append(p)
457
+
458
+ for p, subtract in parents.items():
459
+ p.ref_count = p.ref_count - subtract
460
+ if T: T.write(self.trace_message(u'Task.postprocess()',
461
+ p,
462
+ 'adjusted parent ref count'))
463
+ if p.ref_count == 0:
464
+ self.tm.candidates.append(p)
465
+
466
+ for t in targets:
467
+ t.postprocess()
468
+
469
+ # Exception handling subsystem.
470
+ #
471
+ # Exceptions that occur while walking the DAG or examining Nodes
472
+ # must be raised, but must be raised at an appropriate time and in
473
+ # a controlled manner so we can, if necessary, recover gracefully,
474
+ # possibly write out signature information for Nodes we've updated,
475
+ # etc. This is done by having the Taskmaster tell us about the
476
+ # exception, and letting
477
+
478
+ def exc_info(self):
479
+ """
480
+ Returns info about a recorded exception.
481
+ """
482
+ return self.exception
483
+
484
+ def exc_clear(self):
485
+ """
486
+ Clears any recorded exception.
487
+
488
+ This also changes the "exception_raise" attribute to point
489
+ to the appropriate do-nothing method.
490
+ """
491
+ self.exception = (None, None, None)
492
+ self.exception_raise = self._no_exception_to_raise
493
+
494
+ def exception_set(self, exception=None):
495
+ """
496
+ Records an exception to be raised at the appropriate time.
497
+
498
+ This also changes the "exception_raise" attribute to point
499
+ to the method that will, in fact
500
+ """
501
+ if not exception:
502
+ exception = sys.exc_info()
503
+ self.exception = exception
504
+ self.exception_raise = self._exception_raise
505
+
506
+ def _no_exception_to_raise(self):
507
+ pass
508
+
509
+ def _exception_raise(self):
510
+ """
511
+ Raises a pending exception that was recorded while getting a
512
+ Task ready for execution.
513
+ """
514
+ exc = self.exc_info()[:]
515
+ try:
516
+ exc_type, exc_value, exc_traceback = exc
517
+ except ValueError:
518
+ exc_type, exc_value = exc
519
+ exc_traceback = None
520
+ raise exc_type, exc_value, exc_traceback
521
+
522
+ class AlwaysTask(Task):
523
+ def needs_execute(self):
524
+ """
525
+ Always returns True (indicating this Task should always
526
+ be executed).
527
+
528
+ Subclasses that need this behavior (as opposed to the default
529
+ of only executing Nodes that are out of date w.r.t. their
530
+ dependencies) can use this as follows:
531
+
532
+ class MyTaskSubclass(SCons.Taskmaster.Task):
533
+ needs_execute = SCons.Taskmaster.Task.execute_always
534
+ """
535
+ return True
536
+
537
+ class OutOfDateTask(Task):
538
+ def needs_execute(self):
539
+ """
540
+ Returns True (indicating this Task should be executed) if this
541
+ Task's target state indicates it needs executing, which has
542
+ already been determined by an earlier up-to-date check.
543
+ """
544
+ return self.targets[0].get_state() == SCons.Node.executing
545
+
546
+
547
+ def find_cycle(stack, visited):
548
+ if stack[-1] in visited:
549
+ return None
550
+ visited.add(stack[-1])
551
+ for n in stack[-1].waiting_parents:
552
+ stack.append(n)
553
+ if stack[0] == stack[-1]:
554
+ return stack
555
+ if find_cycle(stack, visited):
556
+ return stack
557
+ stack.pop()
558
+ return None
559
+
560
+
561
+ class Taskmaster(object):
562
+ """
563
+ The Taskmaster for walking the dependency DAG.
564
+ """
565
+
566
+ def __init__(self, targets=[], tasker=None, order=None, trace=None):
567
+ self.original_top = targets
568
+ self.top_targets_left = targets[:]
569
+ self.top_targets_left.reverse()
570
+ self.candidates = []
571
+ if tasker is None:
572
+ tasker = OutOfDateTask
573
+ self.tasker = tasker
574
+ if not order:
575
+ order = lambda l: l
576
+ self.order = order
577
+ self.message = None
578
+ self.trace = trace
579
+ self.next_candidate = self.find_next_candidate
580
+ self.pending_children = set()
581
+
582
+ def find_next_candidate(self):
583
+ """
584
+ Returns the next candidate Node for (potential) evaluation.
585
+
586
+ The candidate list (really a stack) initially consists of all of
587
+ the top-level (command line) targets provided when the Taskmaster
588
+ was initialized. While we walk the DAG, visiting Nodes, all the
589
+ children that haven't finished processing get pushed on to the
590
+ candidate list. Each child can then be popped and examined in
591
+ turn for whether *their* children are all up-to-date, in which
592
+ case a Task will be created for their actual evaluation and
593
+ potential building.
594
+
595
+ Here is where we also allow candidate Nodes to alter the list of
596
+ Nodes that should be examined. This is used, for example, when
597
+ invoking SCons in a source directory. A source directory Node can
598
+ return its corresponding build directory Node, essentially saying,
599
+ "Hey, you really need to build this thing over here instead."
600
+ """
601
+ try:
602
+ return self.candidates.pop()
603
+ except IndexError:
604
+ pass
605
+ try:
606
+ node = self.top_targets_left.pop()
607
+ except IndexError:
608
+ return None
609
+ self.current_top = node
610
+ alt, message = node.alter_targets()
611
+ if alt:
612
+ self.message = message
613
+ self.candidates.append(node)
614
+ self.candidates.extend(self.order(alt))
615
+ node = self.candidates.pop()
616
+ return node
617
+
618
+ def no_next_candidate(self):
619
+ """
620
+ Stops Taskmaster processing by not returning a next candidate.
621
+
622
+ Note that we have to clean-up the Taskmaster candidate list
623
+ because the cycle detection depends on the fact all nodes have
624
+ been processed somehow.
625
+ """
626
+ while self.candidates:
627
+ candidates = self.candidates
628
+ self.candidates = []
629
+ self.will_not_build(candidates)
630
+ return None
631
+
632
+ def _validate_pending_children(self):
633
+ """
634
+ Validate the content of the pending_children set. Assert if an
635
+ internal error is found.
636
+
637
+ This function is used strictly for debugging the taskmaster by
638
+ checking that no invariants are violated. It is not used in
639
+ normal operation.
640
+
641
+ The pending_children set is used to detect cycles in the
642
+ dependency graph. We call a "pending child" a child that is
643
+ found in the "pending" state when checking the dependencies of
644
+ its parent node.
645
+
646
+ A pending child can occur when the Taskmaster completes a loop
647
+ through a cycle. For example, lets imagine a graph made of
648
+ three node (A, B and C) making a cycle. The evaluation starts
649
+ at node A. The taskmaster first consider whether node A's
650
+ child B is up-to-date. Then, recursively, node B needs to
651
+ check whether node C is up-to-date. This leaves us with a
652
+ dependency graph looking like:
653
+
654
+ Next candidate \
655
+ \
656
+ Node A (Pending) --> Node B(Pending) --> Node C (NoState)
657
+ ^ |
658
+ | |
659
+ +-------------------------------------+
660
+
661
+ Now, when the Taskmaster examines the Node C's child Node A,
662
+ it finds that Node A is in the "pending" state. Therefore,
663
+ Node A is a pending child of node C.
664
+
665
+ Pending children indicate that the Taskmaster has potentially
666
+ loop back through a cycle. We say potentially because it could
667
+ also occur when a DAG is evaluated in parallel. For example,
668
+ consider the following graph:
669
+
670
+
671
+ Node A (Pending) --> Node B(Pending) --> Node C (Pending) --> ...
672
+ | ^
673
+ | |
674
+ +----------> Node D (NoState) --------+
675
+ /
676
+ Next candidate /
677
+
678
+ The Taskmaster first evaluates the nodes A, B, and C and
679
+ starts building some children of node C. Assuming, that the
680
+ maximum parallel level has not been reached, the Taskmaster
681
+ will examine Node D. It will find that Node C is a pending
682
+ child of Node D.
683
+
684
+ In summary, evaluating a graph with a cycle will always
685
+ involve a pending child at one point. A pending child might
686
+ indicate either a cycle or a diamond-shaped DAG. Only a
687
+ fraction of the nodes ends-up being a "pending child" of
688
+ another node. This keeps the pending_children set small in
689
+ practice.
690
+
691
+ We can differentiate between the two cases if we wait until
692
+ the end of the build. At this point, all the pending children
693
+ nodes due to a diamond-shaped DAG will have been properly
694
+ built (or will have failed to build). But, the pending
695
+ children involved in a cycle will still be in the pending
696
+ state.
697
+
698
+ The taskmaster removes nodes from the pending_children set as
699
+ soon as a pending_children node moves out of the pending
700
+ state. This also helps to keep the pending_children set small.
701
+ """
702
+
703
+ for n in self.pending_children:
704
+ assert n.state in (NODE_PENDING, NODE_EXECUTING), \
705
+ (str(n), StateString[n.state])
706
+ assert len(n.waiting_parents) != 0, (str(n), len(n.waiting_parents))
707
+ for p in n.waiting_parents:
708
+ assert p.ref_count > 0, (str(n), str(p), p.ref_count)
709
+
710
+
711
+ def trace_message(self, message):
712
+ return 'Taskmaster: %s\n' % message
713
+
714
+ def trace_node(self, node):
715
+ return '<%-10s %-3s %s>' % (StateString[node.get_state()],
716
+ node.ref_count,
717
+ repr(str(node)))
718
+
719
+ def _find_next_ready_node(self):
720
+ """
721
+ Finds the next node that is ready to be built.
722
+
723
+ This is *the* main guts of the DAG walk. We loop through the
724
+ list of candidates, looking for something that has no un-built
725
+ children (i.e., that is a leaf Node or has dependencies that are
726
+ all leaf Nodes or up-to-date). Candidate Nodes are re-scanned
727
+ (both the target Node itself and its sources, which are always
728
+ scanned in the context of a given target) to discover implicit
729
+ dependencies. A Node that must wait for some children to be
730
+ built will be put back on the candidates list after the children
731
+ have finished building. A Node that has been put back on the
732
+ candidates list in this way may have itself (or its sources)
733
+ re-scanned, in order to handle generated header files (e.g.) and
734
+ the implicit dependencies therein.
735
+
736
+ Note that this method does not do any signature calculation or
737
+ up-to-date check itself. All of that is handled by the Task
738
+ class. This is purely concerned with the dependency graph walk.
739
+ """
740
+
741
+ self.ready_exc = None
742
+
743
+ T = self.trace
744
+ if T: T.write(u'\n' + self.trace_message('Looking for a node to evaluate'))
745
+
746
+ while True:
747
+ node = self.next_candidate()
748
+ if node is None:
749
+ if T: T.write(self.trace_message('No candidate anymore.') + u'\n')
750
+ return None
751
+
752
+ node = node.disambiguate()
753
+ state = node.get_state()
754
+
755
+ # For debugging only:
756
+ #
757
+ # try:
758
+ # self._validate_pending_children()
759
+ # except:
760
+ # self.ready_exc = sys.exc_info()
761
+ # return node
762
+
763
+ if CollectStats:
764
+ if not hasattr(node, 'stats'):
765
+ node.stats = Stats()
766
+ StatsNodes.append(node)
767
+ S = node.stats
768
+ S.considered = S.considered + 1
769
+ else:
770
+ S = None
771
+
772
+ if T: T.write(self.trace_message(u' Considering node %s and its children:' % self.trace_node(node)))
773
+
774
+ if state == NODE_NO_STATE:
775
+ # Mark this node as being on the execution stack:
776
+ node.set_state(NODE_PENDING)
777
+ elif state > NODE_PENDING:
778
+ # Skip this node if it has already been evaluated:
779
+ if S: S.already_handled = S.already_handled + 1
780
+ if T: T.write(self.trace_message(u' already handled (executed)'))
781
+ continue
782
+
783
+ executor = node.get_executor()
784
+
785
+ try:
786
+ children = executor.get_all_children()
787
+ except SystemExit:
788
+ exc_value = sys.exc_info()[1]
789
+ e = SCons.Errors.ExplicitExit(node, exc_value.code)
790
+ self.ready_exc = (SCons.Errors.ExplicitExit, e)
791
+ if T: T.write(self.trace_message(' SystemExit'))
792
+ return node
793
+ except Exception, e:
794
+ # We had a problem just trying to figure out the
795
+ # children (like a child couldn't be linked in to a
796
+ # VariantDir, or a Scanner threw something). Arrange to
797
+ # raise the exception when the Task is "executed."
798
+ self.ready_exc = sys.exc_info()
799
+ if S: S.problem = S.problem + 1
800
+ if T: T.write(self.trace_message(' exception %s while scanning children.\n' % e))
801
+ return node
802
+
803
+ children_not_visited = []
804
+ children_pending = set()
805
+ children_not_ready = []
806
+ children_failed = False
807
+
808
+ for child in chain(executor.get_all_prerequisites(), children):
809
+ childstate = child.get_state()
810
+
811
+ if T: T.write(self.trace_message(u' ' + self.trace_node(child)))
812
+
813
+ if childstate == NODE_NO_STATE:
814
+ children_not_visited.append(child)
815
+ elif childstate == NODE_PENDING:
816
+ children_pending.add(child)
817
+ elif childstate == NODE_FAILED:
818
+ children_failed = True
819
+
820
+ if childstate <= NODE_EXECUTING:
821
+ children_not_ready.append(child)
822
+
823
+
824
+ # These nodes have not even been visited yet. Add
825
+ # them to the list so that on some next pass we can
826
+ # take a stab at evaluating them (or their children).
827
+ children_not_visited.reverse()
828
+ self.candidates.extend(self.order(children_not_visited))
829
+ #if T and children_not_visited:
830
+ # T.write(self.trace_message(' adding to candidates: %s' % map(str, children_not_visited)))
831
+ # T.write(self.trace_message(' candidates now: %s\n' % map(str, self.candidates)))
832
+
833
+ # Skip this node if any of its children have failed.
834
+ #
835
+ # This catches the case where we're descending a top-level
836
+ # target and one of our children failed while trying to be
837
+ # built by a *previous* descent of an earlier top-level
838
+ # target.
839
+ #
840
+ # It can also occur if a node is reused in multiple
841
+ # targets. One first descends though the one of the
842
+ # target, the next time occurs through the other target.
843
+ #
844
+ # Note that we can only have failed_children if the
845
+ # --keep-going flag was used, because without it the build
846
+ # will stop before diving in the other branch.
847
+ #
848
+ # Note that even if one of the children fails, we still
849
+ # added the other children to the list of candidate nodes
850
+ # to keep on building (--keep-going).
851
+ if children_failed:
852
+ for n in executor.get_action_targets():
853
+ n.set_state(NODE_FAILED)
854
+
855
+ if S: S.child_failed = S.child_failed + 1
856
+ if T: T.write(self.trace_message('****** %s\n' % self.trace_node(node)))
857
+ continue
858
+
859
+ if children_not_ready:
860
+ for child in children_not_ready:
861
+ # We're waiting on one or more derived targets
862
+ # that have not yet finished building.
863
+ if S: S.not_built = S.not_built + 1
864
+
865
+ # Add this node to the waiting parents lists of
866
+ # anything we're waiting on, with a reference
867
+ # count so we can be put back on the list for
868
+ # re-evaluation when they've all finished.
869
+ node.ref_count = node.ref_count + child.add_to_waiting_parents(node)
870
+ if T: T.write(self.trace_message(u' adjusted ref count: %s, child %s' %
871
+ (self.trace_node(node), repr(str(child)))))
872
+
873
+ if T:
874
+ for pc in children_pending:
875
+ T.write(self.trace_message(' adding %s to the pending children set\n' %
876
+ self.trace_node(pc)))
877
+ self.pending_children = self.pending_children | children_pending
878
+
879
+ continue
880
+
881
+ # Skip this node if it has side-effects that are
882
+ # currently being built:
883
+ wait_side_effects = False
884
+ for se in executor.get_action_side_effects():
885
+ if se.get_state() == NODE_EXECUTING:
886
+ se.add_to_waiting_s_e(node)
887
+ wait_side_effects = True
888
+
889
+ if wait_side_effects:
890
+ if S: S.side_effects = S.side_effects + 1
891
+ continue
892
+
893
+ # The default when we've gotten through all of the checks above:
894
+ # this node is ready to be built.
895
+ if S: S.build = S.build + 1
896
+ if T: T.write(self.trace_message(u'Evaluating %s\n' %
897
+ self.trace_node(node)))
898
+
899
+ # For debugging only:
900
+ #
901
+ # try:
902
+ # self._validate_pending_children()
903
+ # except:
904
+ # self.ready_exc = sys.exc_info()
905
+ # return node
906
+
907
+ return node
908
+
909
+ return None
910
+
911
+ def next_task(self):
912
+ """
913
+ Returns the next task to be executed.
914
+
915
+ This simply asks for the next Node to be evaluated, and then wraps
916
+ it in the specific Task subclass with which we were initialized.
917
+ """
918
+ node = self._find_next_ready_node()
919
+
920
+ if node is None:
921
+ return None
922
+
923
+ tlist = node.get_executor().get_all_targets()
924
+
925
+ task = self.tasker(self, tlist, node in self.original_top, node)
926
+ try:
927
+ task.make_ready()
928
+ except:
929
+ # We had a problem just trying to get this task ready (like
930
+ # a child couldn't be linked in to a VariantDir when deciding
931
+ # whether this node is current). Arrange to raise the
932
+ # exception when the Task is "executed."
933
+ self.ready_exc = sys.exc_info()
934
+
935
+ if self.ready_exc:
936
+ task.exception_set(self.ready_exc)
937
+
938
+ self.ready_exc = None
939
+
940
+ return task
941
+
942
+ def will_not_build(self, nodes, node_func=lambda n: None):
943
+ """
944
+ Perform clean-up about nodes that will never be built. Invokes
945
+ a user defined function on all of these nodes (including all
946
+ of their parents).
947
+ """
948
+
949
+ T = self.trace
950
+
951
+ pending_children = self.pending_children
952
+
953
+ to_visit = set(nodes)
954
+ pending_children = pending_children - to_visit
955
+
956
+ if T:
957
+ for n in nodes:
958
+ T.write(self.trace_message(' removing node %s from the pending children set\n' %
959
+ self.trace_node(n)))
960
+ try:
961
+ while len(to_visit):
962
+ node = to_visit.pop()
963
+ node_func(node)
964
+
965
+ # Prune recursion by flushing the waiting children
966
+ # list immediately.
967
+ parents = node.waiting_parents
968
+ node.waiting_parents = set()
969
+
970
+ to_visit = to_visit | parents
971
+ pending_children = pending_children - parents
972
+
973
+ for p in parents:
974
+ p.ref_count = p.ref_count - 1
975
+ if T: T.write(self.trace_message(' removing parent %s from the pending children set\n' %
976
+ self.trace_node(p)))
977
+ except KeyError:
978
+ # The container to_visit has been emptied.
979
+ pass
980
+
981
+ # We have the stick back the pending_children list into the
982
+ # taskmaster because the python 1.5.2 compatibility does not
983
+ # allow us to use in-place updates
984
+ self.pending_children = pending_children
985
+
986
+ def stop(self):
987
+ """
988
+ Stops the current build completely.
989
+ """
990
+ self.next_candidate = self.no_next_candidate
991
+
992
+ def cleanup(self):
993
+ """
994
+ Check for dependency cycles.
995
+ """
996
+ if not self.pending_children:
997
+ return
998
+
999
+ nclist = [(n, find_cycle([n], set())) for n in self.pending_children]
1000
+
1001
+ genuine_cycles = [
1002
+ node for node,cycle in nclist
1003
+ if cycle or node.get_state() != NODE_EXECUTED
1004
+ ]
1005
+ if not genuine_cycles:
1006
+ # All of the "cycles" found were single nodes in EXECUTED state,
1007
+ # which is to say, they really weren't cycles. Just return.
1008
+ return
1009
+
1010
+ desc = 'Found dependency cycle(s):\n'
1011
+ for node, cycle in nclist:
1012
+ if cycle:
1013
+ desc = desc + " " + " -> ".join(map(str, cycle)) + "\n"
1014
+ else:
1015
+ desc = desc + \
1016
+ " Internal Error: no cycle found for node %s (%s) in state %s\n" % \
1017
+ (node, repr(node), StateString[node.get_state()])
1018
+
1019
+ raise SCons.Errors.UserError(desc)
1020
+
1021
+ # Local Variables:
1022
+ # tab-width:4
1023
+ # indent-tabs-mode:nil
1024
+ # End:
1025
+ # vim: set expandtab tabstop=4 shiftwidth=4: