therubyracer 0.9.0beta4 → 0.9.0beta5

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of therubyracer might be problematic. Click here for more details.

Files changed (771) hide show
  1. data/.gitignore +1 -0
  2. data/Rakefile +0 -11
  3. data/ext/v8/extconf.rb +9 -9
  4. data/ext/v8/v8_external.cpp +40 -10
  5. data/lib/v8/cli.rb +2 -1
  6. data/lib/v8/version.rb +1 -1
  7. data/spec/redjs/.gitignore +1 -0
  8. data/therubyracer.gemspec +2 -3
  9. metadata +33 -779
  10. data/ext/v8/upstream/Makefile +0 -38
  11. data/ext/v8/upstream/detect_cpu.rb +0 -27
  12. data/ext/v8/upstream/fpic-on-linux-amd64.patch +0 -13
  13. data/ext/v8/upstream/scons/CHANGES.txt +0 -5183
  14. data/ext/v8/upstream/scons/LICENSE.txt +0 -20
  15. data/ext/v8/upstream/scons/MANIFEST +0 -202
  16. data/ext/v8/upstream/scons/PKG-INFO +0 -13
  17. data/ext/v8/upstream/scons/README.txt +0 -273
  18. data/ext/v8/upstream/scons/RELEASE.txt +0 -1040
  19. data/ext/v8/upstream/scons/engine/SCons/Action.py +0 -1256
  20. data/ext/v8/upstream/scons/engine/SCons/Builder.py +0 -868
  21. data/ext/v8/upstream/scons/engine/SCons/CacheDir.py +0 -217
  22. data/ext/v8/upstream/scons/engine/SCons/Conftest.py +0 -794
  23. data/ext/v8/upstream/scons/engine/SCons/Debug.py +0 -237
  24. data/ext/v8/upstream/scons/engine/SCons/Defaults.py +0 -485
  25. data/ext/v8/upstream/scons/engine/SCons/Environment.py +0 -2327
  26. data/ext/v8/upstream/scons/engine/SCons/Errors.py +0 -207
  27. data/ext/v8/upstream/scons/engine/SCons/Executor.py +0 -636
  28. data/ext/v8/upstream/scons/engine/SCons/Job.py +0 -435
  29. data/ext/v8/upstream/scons/engine/SCons/Memoize.py +0 -292
  30. data/ext/v8/upstream/scons/engine/SCons/Node/Alias.py +0 -153
  31. data/ext/v8/upstream/scons/engine/SCons/Node/FS.py +0 -3220
  32. data/ext/v8/upstream/scons/engine/SCons/Node/Python.py +0 -128
  33. data/ext/v8/upstream/scons/engine/SCons/Node/__init__.py +0 -1341
  34. data/ext/v8/upstream/scons/engine/SCons/Options/BoolOption.py +0 -50
  35. data/ext/v8/upstream/scons/engine/SCons/Options/EnumOption.py +0 -50
  36. data/ext/v8/upstream/scons/engine/SCons/Options/ListOption.py +0 -50
  37. data/ext/v8/upstream/scons/engine/SCons/Options/PackageOption.py +0 -50
  38. data/ext/v8/upstream/scons/engine/SCons/Options/PathOption.py +0 -76
  39. data/ext/v8/upstream/scons/engine/SCons/Options/__init__.py +0 -74
  40. data/ext/v8/upstream/scons/engine/SCons/PathList.py +0 -232
  41. data/ext/v8/upstream/scons/engine/SCons/Platform/__init__.py +0 -236
  42. data/ext/v8/upstream/scons/engine/SCons/Platform/aix.py +0 -70
  43. data/ext/v8/upstream/scons/engine/SCons/Platform/cygwin.py +0 -55
  44. data/ext/v8/upstream/scons/engine/SCons/Platform/darwin.py +0 -46
  45. data/ext/v8/upstream/scons/engine/SCons/Platform/hpux.py +0 -46
  46. data/ext/v8/upstream/scons/engine/SCons/Platform/irix.py +0 -44
  47. data/ext/v8/upstream/scons/engine/SCons/Platform/os2.py +0 -58
  48. data/ext/v8/upstream/scons/engine/SCons/Platform/posix.py +0 -264
  49. data/ext/v8/upstream/scons/engine/SCons/Platform/sunos.py +0 -50
  50. data/ext/v8/upstream/scons/engine/SCons/Platform/win32.py +0 -386
  51. data/ext/v8/upstream/scons/engine/SCons/SConf.py +0 -1038
  52. data/ext/v8/upstream/scons/engine/SCons/SConsign.py +0 -381
  53. data/ext/v8/upstream/scons/engine/SCons/Scanner/C.py +0 -132
  54. data/ext/v8/upstream/scons/engine/SCons/Scanner/D.py +0 -74
  55. data/ext/v8/upstream/scons/engine/SCons/Scanner/Dir.py +0 -111
  56. data/ext/v8/upstream/scons/engine/SCons/Scanner/Fortran.py +0 -320
  57. data/ext/v8/upstream/scons/engine/SCons/Scanner/IDL.py +0 -48
  58. data/ext/v8/upstream/scons/engine/SCons/Scanner/LaTeX.py +0 -378
  59. data/ext/v8/upstream/scons/engine/SCons/Scanner/Prog.py +0 -103
  60. data/ext/v8/upstream/scons/engine/SCons/Scanner/RC.py +0 -55
  61. data/ext/v8/upstream/scons/engine/SCons/Scanner/__init__.py +0 -415
  62. data/ext/v8/upstream/scons/engine/SCons/Script/Interactive.py +0 -386
  63. data/ext/v8/upstream/scons/engine/SCons/Script/Main.py +0 -1360
  64. data/ext/v8/upstream/scons/engine/SCons/Script/SConsOptions.py +0 -944
  65. data/ext/v8/upstream/scons/engine/SCons/Script/SConscript.py +0 -642
  66. data/ext/v8/upstream/scons/engine/SCons/Script/__init__.py +0 -414
  67. data/ext/v8/upstream/scons/engine/SCons/Sig.py +0 -63
  68. data/ext/v8/upstream/scons/engine/SCons/Subst.py +0 -911
  69. data/ext/v8/upstream/scons/engine/SCons/Taskmaster.py +0 -1030
  70. data/ext/v8/upstream/scons/engine/SCons/Tool/386asm.py +0 -61
  71. data/ext/v8/upstream/scons/engine/SCons/Tool/BitKeeper.py +0 -65
  72. data/ext/v8/upstream/scons/engine/SCons/Tool/CVS.py +0 -73
  73. data/ext/v8/upstream/scons/engine/SCons/Tool/FortranCommon.py +0 -247
  74. data/ext/v8/upstream/scons/engine/SCons/Tool/JavaCommon.py +0 -324
  75. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/__init__.py +0 -56
  76. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/arch.py +0 -61
  77. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/common.py +0 -210
  78. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/netframework.py +0 -84
  79. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/sdk.py +0 -321
  80. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/vc.py +0 -367
  81. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/vs.py +0 -497
  82. data/ext/v8/upstream/scons/engine/SCons/Tool/Perforce.py +0 -104
  83. data/ext/v8/upstream/scons/engine/SCons/Tool/PharLapCommon.py +0 -138
  84. data/ext/v8/upstream/scons/engine/SCons/Tool/RCS.py +0 -64
  85. data/ext/v8/upstream/scons/engine/SCons/Tool/SCCS.py +0 -64
  86. data/ext/v8/upstream/scons/engine/SCons/Tool/Subversion.py +0 -71
  87. data/ext/v8/upstream/scons/engine/SCons/Tool/__init__.py +0 -675
  88. data/ext/v8/upstream/scons/engine/SCons/Tool/aixc++.py +0 -82
  89. data/ext/v8/upstream/scons/engine/SCons/Tool/aixcc.py +0 -74
  90. data/ext/v8/upstream/scons/engine/SCons/Tool/aixf77.py +0 -80
  91. data/ext/v8/upstream/scons/engine/SCons/Tool/aixlink.py +0 -76
  92. data/ext/v8/upstream/scons/engine/SCons/Tool/applelink.py +0 -71
  93. data/ext/v8/upstream/scons/engine/SCons/Tool/ar.py +0 -63
  94. data/ext/v8/upstream/scons/engine/SCons/Tool/as.py +0 -78
  95. data/ext/v8/upstream/scons/engine/SCons/Tool/bcc32.py +0 -82
  96. data/ext/v8/upstream/scons/engine/SCons/Tool/c++.py +0 -99
  97. data/ext/v8/upstream/scons/engine/SCons/Tool/cc.py +0 -114
  98. data/ext/v8/upstream/scons/engine/SCons/Tool/cvf.py +0 -58
  99. data/ext/v8/upstream/scons/engine/SCons/Tool/default.py +0 -50
  100. data/ext/v8/upstream/scons/engine/SCons/Tool/dmd.py +0 -224
  101. data/ext/v8/upstream/scons/engine/SCons/Tool/dvi.py +0 -64
  102. data/ext/v8/upstream/scons/engine/SCons/Tool/dvipdf.py +0 -125
  103. data/ext/v8/upstream/scons/engine/SCons/Tool/dvips.py +0 -94
  104. data/ext/v8/upstream/scons/engine/SCons/Tool/f77.py +0 -62
  105. data/ext/v8/upstream/scons/engine/SCons/Tool/f90.py +0 -62
  106. data/ext/v8/upstream/scons/engine/SCons/Tool/f95.py +0 -63
  107. data/ext/v8/upstream/scons/engine/SCons/Tool/filesystem.py +0 -98
  108. data/ext/v8/upstream/scons/engine/SCons/Tool/fortran.py +0 -63
  109. data/ext/v8/upstream/scons/engine/SCons/Tool/g++.py +0 -90
  110. data/ext/v8/upstream/scons/engine/SCons/Tool/g77.py +0 -73
  111. data/ext/v8/upstream/scons/engine/SCons/Tool/gas.py +0 -53
  112. data/ext/v8/upstream/scons/engine/SCons/Tool/gcc.py +0 -80
  113. data/ext/v8/upstream/scons/engine/SCons/Tool/gfortran.py +0 -64
  114. data/ext/v8/upstream/scons/engine/SCons/Tool/gnulink.py +0 -63
  115. data/ext/v8/upstream/scons/engine/SCons/Tool/gs.py +0 -81
  116. data/ext/v8/upstream/scons/engine/SCons/Tool/hpc++.py +0 -85
  117. data/ext/v8/upstream/scons/engine/SCons/Tool/hpcc.py +0 -53
  118. data/ext/v8/upstream/scons/engine/SCons/Tool/hplink.py +0 -77
  119. data/ext/v8/upstream/scons/engine/SCons/Tool/icc.py +0 -59
  120. data/ext/v8/upstream/scons/engine/SCons/Tool/icl.py +0 -52
  121. data/ext/v8/upstream/scons/engine/SCons/Tool/ifl.py +0 -72
  122. data/ext/v8/upstream/scons/engine/SCons/Tool/ifort.py +0 -90
  123. data/ext/v8/upstream/scons/engine/SCons/Tool/ilink.py +0 -59
  124. data/ext/v8/upstream/scons/engine/SCons/Tool/ilink32.py +0 -60
  125. data/ext/v8/upstream/scons/engine/SCons/Tool/install.py +0 -229
  126. data/ext/v8/upstream/scons/engine/SCons/Tool/intelc.py +0 -490
  127. data/ext/v8/upstream/scons/engine/SCons/Tool/ipkg.py +0 -71
  128. data/ext/v8/upstream/scons/engine/SCons/Tool/jar.py +0 -110
  129. data/ext/v8/upstream/scons/engine/SCons/Tool/javac.py +0 -234
  130. data/ext/v8/upstream/scons/engine/SCons/Tool/javah.py +0 -138
  131. data/ext/v8/upstream/scons/engine/SCons/Tool/latex.py +0 -79
  132. data/ext/v8/upstream/scons/engine/SCons/Tool/lex.py +0 -99
  133. data/ext/v8/upstream/scons/engine/SCons/Tool/link.py +0 -121
  134. data/ext/v8/upstream/scons/engine/SCons/Tool/linkloc.py +0 -112
  135. data/ext/v8/upstream/scons/engine/SCons/Tool/m4.py +0 -63
  136. data/ext/v8/upstream/scons/engine/SCons/Tool/masm.py +0 -77
  137. data/ext/v8/upstream/scons/engine/SCons/Tool/midl.py +0 -90
  138. data/ext/v8/upstream/scons/engine/SCons/Tool/mingw.py +0 -159
  139. data/ext/v8/upstream/scons/engine/SCons/Tool/mslib.py +0 -64
  140. data/ext/v8/upstream/scons/engine/SCons/Tool/mslink.py +0 -266
  141. data/ext/v8/upstream/scons/engine/SCons/Tool/mssdk.py +0 -50
  142. data/ext/v8/upstream/scons/engine/SCons/Tool/msvc.py +0 -269
  143. data/ext/v8/upstream/scons/engine/SCons/Tool/msvs.py +0 -1439
  144. data/ext/v8/upstream/scons/engine/SCons/Tool/mwcc.py +0 -208
  145. data/ext/v8/upstream/scons/engine/SCons/Tool/mwld.py +0 -107
  146. data/ext/v8/upstream/scons/engine/SCons/Tool/nasm.py +0 -72
  147. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/__init__.py +0 -314
  148. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/ipk.py +0 -185
  149. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/msi.py +0 -526
  150. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/rpm.py +0 -367
  151. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_tarbz2.py +0 -43
  152. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_targz.py +0 -43
  153. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_zip.py +0 -43
  154. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/tarbz2.py +0 -44
  155. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/targz.py +0 -44
  156. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/zip.py +0 -44
  157. data/ext/v8/upstream/scons/engine/SCons/Tool/pdf.py +0 -78
  158. data/ext/v8/upstream/scons/engine/SCons/Tool/pdflatex.py +0 -83
  159. data/ext/v8/upstream/scons/engine/SCons/Tool/pdftex.py +0 -108
  160. data/ext/v8/upstream/scons/engine/SCons/Tool/qt.py +0 -336
  161. data/ext/v8/upstream/scons/engine/SCons/Tool/rmic.py +0 -121
  162. data/ext/v8/upstream/scons/engine/SCons/Tool/rpcgen.py +0 -70
  163. data/ext/v8/upstream/scons/engine/SCons/Tool/rpm.py +0 -132
  164. data/ext/v8/upstream/scons/engine/SCons/Tool/sgiar.py +0 -68
  165. data/ext/v8/upstream/scons/engine/SCons/Tool/sgic++.py +0 -58
  166. data/ext/v8/upstream/scons/engine/SCons/Tool/sgicc.py +0 -53
  167. data/ext/v8/upstream/scons/engine/SCons/Tool/sgilink.py +0 -63
  168. data/ext/v8/upstream/scons/engine/SCons/Tool/sunar.py +0 -67
  169. data/ext/v8/upstream/scons/engine/SCons/Tool/sunc++.py +0 -142
  170. data/ext/v8/upstream/scons/engine/SCons/Tool/suncc.py +0 -58
  171. data/ext/v8/upstream/scons/engine/SCons/Tool/sunf77.py +0 -63
  172. data/ext/v8/upstream/scons/engine/SCons/Tool/sunf90.py +0 -64
  173. data/ext/v8/upstream/scons/engine/SCons/Tool/sunf95.py +0 -64
  174. data/ext/v8/upstream/scons/engine/SCons/Tool/sunlink.py +0 -77
  175. data/ext/v8/upstream/scons/engine/SCons/Tool/swig.py +0 -186
  176. data/ext/v8/upstream/scons/engine/SCons/Tool/tar.py +0 -73
  177. data/ext/v8/upstream/scons/engine/SCons/Tool/tex.py +0 -805
  178. data/ext/v8/upstream/scons/engine/SCons/Tool/textfile.py +0 -175
  179. data/ext/v8/upstream/scons/engine/SCons/Tool/tlib.py +0 -53
  180. data/ext/v8/upstream/scons/engine/SCons/Tool/wix.py +0 -100
  181. data/ext/v8/upstream/scons/engine/SCons/Tool/yacc.py +0 -131
  182. data/ext/v8/upstream/scons/engine/SCons/Tool/zip.py +0 -100
  183. data/ext/v8/upstream/scons/engine/SCons/Util.py +0 -1645
  184. data/ext/v8/upstream/scons/engine/SCons/Variables/BoolVariable.py +0 -91
  185. data/ext/v8/upstream/scons/engine/SCons/Variables/EnumVariable.py +0 -107
  186. data/ext/v8/upstream/scons/engine/SCons/Variables/ListVariable.py +0 -139
  187. data/ext/v8/upstream/scons/engine/SCons/Variables/PackageVariable.py +0 -109
  188. data/ext/v8/upstream/scons/engine/SCons/Variables/PathVariable.py +0 -147
  189. data/ext/v8/upstream/scons/engine/SCons/Variables/__init__.py +0 -317
  190. data/ext/v8/upstream/scons/engine/SCons/Warnings.py +0 -228
  191. data/ext/v8/upstream/scons/engine/SCons/__init__.py +0 -49
  192. data/ext/v8/upstream/scons/engine/SCons/compat/__init__.py +0 -302
  193. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_UserString.py +0 -98
  194. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_hashlib.py +0 -91
  195. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_itertools.py +0 -124
  196. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_optparse.py +0 -1725
  197. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_sets.py +0 -583
  198. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_sets15.py +0 -176
  199. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_shlex.py +0 -325
  200. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_subprocess.py +0 -1296
  201. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_textwrap.py +0 -382
  202. data/ext/v8/upstream/scons/engine/SCons/compat/builtins.py +0 -187
  203. data/ext/v8/upstream/scons/engine/SCons/cpp.py +0 -598
  204. data/ext/v8/upstream/scons/engine/SCons/dblite.py +0 -248
  205. data/ext/v8/upstream/scons/engine/SCons/exitfuncs.py +0 -77
  206. data/ext/v8/upstream/scons/os_spawnv_fix.diff +0 -83
  207. data/ext/v8/upstream/scons/scons-time.1 +0 -1017
  208. data/ext/v8/upstream/scons/scons.1 +0 -15179
  209. data/ext/v8/upstream/scons/sconsign.1 +0 -208
  210. data/ext/v8/upstream/scons/script/scons +0 -184
  211. data/ext/v8/upstream/scons/script/scons-time +0 -1529
  212. data/ext/v8/upstream/scons/script/scons.bat +0 -31
  213. data/ext/v8/upstream/scons/script/sconsign +0 -508
  214. data/ext/v8/upstream/scons/setup.cfg +0 -6
  215. data/ext/v8/upstream/scons/setup.py +0 -427
  216. data/ext/v8/upstream/v8/.gitignore +0 -33
  217. data/ext/v8/upstream/v8/AUTHORS +0 -42
  218. data/ext/v8/upstream/v8/ChangeLog +0 -2663
  219. data/ext/v8/upstream/v8/LICENSE +0 -52
  220. data/ext/v8/upstream/v8/LICENSE.strongtalk +0 -29
  221. data/ext/v8/upstream/v8/LICENSE.v8 +0 -26
  222. data/ext/v8/upstream/v8/LICENSE.valgrind +0 -45
  223. data/ext/v8/upstream/v8/SConstruct +0 -1473
  224. data/ext/v8/upstream/v8/build/README.txt +0 -25
  225. data/ext/v8/upstream/v8/build/all.gyp +0 -18
  226. data/ext/v8/upstream/v8/build/armu.gypi +0 -32
  227. data/ext/v8/upstream/v8/build/common.gypi +0 -82
  228. data/ext/v8/upstream/v8/build/gyp_v8 +0 -145
  229. data/ext/v8/upstream/v8/include/v8-debug.h +0 -394
  230. data/ext/v8/upstream/v8/include/v8-preparser.h +0 -116
  231. data/ext/v8/upstream/v8/include/v8-profiler.h +0 -505
  232. data/ext/v8/upstream/v8/include/v8-testing.h +0 -104
  233. data/ext/v8/upstream/v8/include/v8.h +0 -4000
  234. data/ext/v8/upstream/v8/include/v8stdint.h +0 -53
  235. data/ext/v8/upstream/v8/preparser/SConscript +0 -38
  236. data/ext/v8/upstream/v8/preparser/preparser-process.cc +0 -169
  237. data/ext/v8/upstream/v8/src/SConscript +0 -380
  238. data/ext/v8/upstream/v8/src/accessors.cc +0 -766
  239. data/ext/v8/upstream/v8/src/accessors.h +0 -121
  240. data/ext/v8/upstream/v8/src/allocation-inl.h +0 -49
  241. data/ext/v8/upstream/v8/src/allocation.cc +0 -122
  242. data/ext/v8/upstream/v8/src/allocation.h +0 -143
  243. data/ext/v8/upstream/v8/src/api.cc +0 -5678
  244. data/ext/v8/upstream/v8/src/api.h +0 -572
  245. data/ext/v8/upstream/v8/src/apinatives.js +0 -110
  246. data/ext/v8/upstream/v8/src/apiutils.h +0 -73
  247. data/ext/v8/upstream/v8/src/arguments.h +0 -116
  248. data/ext/v8/upstream/v8/src/arm/assembler-arm-inl.h +0 -353
  249. data/ext/v8/upstream/v8/src/arm/assembler-arm.cc +0 -2877
  250. data/ext/v8/upstream/v8/src/arm/assembler-arm.h +0 -1382
  251. data/ext/v8/upstream/v8/src/arm/builtins-arm.cc +0 -1634
  252. data/ext/v8/upstream/v8/src/arm/code-stubs-arm.cc +0 -6917
  253. data/ext/v8/upstream/v8/src/arm/code-stubs-arm.h +0 -623
  254. data/ext/v8/upstream/v8/src/arm/codegen-arm-inl.h +0 -48
  255. data/ext/v8/upstream/v8/src/arm/codegen-arm.cc +0 -7437
  256. data/ext/v8/upstream/v8/src/arm/codegen-arm.h +0 -595
  257. data/ext/v8/upstream/v8/src/arm/constants-arm.cc +0 -152
  258. data/ext/v8/upstream/v8/src/arm/constants-arm.h +0 -778
  259. data/ext/v8/upstream/v8/src/arm/cpu-arm.cc +0 -149
  260. data/ext/v8/upstream/v8/src/arm/debug-arm.cc +0 -317
  261. data/ext/v8/upstream/v8/src/arm/deoptimizer-arm.cc +0 -737
  262. data/ext/v8/upstream/v8/src/arm/disasm-arm.cc +0 -1503
  263. data/ext/v8/upstream/v8/src/arm/frames-arm.cc +0 -45
  264. data/ext/v8/upstream/v8/src/arm/frames-arm.h +0 -168
  265. data/ext/v8/upstream/v8/src/arm/full-codegen-arm.cc +0 -4374
  266. data/ext/v8/upstream/v8/src/arm/ic-arm.cc +0 -1793
  267. data/ext/v8/upstream/v8/src/arm/jump-target-arm.cc +0 -174
  268. data/ext/v8/upstream/v8/src/arm/lithium-arm.cc +0 -2120
  269. data/ext/v8/upstream/v8/src/arm/lithium-arm.h +0 -2179
  270. data/ext/v8/upstream/v8/src/arm/lithium-codegen-arm.cc +0 -4132
  271. data/ext/v8/upstream/v8/src/arm/lithium-codegen-arm.h +0 -329
  272. data/ext/v8/upstream/v8/src/arm/lithium-gap-resolver-arm.cc +0 -305
  273. data/ext/v8/upstream/v8/src/arm/lithium-gap-resolver-arm.h +0 -84
  274. data/ext/v8/upstream/v8/src/arm/macro-assembler-arm.cc +0 -2939
  275. data/ext/v8/upstream/v8/src/arm/macro-assembler-arm.h +0 -1071
  276. data/ext/v8/upstream/v8/src/arm/regexp-macro-assembler-arm.cc +0 -1287
  277. data/ext/v8/upstream/v8/src/arm/regexp-macro-assembler-arm.h +0 -253
  278. data/ext/v8/upstream/v8/src/arm/register-allocator-arm-inl.h +0 -100
  279. data/ext/v8/upstream/v8/src/arm/register-allocator-arm.cc +0 -63
  280. data/ext/v8/upstream/v8/src/arm/register-allocator-arm.h +0 -44
  281. data/ext/v8/upstream/v8/src/arm/simulator-arm.cc +0 -3288
  282. data/ext/v8/upstream/v8/src/arm/simulator-arm.h +0 -413
  283. data/ext/v8/upstream/v8/src/arm/stub-cache-arm.cc +0 -4034
  284. data/ext/v8/upstream/v8/src/arm/virtual-frame-arm-inl.h +0 -59
  285. data/ext/v8/upstream/v8/src/arm/virtual-frame-arm.cc +0 -843
  286. data/ext/v8/upstream/v8/src/arm/virtual-frame-arm.h +0 -523
  287. data/ext/v8/upstream/v8/src/array.js +0 -1249
  288. data/ext/v8/upstream/v8/src/assembler.cc +0 -1067
  289. data/ext/v8/upstream/v8/src/assembler.h +0 -823
  290. data/ext/v8/upstream/v8/src/ast-inl.h +0 -112
  291. data/ext/v8/upstream/v8/src/ast.cc +0 -1078
  292. data/ext/v8/upstream/v8/src/ast.h +0 -2234
  293. data/ext/v8/upstream/v8/src/atomicops.h +0 -167
  294. data/ext/v8/upstream/v8/src/atomicops_internals_arm_gcc.h +0 -145
  295. data/ext/v8/upstream/v8/src/atomicops_internals_mips_gcc.h +0 -169
  296. data/ext/v8/upstream/v8/src/atomicops_internals_x86_gcc.cc +0 -126
  297. data/ext/v8/upstream/v8/src/atomicops_internals_x86_gcc.h +0 -287
  298. data/ext/v8/upstream/v8/src/atomicops_internals_x86_macosx.h +0 -301
  299. data/ext/v8/upstream/v8/src/atomicops_internals_x86_msvc.h +0 -203
  300. data/ext/v8/upstream/v8/src/bignum-dtoa.cc +0 -655
  301. data/ext/v8/upstream/v8/src/bignum-dtoa.h +0 -81
  302. data/ext/v8/upstream/v8/src/bignum.cc +0 -768
  303. data/ext/v8/upstream/v8/src/bignum.h +0 -140
  304. data/ext/v8/upstream/v8/src/bootstrapper.cc +0 -2138
  305. data/ext/v8/upstream/v8/src/bootstrapper.h +0 -185
  306. data/ext/v8/upstream/v8/src/builtins.cc +0 -1708
  307. data/ext/v8/upstream/v8/src/builtins.h +0 -368
  308. data/ext/v8/upstream/v8/src/bytecodes-irregexp.h +0 -105
  309. data/ext/v8/upstream/v8/src/cached-powers.cc +0 -177
  310. data/ext/v8/upstream/v8/src/cached-powers.h +0 -65
  311. data/ext/v8/upstream/v8/src/char-predicates-inl.h +0 -94
  312. data/ext/v8/upstream/v8/src/char-predicates.h +0 -65
  313. data/ext/v8/upstream/v8/src/checks.cc +0 -110
  314. data/ext/v8/upstream/v8/src/checks.h +0 -296
  315. data/ext/v8/upstream/v8/src/circular-queue-inl.h +0 -53
  316. data/ext/v8/upstream/v8/src/circular-queue.cc +0 -122
  317. data/ext/v8/upstream/v8/src/circular-queue.h +0 -103
  318. data/ext/v8/upstream/v8/src/code-stubs.cc +0 -240
  319. data/ext/v8/upstream/v8/src/code-stubs.h +0 -971
  320. data/ext/v8/upstream/v8/src/code.h +0 -68
  321. data/ext/v8/upstream/v8/src/codegen-inl.h +0 -68
  322. data/ext/v8/upstream/v8/src/codegen.cc +0 -505
  323. data/ext/v8/upstream/v8/src/codegen.h +0 -245
  324. data/ext/v8/upstream/v8/src/compilation-cache.cc +0 -540
  325. data/ext/v8/upstream/v8/src/compilation-cache.h +0 -287
  326. data/ext/v8/upstream/v8/src/compiler.cc +0 -792
  327. data/ext/v8/upstream/v8/src/compiler.h +0 -307
  328. data/ext/v8/upstream/v8/src/contexts.cc +0 -327
  329. data/ext/v8/upstream/v8/src/contexts.h +0 -382
  330. data/ext/v8/upstream/v8/src/conversions-inl.h +0 -110
  331. data/ext/v8/upstream/v8/src/conversions.cc +0 -1125
  332. data/ext/v8/upstream/v8/src/conversions.h +0 -122
  333. data/ext/v8/upstream/v8/src/counters.cc +0 -93
  334. data/ext/v8/upstream/v8/src/counters.h +0 -254
  335. data/ext/v8/upstream/v8/src/cpu-profiler-inl.h +0 -101
  336. data/ext/v8/upstream/v8/src/cpu-profiler.cc +0 -606
  337. data/ext/v8/upstream/v8/src/cpu-profiler.h +0 -305
  338. data/ext/v8/upstream/v8/src/cpu.h +0 -67
  339. data/ext/v8/upstream/v8/src/d8-debug.cc +0 -367
  340. data/ext/v8/upstream/v8/src/d8-debug.h +0 -158
  341. data/ext/v8/upstream/v8/src/d8-posix.cc +0 -695
  342. data/ext/v8/upstream/v8/src/d8-readline.cc +0 -128
  343. data/ext/v8/upstream/v8/src/d8-windows.cc +0 -42
  344. data/ext/v8/upstream/v8/src/d8.cc +0 -796
  345. data/ext/v8/upstream/v8/src/d8.gyp +0 -88
  346. data/ext/v8/upstream/v8/src/d8.h +0 -231
  347. data/ext/v8/upstream/v8/src/d8.js +0 -2798
  348. data/ext/v8/upstream/v8/src/data-flow.cc +0 -545
  349. data/ext/v8/upstream/v8/src/data-flow.h +0 -379
  350. data/ext/v8/upstream/v8/src/date.js +0 -1103
  351. data/ext/v8/upstream/v8/src/dateparser-inl.h +0 -125
  352. data/ext/v8/upstream/v8/src/dateparser.cc +0 -178
  353. data/ext/v8/upstream/v8/src/dateparser.h +0 -265
  354. data/ext/v8/upstream/v8/src/debug-agent.cc +0 -447
  355. data/ext/v8/upstream/v8/src/debug-agent.h +0 -129
  356. data/ext/v8/upstream/v8/src/debug-debugger.js +0 -2569
  357. data/ext/v8/upstream/v8/src/debug.cc +0 -3188
  358. data/ext/v8/upstream/v8/src/debug.h +0 -1055
  359. data/ext/v8/upstream/v8/src/deoptimizer.cc +0 -1296
  360. data/ext/v8/upstream/v8/src/deoptimizer.h +0 -629
  361. data/ext/v8/upstream/v8/src/disasm.h +0 -80
  362. data/ext/v8/upstream/v8/src/disassembler.cc +0 -339
  363. data/ext/v8/upstream/v8/src/disassembler.h +0 -56
  364. data/ext/v8/upstream/v8/src/diy-fp.cc +0 -58
  365. data/ext/v8/upstream/v8/src/diy-fp.h +0 -117
  366. data/ext/v8/upstream/v8/src/double.h +0 -238
  367. data/ext/v8/upstream/v8/src/dtoa.cc +0 -103
  368. data/ext/v8/upstream/v8/src/dtoa.h +0 -85
  369. data/ext/v8/upstream/v8/src/execution.cc +0 -791
  370. data/ext/v8/upstream/v8/src/execution.h +0 -291
  371. data/ext/v8/upstream/v8/src/extensions/experimental/break-iterator.cc +0 -250
  372. data/ext/v8/upstream/v8/src/extensions/experimental/break-iterator.h +0 -89
  373. data/ext/v8/upstream/v8/src/extensions/experimental/experimental.gyp +0 -55
  374. data/ext/v8/upstream/v8/src/extensions/experimental/i18n-extension.cc +0 -284
  375. data/ext/v8/upstream/v8/src/extensions/experimental/i18n-extension.h +0 -64
  376. data/ext/v8/upstream/v8/src/extensions/externalize-string-extension.cc +0 -141
  377. data/ext/v8/upstream/v8/src/extensions/externalize-string-extension.h +0 -50
  378. data/ext/v8/upstream/v8/src/extensions/gc-extension.cc +0 -58
  379. data/ext/v8/upstream/v8/src/extensions/gc-extension.h +0 -49
  380. data/ext/v8/upstream/v8/src/factory.cc +0 -1194
  381. data/ext/v8/upstream/v8/src/factory.h +0 -436
  382. data/ext/v8/upstream/v8/src/fast-dtoa.cc +0 -736
  383. data/ext/v8/upstream/v8/src/fast-dtoa.h +0 -83
  384. data/ext/v8/upstream/v8/src/fixed-dtoa.cc +0 -405
  385. data/ext/v8/upstream/v8/src/fixed-dtoa.h +0 -55
  386. data/ext/v8/upstream/v8/src/flag-definitions.h +0 -556
  387. data/ext/v8/upstream/v8/src/flags.cc +0 -551
  388. data/ext/v8/upstream/v8/src/flags.h +0 -79
  389. data/ext/v8/upstream/v8/src/frame-element.cc +0 -37
  390. data/ext/v8/upstream/v8/src/frame-element.h +0 -269
  391. data/ext/v8/upstream/v8/src/frames-inl.h +0 -236
  392. data/ext/v8/upstream/v8/src/frames.cc +0 -1273
  393. data/ext/v8/upstream/v8/src/frames.h +0 -854
  394. data/ext/v8/upstream/v8/src/full-codegen.cc +0 -1385
  395. data/ext/v8/upstream/v8/src/full-codegen.h +0 -753
  396. data/ext/v8/upstream/v8/src/func-name-inferrer.cc +0 -91
  397. data/ext/v8/upstream/v8/src/func-name-inferrer.h +0 -111
  398. data/ext/v8/upstream/v8/src/gdb-jit.cc +0 -1548
  399. data/ext/v8/upstream/v8/src/gdb-jit.h +0 -138
  400. data/ext/v8/upstream/v8/src/global-handles.cc +0 -596
  401. data/ext/v8/upstream/v8/src/global-handles.h +0 -239
  402. data/ext/v8/upstream/v8/src/globals.h +0 -325
  403. data/ext/v8/upstream/v8/src/handles-inl.h +0 -177
  404. data/ext/v8/upstream/v8/src/handles.cc +0 -965
  405. data/ext/v8/upstream/v8/src/handles.h +0 -372
  406. data/ext/v8/upstream/v8/src/hashmap.cc +0 -230
  407. data/ext/v8/upstream/v8/src/hashmap.h +0 -121
  408. data/ext/v8/upstream/v8/src/heap-inl.h +0 -703
  409. data/ext/v8/upstream/v8/src/heap-profiler.cc +0 -1173
  410. data/ext/v8/upstream/v8/src/heap-profiler.h +0 -396
  411. data/ext/v8/upstream/v8/src/heap.cc +0 -5856
  412. data/ext/v8/upstream/v8/src/heap.h +0 -2264
  413. data/ext/v8/upstream/v8/src/hydrogen-instructions.cc +0 -1639
  414. data/ext/v8/upstream/v8/src/hydrogen-instructions.h +0 -3657
  415. data/ext/v8/upstream/v8/src/hydrogen.cc +0 -6011
  416. data/ext/v8/upstream/v8/src/hydrogen.h +0 -1137
  417. data/ext/v8/upstream/v8/src/ia32/assembler-ia32-inl.h +0 -430
  418. data/ext/v8/upstream/v8/src/ia32/assembler-ia32.cc +0 -2846
  419. data/ext/v8/upstream/v8/src/ia32/assembler-ia32.h +0 -1159
  420. data/ext/v8/upstream/v8/src/ia32/builtins-ia32.cc +0 -1596
  421. data/ext/v8/upstream/v8/src/ia32/code-stubs-ia32.cc +0 -6549
  422. data/ext/v8/upstream/v8/src/ia32/code-stubs-ia32.h +0 -495
  423. data/ext/v8/upstream/v8/src/ia32/codegen-ia32-inl.h +0 -46
  424. data/ext/v8/upstream/v8/src/ia32/codegen-ia32.cc +0 -10385
  425. data/ext/v8/upstream/v8/src/ia32/codegen-ia32.h +0 -801
  426. data/ext/v8/upstream/v8/src/ia32/cpu-ia32.cc +0 -88
  427. data/ext/v8/upstream/v8/src/ia32/debug-ia32.cc +0 -312
  428. data/ext/v8/upstream/v8/src/ia32/deoptimizer-ia32.cc +0 -774
  429. data/ext/v8/upstream/v8/src/ia32/disasm-ia32.cc +0 -1620
  430. data/ext/v8/upstream/v8/src/ia32/frames-ia32.cc +0 -45
  431. data/ext/v8/upstream/v8/src/ia32/frames-ia32.h +0 -140
  432. data/ext/v8/upstream/v8/src/ia32/full-codegen-ia32.cc +0 -4357
  433. data/ext/v8/upstream/v8/src/ia32/ic-ia32.cc +0 -1779
  434. data/ext/v8/upstream/v8/src/ia32/jump-target-ia32.cc +0 -437
  435. data/ext/v8/upstream/v8/src/ia32/lithium-codegen-ia32.cc +0 -4158
  436. data/ext/v8/upstream/v8/src/ia32/lithium-codegen-ia32.h +0 -318
  437. data/ext/v8/upstream/v8/src/ia32/lithium-gap-resolver-ia32.cc +0 -466
  438. data/ext/v8/upstream/v8/src/ia32/lithium-gap-resolver-ia32.h +0 -110
  439. data/ext/v8/upstream/v8/src/ia32/lithium-ia32.cc +0 -2181
  440. data/ext/v8/upstream/v8/src/ia32/lithium-ia32.h +0 -2235
  441. data/ext/v8/upstream/v8/src/ia32/macro-assembler-ia32.cc +0 -2056
  442. data/ext/v8/upstream/v8/src/ia32/macro-assembler-ia32.h +0 -807
  443. data/ext/v8/upstream/v8/src/ia32/regexp-macro-assembler-ia32.cc +0 -1264
  444. data/ext/v8/upstream/v8/src/ia32/regexp-macro-assembler-ia32.h +0 -216
  445. data/ext/v8/upstream/v8/src/ia32/register-allocator-ia32-inl.h +0 -82
  446. data/ext/v8/upstream/v8/src/ia32/register-allocator-ia32.cc +0 -157
  447. data/ext/v8/upstream/v8/src/ia32/register-allocator-ia32.h +0 -43
  448. data/ext/v8/upstream/v8/src/ia32/simulator-ia32.cc +0 -30
  449. data/ext/v8/upstream/v8/src/ia32/simulator-ia32.h +0 -72
  450. data/ext/v8/upstream/v8/src/ia32/stub-cache-ia32.cc +0 -3711
  451. data/ext/v8/upstream/v8/src/ia32/virtual-frame-ia32.cc +0 -1366
  452. data/ext/v8/upstream/v8/src/ia32/virtual-frame-ia32.h +0 -650
  453. data/ext/v8/upstream/v8/src/ic-inl.h +0 -130
  454. data/ext/v8/upstream/v8/src/ic.cc +0 -2389
  455. data/ext/v8/upstream/v8/src/ic.h +0 -675
  456. data/ext/v8/upstream/v8/src/inspector.cc +0 -63
  457. data/ext/v8/upstream/v8/src/inspector.h +0 -62
  458. data/ext/v8/upstream/v8/src/interpreter-irregexp.cc +0 -659
  459. data/ext/v8/upstream/v8/src/interpreter-irregexp.h +0 -49
  460. data/ext/v8/upstream/v8/src/isolate.cc +0 -883
  461. data/ext/v8/upstream/v8/src/isolate.h +0 -1306
  462. data/ext/v8/upstream/v8/src/json.js +0 -342
  463. data/ext/v8/upstream/v8/src/jsregexp.cc +0 -5371
  464. data/ext/v8/upstream/v8/src/jsregexp.h +0 -1483
  465. data/ext/v8/upstream/v8/src/jump-target-heavy-inl.h +0 -51
  466. data/ext/v8/upstream/v8/src/jump-target-heavy.cc +0 -427
  467. data/ext/v8/upstream/v8/src/jump-target-heavy.h +0 -238
  468. data/ext/v8/upstream/v8/src/jump-target-inl.h +0 -48
  469. data/ext/v8/upstream/v8/src/jump-target-light-inl.h +0 -56
  470. data/ext/v8/upstream/v8/src/jump-target-light.cc +0 -111
  471. data/ext/v8/upstream/v8/src/jump-target-light.h +0 -193
  472. data/ext/v8/upstream/v8/src/jump-target.cc +0 -91
  473. data/ext/v8/upstream/v8/src/jump-target.h +0 -90
  474. data/ext/v8/upstream/v8/src/list-inl.h +0 -206
  475. data/ext/v8/upstream/v8/src/list.h +0 -164
  476. data/ext/v8/upstream/v8/src/lithium-allocator-inl.h +0 -142
  477. data/ext/v8/upstream/v8/src/lithium-allocator.cc +0 -2105
  478. data/ext/v8/upstream/v8/src/lithium-allocator.h +0 -630
  479. data/ext/v8/upstream/v8/src/lithium.cc +0 -169
  480. data/ext/v8/upstream/v8/src/lithium.h +0 -592
  481. data/ext/v8/upstream/v8/src/liveedit-debugger.js +0 -1082
  482. data/ext/v8/upstream/v8/src/liveedit.cc +0 -1693
  483. data/ext/v8/upstream/v8/src/liveedit.h +0 -179
  484. data/ext/v8/upstream/v8/src/liveobjectlist-inl.h +0 -126
  485. data/ext/v8/upstream/v8/src/liveobjectlist.cc +0 -2589
  486. data/ext/v8/upstream/v8/src/liveobjectlist.h +0 -322
  487. data/ext/v8/upstream/v8/src/log-inl.h +0 -59
  488. data/ext/v8/upstream/v8/src/log-utils.cc +0 -423
  489. data/ext/v8/upstream/v8/src/log-utils.h +0 -229
  490. data/ext/v8/upstream/v8/src/log.cc +0 -1666
  491. data/ext/v8/upstream/v8/src/log.h +0 -446
  492. data/ext/v8/upstream/v8/src/macro-assembler.h +0 -120
  493. data/ext/v8/upstream/v8/src/macros.py +0 -178
  494. data/ext/v8/upstream/v8/src/mark-compact.cc +0 -3092
  495. data/ext/v8/upstream/v8/src/mark-compact.h +0 -506
  496. data/ext/v8/upstream/v8/src/math.js +0 -264
  497. data/ext/v8/upstream/v8/src/messages.cc +0 -166
  498. data/ext/v8/upstream/v8/src/messages.h +0 -114
  499. data/ext/v8/upstream/v8/src/messages.js +0 -1090
  500. data/ext/v8/upstream/v8/src/mips/assembler-mips-inl.h +0 -335
  501. data/ext/v8/upstream/v8/src/mips/assembler-mips.cc +0 -2093
  502. data/ext/v8/upstream/v8/src/mips/assembler-mips.h +0 -1066
  503. data/ext/v8/upstream/v8/src/mips/builtins-mips.cc +0 -148
  504. data/ext/v8/upstream/v8/src/mips/code-stubs-mips.cc +0 -752
  505. data/ext/v8/upstream/v8/src/mips/code-stubs-mips.h +0 -511
  506. data/ext/v8/upstream/v8/src/mips/codegen-mips-inl.h +0 -64
  507. data/ext/v8/upstream/v8/src/mips/codegen-mips.cc +0 -1213
  508. data/ext/v8/upstream/v8/src/mips/codegen-mips.h +0 -633
  509. data/ext/v8/upstream/v8/src/mips/constants-mips.cc +0 -352
  510. data/ext/v8/upstream/v8/src/mips/constants-mips.h +0 -723
  511. data/ext/v8/upstream/v8/src/mips/cpu-mips.cc +0 -90
  512. data/ext/v8/upstream/v8/src/mips/debug-mips.cc +0 -155
  513. data/ext/v8/upstream/v8/src/mips/deoptimizer-mips.cc +0 -91
  514. data/ext/v8/upstream/v8/src/mips/disasm-mips.cc +0 -1023
  515. data/ext/v8/upstream/v8/src/mips/frames-mips.cc +0 -48
  516. data/ext/v8/upstream/v8/src/mips/frames-mips.h +0 -179
  517. data/ext/v8/upstream/v8/src/mips/full-codegen-mips.cc +0 -727
  518. data/ext/v8/upstream/v8/src/mips/ic-mips.cc +0 -244
  519. data/ext/v8/upstream/v8/src/mips/jump-target-mips.cc +0 -80
  520. data/ext/v8/upstream/v8/src/mips/lithium-codegen-mips.h +0 -65
  521. data/ext/v8/upstream/v8/src/mips/lithium-mips.h +0 -304
  522. data/ext/v8/upstream/v8/src/mips/macro-assembler-mips.cc +0 -3327
  523. data/ext/v8/upstream/v8/src/mips/macro-assembler-mips.h +0 -1058
  524. data/ext/v8/upstream/v8/src/mips/regexp-macro-assembler-mips.cc +0 -478
  525. data/ext/v8/upstream/v8/src/mips/regexp-macro-assembler-mips.h +0 -250
  526. data/ext/v8/upstream/v8/src/mips/register-allocator-mips-inl.h +0 -134
  527. data/ext/v8/upstream/v8/src/mips/register-allocator-mips.cc +0 -63
  528. data/ext/v8/upstream/v8/src/mips/register-allocator-mips.h +0 -47
  529. data/ext/v8/upstream/v8/src/mips/simulator-mips.cc +0 -2438
  530. data/ext/v8/upstream/v8/src/mips/simulator-mips.h +0 -394
  531. data/ext/v8/upstream/v8/src/mips/stub-cache-mips.cc +0 -601
  532. data/ext/v8/upstream/v8/src/mips/virtual-frame-mips-inl.h +0 -58
  533. data/ext/v8/upstream/v8/src/mips/virtual-frame-mips.cc +0 -307
  534. data/ext/v8/upstream/v8/src/mips/virtual-frame-mips.h +0 -530
  535. data/ext/v8/upstream/v8/src/mirror-debugger.js +0 -2381
  536. data/ext/v8/upstream/v8/src/mksnapshot.cc +0 -256
  537. data/ext/v8/upstream/v8/src/natives.h +0 -63
  538. data/ext/v8/upstream/v8/src/objects-debug.cc +0 -722
  539. data/ext/v8/upstream/v8/src/objects-inl.h +0 -4166
  540. data/ext/v8/upstream/v8/src/objects-printer.cc +0 -801
  541. data/ext/v8/upstream/v8/src/objects-visiting.cc +0 -142
  542. data/ext/v8/upstream/v8/src/objects-visiting.h +0 -422
  543. data/ext/v8/upstream/v8/src/objects.cc +0 -10296
  544. data/ext/v8/upstream/v8/src/objects.h +0 -6662
  545. data/ext/v8/upstream/v8/src/parser.cc +0 -5168
  546. data/ext/v8/upstream/v8/src/parser.h +0 -823
  547. data/ext/v8/upstream/v8/src/platform-cygwin.cc +0 -811
  548. data/ext/v8/upstream/v8/src/platform-freebsd.cc +0 -854
  549. data/ext/v8/upstream/v8/src/platform-linux.cc +0 -1120
  550. data/ext/v8/upstream/v8/src/platform-macos.cc +0 -865
  551. data/ext/v8/upstream/v8/src/platform-nullos.cc +0 -504
  552. data/ext/v8/upstream/v8/src/platform-openbsd.cc +0 -672
  553. data/ext/v8/upstream/v8/src/platform-posix.cc +0 -424
  554. data/ext/v8/upstream/v8/src/platform-solaris.cc +0 -796
  555. data/ext/v8/upstream/v8/src/platform-tls-mac.h +0 -62
  556. data/ext/v8/upstream/v8/src/platform-tls-win32.h +0 -62
  557. data/ext/v8/upstream/v8/src/platform-tls.h +0 -50
  558. data/ext/v8/upstream/v8/src/platform-win32.cc +0 -2072
  559. data/ext/v8/upstream/v8/src/platform.h +0 -693
  560. data/ext/v8/upstream/v8/src/preparse-data.cc +0 -185
  561. data/ext/v8/upstream/v8/src/preparse-data.h +0 -249
  562. data/ext/v8/upstream/v8/src/preparser-api.cc +0 -219
  563. data/ext/v8/upstream/v8/src/preparser.cc +0 -1205
  564. data/ext/v8/upstream/v8/src/preparser.h +0 -278
  565. data/ext/v8/upstream/v8/src/prettyprinter.cc +0 -1530
  566. data/ext/v8/upstream/v8/src/prettyprinter.h +0 -223
  567. data/ext/v8/upstream/v8/src/profile-generator-inl.h +0 -128
  568. data/ext/v8/upstream/v8/src/profile-generator.cc +0 -3095
  569. data/ext/v8/upstream/v8/src/profile-generator.h +0 -1125
  570. data/ext/v8/upstream/v8/src/property.cc +0 -102
  571. data/ext/v8/upstream/v8/src/property.h +0 -348
  572. data/ext/v8/upstream/v8/src/regexp-macro-assembler-irregexp-inl.h +0 -78
  573. data/ext/v8/upstream/v8/src/regexp-macro-assembler-irregexp.cc +0 -470
  574. data/ext/v8/upstream/v8/src/regexp-macro-assembler-irregexp.h +0 -142
  575. data/ext/v8/upstream/v8/src/regexp-macro-assembler-tracer.cc +0 -373
  576. data/ext/v8/upstream/v8/src/regexp-macro-assembler-tracer.h +0 -104
  577. data/ext/v8/upstream/v8/src/regexp-macro-assembler.cc +0 -266
  578. data/ext/v8/upstream/v8/src/regexp-macro-assembler.h +0 -236
  579. data/ext/v8/upstream/v8/src/regexp-stack.cc +0 -111
  580. data/ext/v8/upstream/v8/src/regexp-stack.h +0 -147
  581. data/ext/v8/upstream/v8/src/regexp.js +0 -483
  582. data/ext/v8/upstream/v8/src/register-allocator-inl.h +0 -141
  583. data/ext/v8/upstream/v8/src/register-allocator.cc +0 -98
  584. data/ext/v8/upstream/v8/src/register-allocator.h +0 -310
  585. data/ext/v8/upstream/v8/src/rewriter.cc +0 -1024
  586. data/ext/v8/upstream/v8/src/rewriter.h +0 -59
  587. data/ext/v8/upstream/v8/src/runtime-profiler.cc +0 -478
  588. data/ext/v8/upstream/v8/src/runtime-profiler.h +0 -192
  589. data/ext/v8/upstream/v8/src/runtime.cc +0 -11949
  590. data/ext/v8/upstream/v8/src/runtime.h +0 -643
  591. data/ext/v8/upstream/v8/src/runtime.js +0 -643
  592. data/ext/v8/upstream/v8/src/safepoint-table.cc +0 -256
  593. data/ext/v8/upstream/v8/src/safepoint-table.h +0 -269
  594. data/ext/v8/upstream/v8/src/scanner-base.cc +0 -964
  595. data/ext/v8/upstream/v8/src/scanner-base.h +0 -664
  596. data/ext/v8/upstream/v8/src/scanner.cc +0 -584
  597. data/ext/v8/upstream/v8/src/scanner.h +0 -196
  598. data/ext/v8/upstream/v8/src/scopeinfo.cc +0 -631
  599. data/ext/v8/upstream/v8/src/scopeinfo.h +0 -249
  600. data/ext/v8/upstream/v8/src/scopes.cc +0 -1093
  601. data/ext/v8/upstream/v8/src/scopes.h +0 -508
  602. data/ext/v8/upstream/v8/src/serialize.cc +0 -1574
  603. data/ext/v8/upstream/v8/src/serialize.h +0 -589
  604. data/ext/v8/upstream/v8/src/shell.h +0 -55
  605. data/ext/v8/upstream/v8/src/simulator.h +0 -43
  606. data/ext/v8/upstream/v8/src/small-pointer-list.h +0 -163
  607. data/ext/v8/upstream/v8/src/smart-pointer.h +0 -109
  608. data/ext/v8/upstream/v8/src/snapshot-common.cc +0 -82
  609. data/ext/v8/upstream/v8/src/snapshot-empty.cc +0 -50
  610. data/ext/v8/upstream/v8/src/snapshot.h +0 -73
  611. data/ext/v8/upstream/v8/src/spaces-inl.h +0 -529
  612. data/ext/v8/upstream/v8/src/spaces.cc +0 -3147
  613. data/ext/v8/upstream/v8/src/spaces.h +0 -2368
  614. data/ext/v8/upstream/v8/src/splay-tree-inl.h +0 -310
  615. data/ext/v8/upstream/v8/src/splay-tree.h +0 -203
  616. data/ext/v8/upstream/v8/src/string-search.cc +0 -41
  617. data/ext/v8/upstream/v8/src/string-search.h +0 -568
  618. data/ext/v8/upstream/v8/src/string-stream.cc +0 -592
  619. data/ext/v8/upstream/v8/src/string-stream.h +0 -191
  620. data/ext/v8/upstream/v8/src/string.js +0 -915
  621. data/ext/v8/upstream/v8/src/strtod.cc +0 -440
  622. data/ext/v8/upstream/v8/src/strtod.h +0 -40
  623. data/ext/v8/upstream/v8/src/stub-cache.cc +0 -1940
  624. data/ext/v8/upstream/v8/src/stub-cache.h +0 -866
  625. data/ext/v8/upstream/v8/src/third_party/valgrind/valgrind.h +0 -3925
  626. data/ext/v8/upstream/v8/src/token.cc +0 -63
  627. data/ext/v8/upstream/v8/src/token.h +0 -288
  628. data/ext/v8/upstream/v8/src/top.cc +0 -983
  629. data/ext/v8/upstream/v8/src/type-info.cc +0 -472
  630. data/ext/v8/upstream/v8/src/type-info.h +0 -290
  631. data/ext/v8/upstream/v8/src/unbound-queue-inl.h +0 -95
  632. data/ext/v8/upstream/v8/src/unbound-queue.h +0 -67
  633. data/ext/v8/upstream/v8/src/unicode-inl.h +0 -238
  634. data/ext/v8/upstream/v8/src/unicode.cc +0 -1624
  635. data/ext/v8/upstream/v8/src/unicode.h +0 -280
  636. data/ext/v8/upstream/v8/src/uri.js +0 -402
  637. data/ext/v8/upstream/v8/src/utils.cc +0 -371
  638. data/ext/v8/upstream/v8/src/utils.h +0 -796
  639. data/ext/v8/upstream/v8/src/v8-counters.cc +0 -62
  640. data/ext/v8/upstream/v8/src/v8-counters.h +0 -311
  641. data/ext/v8/upstream/v8/src/v8.cc +0 -215
  642. data/ext/v8/upstream/v8/src/v8.h +0 -130
  643. data/ext/v8/upstream/v8/src/v8checks.h +0 -64
  644. data/ext/v8/upstream/v8/src/v8dll-main.cc +0 -39
  645. data/ext/v8/upstream/v8/src/v8globals.h +0 -486
  646. data/ext/v8/upstream/v8/src/v8memory.h +0 -82
  647. data/ext/v8/upstream/v8/src/v8natives.js +0 -1293
  648. data/ext/v8/upstream/v8/src/v8preparserdll-main.cc +0 -39
  649. data/ext/v8/upstream/v8/src/v8threads.cc +0 -453
  650. data/ext/v8/upstream/v8/src/v8threads.h +0 -164
  651. data/ext/v8/upstream/v8/src/v8utils.h +0 -317
  652. data/ext/v8/upstream/v8/src/variables.cc +0 -132
  653. data/ext/v8/upstream/v8/src/variables.h +0 -212
  654. data/ext/v8/upstream/v8/src/version.cc +0 -116
  655. data/ext/v8/upstream/v8/src/version.h +0 -68
  656. data/ext/v8/upstream/v8/src/virtual-frame-heavy-inl.h +0 -190
  657. data/ext/v8/upstream/v8/src/virtual-frame-heavy.cc +0 -312
  658. data/ext/v8/upstream/v8/src/virtual-frame-inl.h +0 -39
  659. data/ext/v8/upstream/v8/src/virtual-frame-light-inl.h +0 -171
  660. data/ext/v8/upstream/v8/src/virtual-frame-light.cc +0 -52
  661. data/ext/v8/upstream/v8/src/virtual-frame.cc +0 -49
  662. data/ext/v8/upstream/v8/src/virtual-frame.h +0 -59
  663. data/ext/v8/upstream/v8/src/vm-state-inl.h +0 -138
  664. data/ext/v8/upstream/v8/src/vm-state.h +0 -70
  665. data/ext/v8/upstream/v8/src/win32-headers.h +0 -96
  666. data/ext/v8/upstream/v8/src/x64/assembler-x64-inl.h +0 -456
  667. data/ext/v8/upstream/v8/src/x64/assembler-x64.cc +0 -2954
  668. data/ext/v8/upstream/v8/src/x64/assembler-x64.h +0 -1630
  669. data/ext/v8/upstream/v8/src/x64/builtins-x64.cc +0 -1493
  670. data/ext/v8/upstream/v8/src/x64/code-stubs-x64.cc +0 -5132
  671. data/ext/v8/upstream/v8/src/x64/code-stubs-x64.h +0 -477
  672. data/ext/v8/upstream/v8/src/x64/codegen-x64-inl.h +0 -46
  673. data/ext/v8/upstream/v8/src/x64/codegen-x64.cc +0 -8843
  674. data/ext/v8/upstream/v8/src/x64/codegen-x64.h +0 -753
  675. data/ext/v8/upstream/v8/src/x64/cpu-x64.cc +0 -88
  676. data/ext/v8/upstream/v8/src/x64/debug-x64.cc +0 -318
  677. data/ext/v8/upstream/v8/src/x64/deoptimizer-x64.cc +0 -815
  678. data/ext/v8/upstream/v8/src/x64/disasm-x64.cc +0 -1752
  679. data/ext/v8/upstream/v8/src/x64/frames-x64.cc +0 -45
  680. data/ext/v8/upstream/v8/src/x64/frames-x64.h +0 -130
  681. data/ext/v8/upstream/v8/src/x64/full-codegen-x64.cc +0 -4339
  682. data/ext/v8/upstream/v8/src/x64/ic-x64.cc +0 -1752
  683. data/ext/v8/upstream/v8/src/x64/jump-target-x64.cc +0 -437
  684. data/ext/v8/upstream/v8/src/x64/lithium-codegen-x64.cc +0 -3970
  685. data/ext/v8/upstream/v8/src/x64/lithium-codegen-x64.h +0 -318
  686. data/ext/v8/upstream/v8/src/x64/lithium-gap-resolver-x64.cc +0 -320
  687. data/ext/v8/upstream/v8/src/x64/lithium-gap-resolver-x64.h +0 -74
  688. data/ext/v8/upstream/v8/src/x64/lithium-x64.cc +0 -2115
  689. data/ext/v8/upstream/v8/src/x64/lithium-x64.h +0 -2161
  690. data/ext/v8/upstream/v8/src/x64/macro-assembler-x64.cc +0 -2911
  691. data/ext/v8/upstream/v8/src/x64/macro-assembler-x64.h +0 -1984
  692. data/ext/v8/upstream/v8/src/x64/regexp-macro-assembler-x64.cc +0 -1398
  693. data/ext/v8/upstream/v8/src/x64/regexp-macro-assembler-x64.h +0 -282
  694. data/ext/v8/upstream/v8/src/x64/register-allocator-x64-inl.h +0 -87
  695. data/ext/v8/upstream/v8/src/x64/register-allocator-x64.cc +0 -95
  696. data/ext/v8/upstream/v8/src/x64/register-allocator-x64.h +0 -43
  697. data/ext/v8/upstream/v8/src/x64/simulator-x64.cc +0 -27
  698. data/ext/v8/upstream/v8/src/x64/simulator-x64.h +0 -71
  699. data/ext/v8/upstream/v8/src/x64/stub-cache-x64.cc +0 -3460
  700. data/ext/v8/upstream/v8/src/x64/virtual-frame-x64.cc +0 -1296
  701. data/ext/v8/upstream/v8/src/x64/virtual-frame-x64.h +0 -597
  702. data/ext/v8/upstream/v8/src/zone-inl.h +0 -129
  703. data/ext/v8/upstream/v8/src/zone.cc +0 -196
  704. data/ext/v8/upstream/v8/src/zone.h +0 -236
  705. data/ext/v8/upstream/v8/tools/codemap.js +0 -265
  706. data/ext/v8/upstream/v8/tools/consarray.js +0 -93
  707. data/ext/v8/upstream/v8/tools/csvparser.js +0 -78
  708. data/ext/v8/upstream/v8/tools/disasm.py +0 -92
  709. data/ext/v8/upstream/v8/tools/freebsd-tick-processor +0 -10
  710. data/ext/v8/upstream/v8/tools/gc-nvp-trace-processor.py +0 -328
  711. data/ext/v8/upstream/v8/tools/generate-ten-powers.scm +0 -286
  712. data/ext/v8/upstream/v8/tools/grokdump.py +0 -840
  713. data/ext/v8/upstream/v8/tools/gyp/v8.gyp +0 -844
  714. data/ext/v8/upstream/v8/tools/js2c.py +0 -380
  715. data/ext/v8/upstream/v8/tools/jsmin.py +0 -280
  716. data/ext/v8/upstream/v8/tools/linux-tick-processor +0 -35
  717. data/ext/v8/upstream/v8/tools/ll_prof.py +0 -919
  718. data/ext/v8/upstream/v8/tools/logreader.js +0 -185
  719. data/ext/v8/upstream/v8/tools/mac-nm +0 -18
  720. data/ext/v8/upstream/v8/tools/mac-tick-processor +0 -6
  721. data/ext/v8/upstream/v8/tools/oom_dump/README +0 -31
  722. data/ext/v8/upstream/v8/tools/oom_dump/SConstruct +0 -42
  723. data/ext/v8/upstream/v8/tools/oom_dump/oom_dump.cc +0 -288
  724. data/ext/v8/upstream/v8/tools/presubmit.py +0 -305
  725. data/ext/v8/upstream/v8/tools/process-heap-prof.py +0 -120
  726. data/ext/v8/upstream/v8/tools/profile.js +0 -751
  727. data/ext/v8/upstream/v8/tools/profile_view.js +0 -219
  728. data/ext/v8/upstream/v8/tools/run-valgrind.py +0 -77
  729. data/ext/v8/upstream/v8/tools/splaytree.js +0 -316
  730. data/ext/v8/upstream/v8/tools/stats-viewer.py +0 -468
  731. data/ext/v8/upstream/v8/tools/test.py +0 -1490
  732. data/ext/v8/upstream/v8/tools/tickprocessor-driver.js +0 -59
  733. data/ext/v8/upstream/v8/tools/tickprocessor.js +0 -877
  734. data/ext/v8/upstream/v8/tools/utils.py +0 -96
  735. data/ext/v8/upstream/v8/tools/visual_studio/README.txt +0 -70
  736. data/ext/v8/upstream/v8/tools/visual_studio/arm.vsprops +0 -14
  737. data/ext/v8/upstream/v8/tools/visual_studio/common.vsprops +0 -34
  738. data/ext/v8/upstream/v8/tools/visual_studio/d8.vcproj +0 -193
  739. data/ext/v8/upstream/v8/tools/visual_studio/d8_arm.vcproj +0 -193
  740. data/ext/v8/upstream/v8/tools/visual_studio/d8_x64.vcproj +0 -209
  741. data/ext/v8/upstream/v8/tools/visual_studio/d8js2c.cmd +0 -6
  742. data/ext/v8/upstream/v8/tools/visual_studio/debug.vsprops +0 -17
  743. data/ext/v8/upstream/v8/tools/visual_studio/ia32.vsprops +0 -17
  744. data/ext/v8/upstream/v8/tools/visual_studio/js2c.cmd +0 -6
  745. data/ext/v8/upstream/v8/tools/visual_studio/release.vsprops +0 -24
  746. data/ext/v8/upstream/v8/tools/visual_studio/v8.sln +0 -101
  747. data/ext/v8/upstream/v8/tools/visual_studio/v8.vcproj +0 -227
  748. data/ext/v8/upstream/v8/tools/visual_studio/v8_arm.sln +0 -74
  749. data/ext/v8/upstream/v8/tools/visual_studio/v8_arm.vcproj +0 -227
  750. data/ext/v8/upstream/v8/tools/visual_studio/v8_base.vcproj +0 -1308
  751. data/ext/v8/upstream/v8/tools/visual_studio/v8_base_arm.vcproj +0 -1238
  752. data/ext/v8/upstream/v8/tools/visual_studio/v8_base_x64.vcproj +0 -1300
  753. data/ext/v8/upstream/v8/tools/visual_studio/v8_cctest.vcproj +0 -265
  754. data/ext/v8/upstream/v8/tools/visual_studio/v8_cctest_arm.vcproj +0 -249
  755. data/ext/v8/upstream/v8/tools/visual_studio/v8_cctest_x64.vcproj +0 -257
  756. data/ext/v8/upstream/v8/tools/visual_studio/v8_mksnapshot.vcproj +0 -145
  757. data/ext/v8/upstream/v8/tools/visual_studio/v8_mksnapshot_x64.vcproj +0 -145
  758. data/ext/v8/upstream/v8/tools/visual_studio/v8_process_sample.vcproj +0 -145
  759. data/ext/v8/upstream/v8/tools/visual_studio/v8_process_sample_arm.vcproj +0 -145
  760. data/ext/v8/upstream/v8/tools/visual_studio/v8_process_sample_x64.vcproj +0 -161
  761. data/ext/v8/upstream/v8/tools/visual_studio/v8_shell_sample.vcproj +0 -147
  762. data/ext/v8/upstream/v8/tools/visual_studio/v8_shell_sample_arm.vcproj +0 -147
  763. data/ext/v8/upstream/v8/tools/visual_studio/v8_shell_sample_x64.vcproj +0 -163
  764. data/ext/v8/upstream/v8/tools/visual_studio/v8_snapshot.vcproj +0 -142
  765. data/ext/v8/upstream/v8/tools/visual_studio/v8_snapshot_cc.vcproj +0 -92
  766. data/ext/v8/upstream/v8/tools/visual_studio/v8_snapshot_cc_x64.vcproj +0 -92
  767. data/ext/v8/upstream/v8/tools/visual_studio/v8_snapshot_x64.vcproj +0 -142
  768. data/ext/v8/upstream/v8/tools/visual_studio/v8_x64.sln +0 -101
  769. data/ext/v8/upstream/v8/tools/visual_studio/v8_x64.vcproj +0 -227
  770. data/ext/v8/upstream/v8/tools/visual_studio/x64.vsprops +0 -18
  771. data/ext/v8/upstream/v8/tools/windows-tick-processor.bat +0 -30
@@ -1,386 +0,0 @@
1
- #
2
- # Copyright (c) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 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
-
24
- __revision__ = "src/engine/SCons/Script/Interactive.py 4629 2010/01/17 22:23:21 scons"
25
-
26
- __doc__ = """
27
- SCons interactive mode
28
- """
29
-
30
- # TODO:
31
- #
32
- # This has the potential to grow into something with a really big life
33
- # of its own, which might or might not be a good thing. Nevertheless,
34
- # here are some enhancements that will probably be requested some day
35
- # and are worth keeping in mind (assuming this takes off):
36
- #
37
- # - A command to re-read / re-load the SConscript files. This may
38
- # involve allowing people to specify command-line options (e.g. -f,
39
- # -I, --no-site-dir) that affect how the SConscript files are read.
40
- #
41
- # - Additional command-line options on the "build" command.
42
- #
43
- # Of the supported options that seemed to make sense (after a quick
44
- # pass through the list), the ones that seemed likely enough to be
45
- # used are listed in the man page and have explicit test scripts.
46
- #
47
- # These had code changed in Script/Main.py to support them, but didn't
48
- # seem likely to be used regularly, so had no test scripts added:
49
- #
50
- # build --diskcheck=*
51
- # build --implicit-cache=*
52
- # build --implicit-deps-changed=*
53
- # build --implicit-deps-unchanged=*
54
- #
55
- # These look like they should "just work" with no changes to the
56
- # existing code, but like those above, look unlikely to be used and
57
- # therefore had no test scripts added:
58
- #
59
- # build --random
60
- #
61
- # These I'm not sure about. They might be useful for individual
62
- # "build" commands, and may even work, but they seem unlikely enough
63
- # that we'll wait until they're requested before spending any time on
64
- # writing test scripts for them, or investigating whether they work.
65
- #
66
- # build -q [??? is there a useful analog to the exit status?]
67
- # build --duplicate=
68
- # build --profile=
69
- # build --max-drift=
70
- # build --warn=*
71
- # build --Y
72
- #
73
- # - Most of the SCons command-line options that the "build" command
74
- # supports should be settable as default options that apply to all
75
- # subsequent "build" commands. Maybe a "set {option}" command that
76
- # maps to "SetOption('{option}')".
77
- #
78
- # - Need something in the 'help' command that prints the -h output.
79
- #
80
- # - A command to run the configure subsystem separately (must see how
81
- # this interacts with the new automake model).
82
- #
83
- # - Command-line completion of target names; maybe even of SCons options?
84
- # Completion is something that's supported by the Python cmd module,
85
- # so this should be doable without too much trouble.
86
- #
87
-
88
- import cmd
89
- import copy
90
- import os
91
- import re
92
- import shlex
93
- import string
94
- import sys
95
-
96
- try:
97
- import readline
98
- except ImportError:
99
- pass
100
-
101
- class SConsInteractiveCmd(cmd.Cmd):
102
- """\
103
- build [TARGETS] Build the specified TARGETS and their dependencies.
104
- 'b' is a synonym.
105
- clean [TARGETS] Clean (remove) the specified TARGETS and their
106
- dependencies. 'c' is a synonym.
107
- exit Exit SCons interactive mode.
108
- help [COMMAND] Prints help for the specified COMMAND. 'h' and
109
- '?' are synonyms.
110
- shell [COMMANDLINE] Execute COMMANDLINE in a subshell. 'sh' and '!'
111
- are synonyms.
112
- version Prints SCons version information.
113
- """
114
-
115
- synonyms = {
116
- 'b' : 'build',
117
- 'c' : 'clean',
118
- 'h' : 'help',
119
- 'scons' : 'build',
120
- 'sh' : 'shell',
121
- }
122
-
123
- def __init__(self, **kw):
124
- cmd.Cmd.__init__(self)
125
- for key, val in kw.items():
126
- setattr(self, key, val)
127
-
128
- if sys.platform == 'win32':
129
- self.shell_variable = 'COMSPEC'
130
- else:
131
- self.shell_variable = 'SHELL'
132
-
133
- def default(self, argv):
134
- print "*** Unknown command: %s" % argv[0]
135
-
136
- def onecmd(self, line):
137
- line = string.strip(line)
138
- if not line:
139
- print self.lastcmd
140
- return self.emptyline()
141
- self.lastcmd = line
142
- if line[0] == '!':
143
- line = 'shell ' + line[1:]
144
- elif line[0] == '?':
145
- line = 'help ' + line[1:]
146
- if os.sep == '\\':
147
- line = string.replace(line, '\\', '\\\\')
148
- argv = shlex.split(line)
149
- argv[0] = self.synonyms.get(argv[0], argv[0])
150
- if not argv[0]:
151
- return self.default(line)
152
- else:
153
- try:
154
- func = getattr(self, 'do_' + argv[0])
155
- except AttributeError:
156
- return self.default(argv)
157
- return func(argv)
158
-
159
- def do_build(self, argv):
160
- """\
161
- build [TARGETS] Build the specified TARGETS and their
162
- dependencies. 'b' is a synonym.
163
- """
164
- import SCons.Node
165
- import SCons.SConsign
166
- import SCons.Script.Main
167
-
168
- options = copy.deepcopy(self.options)
169
-
170
- options, targets = self.parser.parse_args(argv[1:], values=options)
171
-
172
- SCons.Script.COMMAND_LINE_TARGETS = targets
173
-
174
- if targets:
175
- SCons.Script.BUILD_TARGETS = targets
176
- else:
177
- # If the user didn't specify any targets on the command line,
178
- # use the list of default targets.
179
- SCons.Script.BUILD_TARGETS = SCons.Script._build_plus_default
180
-
181
- nodes = SCons.Script.Main._build_targets(self.fs,
182
- options,
183
- targets,
184
- self.target_top)
185
-
186
- if not nodes:
187
- return
188
-
189
- # Call each of the Node's alter_targets() methods, which may
190
- # provide additional targets that ended up as part of the build
191
- # (the canonical example being a VariantDir() when we're building
192
- # from a source directory) and which we therefore need their
193
- # state cleared, too.
194
- x = []
195
- for n in nodes:
196
- x.extend(n.alter_targets()[0])
197
- nodes.extend(x)
198
-
199
- # Clean up so that we can perform the next build correctly.
200
- #
201
- # We do this by walking over all the children of the targets,
202
- # and clearing their state.
203
- #
204
- # We currently have to re-scan each node to find their
205
- # children, because built nodes have already been partially
206
- # cleared and don't remember their children. (In scons
207
- # 0.96.1 and earlier, this wasn't the case, and we didn't
208
- # have to re-scan the nodes.)
209
- #
210
- # Because we have to re-scan each node, we can't clear the
211
- # nodes as we walk over them, because we may end up rescanning
212
- # a cleared node as we scan a later node. Therefore, only
213
- # store the list of nodes that need to be cleared as we walk
214
- # the tree, and clear them in a separate pass.
215
- #
216
- # XXX: Someone more familiar with the inner workings of scons
217
- # may be able to point out a more efficient way to do this.
218
-
219
- SCons.Script.Main.progress_display("scons: Clearing cached node information ...")
220
-
221
- seen_nodes = {}
222
-
223
- def get_unseen_children(node, parent, seen_nodes=seen_nodes):
224
- def is_unseen(node, seen_nodes=seen_nodes):
225
- return not seen_nodes.has_key(node)
226
- return filter(is_unseen, node.children(scan=1))
227
-
228
- def add_to_seen_nodes(node, parent, seen_nodes=seen_nodes):
229
- seen_nodes[node] = 1
230
-
231
- # If this file is in a VariantDir and has a
232
- # corresponding source file in the source tree, remember the
233
- # node in the source tree, too. This is needed in
234
- # particular to clear cached implicit dependencies on the
235
- # source file, since the scanner will scan it if the
236
- # VariantDir was created with duplicate=0.
237
- try:
238
- rfile_method = node.rfile
239
- except AttributeError:
240
- return
241
- else:
242
- rfile = rfile_method()
243
- if rfile != node:
244
- seen_nodes[rfile] = 1
245
-
246
- for node in nodes:
247
- walker = SCons.Node.Walker(node,
248
- kids_func=get_unseen_children,
249
- eval_func=add_to_seen_nodes)
250
- n = walker.next()
251
- while n:
252
- n = walker.next()
253
-
254
- for node in seen_nodes.keys():
255
- # Call node.clear() to clear most of the state
256
- node.clear()
257
- # node.clear() doesn't reset node.state, so call
258
- # node.set_state() to reset it manually
259
- node.set_state(SCons.Node.no_state)
260
- node.implicit = None
261
-
262
- # Debug: Uncomment to verify that all Taskmaster reference
263
- # counts have been reset to zero.
264
- #if node.ref_count != 0:
265
- # from SCons.Debug import Trace
266
- # Trace('node %s, ref_count %s !!!\n' % (node, node.ref_count))
267
-
268
- SCons.SConsign.Reset()
269
- SCons.Script.Main.progress_display("scons: done clearing node information.")
270
-
271
- def do_clean(self, argv):
272
- """\
273
- clean [TARGETS] Clean (remove) the specified TARGETS
274
- and their dependencies. 'c' is a synonym.
275
- """
276
- return self.do_build(['build', '--clean'] + argv[1:])
277
-
278
- def do_EOF(self, argv):
279
- print
280
- self.do_exit(argv)
281
-
282
- def _do_one_help(self, arg):
283
- try:
284
- # If help_<arg>() exists, then call it.
285
- func = getattr(self, 'help_' + arg)
286
- except AttributeError:
287
- try:
288
- func = getattr(self, 'do_' + arg)
289
- except AttributeError:
290
- doc = None
291
- else:
292
- doc = self._doc_to_help(func)
293
- if doc:
294
- sys.stdout.write(doc + '\n')
295
- sys.stdout.flush()
296
- else:
297
- doc = self.strip_initial_spaces(func())
298
- if doc:
299
- sys.stdout.write(doc + '\n')
300
- sys.stdout.flush()
301
-
302
- def _doc_to_help(self, obj):
303
- doc = obj.__doc__
304
- if doc is None:
305
- return ''
306
- return self._strip_initial_spaces(doc)
307
-
308
- def _strip_initial_spaces(self, s):
309
- #lines = s.split('\n')
310
- lines = string.split(s, '\n')
311
- spaces = re.match(' *', lines[0]).group(0)
312
- #def strip_spaces(l):
313
- # if l.startswith(spaces):
314
- # l = l[len(spaces):]
315
- # return l
316
- #return '\n'.join([ strip_spaces(l) for l in lines ])
317
- def strip_spaces(l, spaces=spaces):
318
- if l[:len(spaces)] == spaces:
319
- l = l[len(spaces):]
320
- return l
321
- lines = map(strip_spaces, lines)
322
- return string.join(lines, '\n')
323
-
324
- def do_exit(self, argv):
325
- """\
326
- exit Exit SCons interactive mode.
327
- """
328
- sys.exit(0)
329
-
330
- def do_help(self, argv):
331
- """\
332
- help [COMMAND] Prints help for the specified COMMAND. 'h'
333
- and '?' are synonyms.
334
- """
335
- if argv[1:]:
336
- for arg in argv[1:]:
337
- if self._do_one_help(arg):
338
- break
339
- else:
340
- # If bare 'help' is called, print this class's doc
341
- # string (if it has one).
342
- doc = self._doc_to_help(self.__class__)
343
- if doc:
344
- sys.stdout.write(doc + '\n')
345
- sys.stdout.flush()
346
-
347
- def do_shell(self, argv):
348
- """\
349
- shell [COMMANDLINE] Execute COMMANDLINE in a subshell. 'sh' and
350
- '!' are synonyms.
351
- """
352
- import subprocess
353
- argv = argv[1:]
354
- if not argv:
355
- argv = os.environ[self.shell_variable]
356
- try:
357
- # Per "[Python-Dev] subprocess insufficiently platform-independent?"
358
- # http://mail.python.org/pipermail/python-dev/2008-August/081979.html "+
359
- # Doing the right thing with an argument list currently
360
- # requires different shell= values on Windows and Linux.
361
- p = subprocess.Popen(argv, shell=(sys.platform=='win32'))
362
- except EnvironmentError, e:
363
- sys.stderr.write('scons: %s: %s\n' % (argv[0], e.strerror))
364
- else:
365
- p.wait()
366
-
367
- def do_version(self, argv):
368
- """\
369
- version Prints SCons version information.
370
- """
371
- sys.stdout.write(self.parser.version + '\n')
372
-
373
- def interact(fs, parser, options, targets, target_top):
374
- c = SConsInteractiveCmd(prompt = 'scons>>> ',
375
- fs = fs,
376
- parser = parser,
377
- options = options,
378
- targets = targets,
379
- target_top = target_top)
380
- c.cmdloop()
381
-
382
- # Local Variables:
383
- # tab-width:4
384
- # indent-tabs-mode:nil
385
- # End:
386
- # vim: set expandtab tabstop=4 shiftwidth=4:
@@ -1,1360 +0,0 @@
1
- """SCons.Script
2
-
3
- This file implements the main() function used by the scons script.
4
-
5
- Architecturally, this *is* the scons script, and will likely only be
6
- called from the external "scons" wrapper. Consequently, anything here
7
- should not be, or be considered, part of the build engine. If it's
8
- something that we expect other software to want to use, it should go in
9
- some other module. If it's specific to the "scons" script invocation,
10
- it goes here.
11
-
12
- """
13
-
14
- #
15
- # Copyright (c) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 The SCons Foundation
16
- #
17
- # Permission is hereby granted, free of charge, to any person obtaining
18
- # a copy of this software and associated documentation files (the
19
- # "Software"), to deal in the Software without restriction, including
20
- # without limitation the rights to use, copy, modify, merge, publish,
21
- # distribute, sublicense, and/or sell copies of the Software, and to
22
- # permit persons to whom the Software is furnished to do so, subject to
23
- # the following conditions:
24
- #
25
- # The above copyright notice and this permission notice shall be included
26
- # in all copies or substantial portions of the Software.
27
- #
28
- # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
29
- # KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
30
- # WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
31
- # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
32
- # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
33
- # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
34
- # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
35
- #
36
-
37
- __revision__ = "src/engine/SCons/Script/Main.py 4629 2010/01/17 22:23:21 scons"
38
-
39
- import os
40
- import os.path
41
- import string
42
- import sys
43
- import time
44
- import traceback
45
-
46
- # Strip the script directory from sys.path() so on case-insensitive
47
- # (Windows) systems Python doesn't think that the "scons" script is the
48
- # "SCons" package. Replace it with our own version directory so, if
49
- # if they're there, we pick up the right version of the build engine
50
- # modules.
51
- #sys.path = [os.path.join(sys.prefix,
52
- # 'lib',
53
- # 'scons-%d' % SCons.__version__)] + sys.path[1:]
54
-
55
- import SCons.CacheDir
56
- import SCons.Debug
57
- import SCons.Defaults
58
- import SCons.Environment
59
- import SCons.Errors
60
- import SCons.Job
61
- import SCons.Node
62
- import SCons.Node.FS
63
- import SCons.SConf
64
- import SCons.Script
65
- import SCons.Taskmaster
66
- import SCons.Util
67
- import SCons.Warnings
68
-
69
- import SCons.Script.Interactive
70
-
71
- def fetch_win32_parallel_msg():
72
- # A subsidiary function that exists solely to isolate this import
73
- # so we don't have to pull it in on all platforms, and so that an
74
- # in-line "import" statement in the _main() function below doesn't
75
- # cause warnings about local names shadowing use of the 'SCons'
76
- # globl in nest scopes and UnboundLocalErrors and the like in some
77
- # versions (2.1) of Python.
78
- import SCons.Platform.win32
79
- return SCons.Platform.win32.parallel_msg
80
-
81
- #
82
-
83
- class SConsPrintHelpException(Exception):
84
- pass
85
-
86
- display = SCons.Util.display
87
- progress_display = SCons.Util.DisplayEngine()
88
-
89
- first_command_start = None
90
- last_command_end = None
91
-
92
- class Progressor:
93
- prev = ''
94
- count = 0
95
- target_string = '$TARGET'
96
-
97
- def __init__(self, obj, interval=1, file=None, overwrite=False):
98
- if file is None:
99
- file = sys.stdout
100
-
101
- self.obj = obj
102
- self.file = file
103
- self.interval = interval
104
- self.overwrite = overwrite
105
-
106
- if callable(obj):
107
- self.func = obj
108
- elif SCons.Util.is_List(obj):
109
- self.func = self.spinner
110
- elif string.find(obj, self.target_string) != -1:
111
- self.func = self.replace_string
112
- else:
113
- self.func = self.string
114
-
115
- def write(self, s):
116
- self.file.write(s)
117
- self.file.flush()
118
- self.prev = s
119
-
120
- def erase_previous(self):
121
- if self.prev:
122
- length = len(self.prev)
123
- if self.prev[-1] in ('\n', '\r'):
124
- length = length - 1
125
- self.write(' ' * length + '\r')
126
- self.prev = ''
127
-
128
- def spinner(self, node):
129
- self.write(self.obj[self.count % len(self.obj)])
130
-
131
- def string(self, node):
132
- self.write(self.obj)
133
-
134
- def replace_string(self, node):
135
- self.write(string.replace(self.obj, self.target_string, str(node)))
136
-
137
- def __call__(self, node):
138
- self.count = self.count + 1
139
- if (self.count % self.interval) == 0:
140
- if self.overwrite:
141
- self.erase_previous()
142
- self.func(node)
143
-
144
- ProgressObject = SCons.Util.Null()
145
-
146
- def Progress(*args, **kw):
147
- global ProgressObject
148
- ProgressObject = apply(Progressor, args, kw)
149
-
150
- # Task control.
151
- #
152
-
153
- _BuildFailures = []
154
-
155
- def GetBuildFailures():
156
- return _BuildFailures
157
-
158
- class BuildTask(SCons.Taskmaster.OutOfDateTask):
159
- """An SCons build task."""
160
- progress = ProgressObject
161
-
162
- def display(self, message):
163
- display('scons: ' + message)
164
-
165
- def prepare(self):
166
- self.progress(self.targets[0])
167
- return SCons.Taskmaster.OutOfDateTask.prepare(self)
168
-
169
- def needs_execute(self):
170
- if SCons.Taskmaster.OutOfDateTask.needs_execute(self):
171
- return True
172
- if self.top and self.targets[0].has_builder():
173
- display("scons: `%s' is up to date." % str(self.node))
174
- return False
175
-
176
- def execute(self):
177
- if print_time:
178
- start_time = time.time()
179
- global first_command_start
180
- if first_command_start is None:
181
- first_command_start = start_time
182
- SCons.Taskmaster.OutOfDateTask.execute(self)
183
- if print_time:
184
- global cumulative_command_time
185
- global last_command_end
186
- finish_time = time.time()
187
- last_command_end = finish_time
188
- cumulative_command_time = cumulative_command_time+finish_time-start_time
189
- sys.stdout.write("Command execution time: %f seconds\n"%(finish_time-start_time))
190
-
191
- def do_failed(self, status=2):
192
- _BuildFailures.append(self.exception[1])
193
- global exit_status
194
- global this_build_status
195
- if self.options.ignore_errors:
196
- SCons.Taskmaster.OutOfDateTask.executed(self)
197
- elif self.options.keep_going:
198
- SCons.Taskmaster.OutOfDateTask.fail_continue(self)
199
- exit_status = status
200
- this_build_status = status
201
- else:
202
- SCons.Taskmaster.OutOfDateTask.fail_stop(self)
203
- exit_status = status
204
- this_build_status = status
205
-
206
- def executed(self):
207
- t = self.targets[0]
208
- if self.top and not t.has_builder() and not t.side_effect:
209
- if not t.exists():
210
- def classname(obj):
211
- return string.split(str(obj.__class__), '.')[-1]
212
- if classname(t) in ('File', 'Dir', 'Entry'):
213
- errstr="Do not know how to make %s target `%s' (%s)." % (classname(t), t, t.abspath)
214
- else: # Alias or Python or ...
215
- errstr="Do not know how to make %s target `%s'." % (classname(t), t)
216
- sys.stderr.write("scons: *** " + errstr)
217
- if not self.options.keep_going:
218
- sys.stderr.write(" Stop.")
219
- sys.stderr.write("\n")
220
- try:
221
- raise SCons.Errors.BuildError(t, errstr)
222
- except KeyboardInterrupt:
223
- raise
224
- except:
225
- self.exception_set()
226
- self.do_failed()
227
- else:
228
- print "scons: Nothing to be done for `%s'." % t
229
- SCons.Taskmaster.OutOfDateTask.executed(self)
230
- else:
231
- SCons.Taskmaster.OutOfDateTask.executed(self)
232
-
233
- def failed(self):
234
- # Handle the failure of a build task. The primary purpose here
235
- # is to display the various types of Errors and Exceptions
236
- # appropriately.
237
- exc_info = self.exc_info()
238
- try:
239
- t, e, tb = exc_info
240
- except ValueError:
241
- t, e = exc_info
242
- tb = None
243
-
244
- if t is None:
245
- # The Taskmaster didn't record an exception for this Task;
246
- # see if the sys module has one.
247
- try:
248
- t, e, tb = sys.exc_info()[:]
249
- except ValueError:
250
- t, e = exc_info
251
- tb = None
252
-
253
- # Deprecated string exceptions will have their string stored
254
- # in the first entry of the tuple.
255
- if e is None:
256
- e = t
257
-
258
- buildError = SCons.Errors.convert_to_BuildError(e)
259
- if not buildError.node:
260
- buildError.node = self.node
261
-
262
- node = buildError.node
263
- if not SCons.Util.is_List(node):
264
- node = [ node ]
265
- nodename = string.join(map(str, node), ', ')
266
-
267
- errfmt = "scons: *** [%s] %s\n"
268
- sys.stderr.write(errfmt % (nodename, buildError))
269
-
270
- if (buildError.exc_info[2] and buildError.exc_info[1] and
271
- # TODO(1.5)
272
- #not isinstance(
273
- # buildError.exc_info[1],
274
- # (EnvironmentError, SCons.Errors.StopError, SCons.Errors.UserError))):
275
- not isinstance(buildError.exc_info[1], EnvironmentError) and
276
- not isinstance(buildError.exc_info[1], SCons.Errors.StopError) and
277
- not isinstance(buildError.exc_info[1], SCons.Errors.UserError)):
278
- type, value, trace = buildError.exc_info
279
- traceback.print_exception(type, value, trace)
280
- elif tb and print_stacktrace:
281
- sys.stderr.write("scons: internal stack trace:\n")
282
- traceback.print_tb(tb, file=sys.stderr)
283
-
284
- self.exception = (e, buildError, tb) # type, value, traceback
285
- self.do_failed(buildError.exitstatus)
286
-
287
- self.exc_clear()
288
-
289
- def postprocess(self):
290
- if self.top:
291
- t = self.targets[0]
292
- for tp in self.options.tree_printers:
293
- tp.display(t)
294
- if self.options.debug_includes:
295
- tree = t.render_include_tree()
296
- if tree:
297
- print
298
- print tree
299
- SCons.Taskmaster.OutOfDateTask.postprocess(self)
300
-
301
- def make_ready(self):
302
- """Make a task ready for execution"""
303
- SCons.Taskmaster.OutOfDateTask.make_ready(self)
304
- if self.out_of_date and self.options.debug_explain:
305
- explanation = self.out_of_date[0].explain()
306
- if explanation:
307
- sys.stdout.write("scons: " + explanation)
308
-
309
- class CleanTask(SCons.Taskmaster.AlwaysTask):
310
- """An SCons clean task."""
311
- def fs_delete(self, path, pathstr, remove=1):
312
- try:
313
- if os.path.lexists(path):
314
- if os.path.isfile(path) or os.path.islink(path):
315
- if remove: os.unlink(path)
316
- display("Removed " + pathstr)
317
- elif os.path.isdir(path) and not os.path.islink(path):
318
- # delete everything in the dir
319
- entries = os.listdir(path)
320
- # Sort for deterministic output (os.listdir() Can
321
- # return entries in a random order).
322
- entries.sort()
323
- for e in entries:
324
- p = os.path.join(path, e)
325
- s = os.path.join(pathstr, e)
326
- if os.path.isfile(p):
327
- if remove: os.unlink(p)
328
- display("Removed " + s)
329
- else:
330
- self.fs_delete(p, s, remove)
331
- # then delete dir itself
332
- if remove: os.rmdir(path)
333
- display("Removed directory " + pathstr)
334
- else:
335
- errstr = "Path '%s' exists but isn't a file or directory."
336
- raise SCons.Errors.UserError(errstr % (pathstr))
337
- except SCons.Errors.UserError, e:
338
- print e
339
- except (IOError, OSError), e:
340
- print "scons: Could not remove '%s':" % pathstr, e.strerror
341
-
342
- def show(self):
343
- target = self.targets[0]
344
- if (target.has_builder() or target.side_effect) and not target.noclean:
345
- for t in self.targets:
346
- if not t.isdir():
347
- display("Removed " + str(t))
348
- if SCons.Environment.CleanTargets.has_key(target):
349
- files = SCons.Environment.CleanTargets[target]
350
- for f in files:
351
- self.fs_delete(f.abspath, str(f), 0)
352
-
353
- def remove(self):
354
- target = self.targets[0]
355
- if (target.has_builder() or target.side_effect) and not target.noclean:
356
- for t in self.targets:
357
- try:
358
- removed = t.remove()
359
- except OSError, e:
360
- # An OSError may indicate something like a permissions
361
- # issue, an IOError would indicate something like
362
- # the file not existing. In either case, print a
363
- # message and keep going to try to remove as many
364
- # targets aa possible.
365
- print "scons: Could not remove '%s':" % str(t), e.strerror
366
- else:
367
- if removed:
368
- display("Removed " + str(t))
369
- if SCons.Environment.CleanTargets.has_key(target):
370
- files = SCons.Environment.CleanTargets[target]
371
- for f in files:
372
- self.fs_delete(f.abspath, str(f))
373
-
374
- execute = remove
375
-
376
- # We want the Taskmaster to update the Node states (and therefore
377
- # handle reference counts, etc.), but we don't want to call
378
- # back to the Node's post-build methods, which would do things
379
- # we don't want, like store .sconsign information.
380
- executed = SCons.Taskmaster.Task.executed_without_callbacks
381
-
382
- # Have the taskmaster arrange to "execute" all of the targets, because
383
- # we'll figure out ourselves (in remove() or show() above) whether
384
- # anything really needs to be done.
385
- make_ready = SCons.Taskmaster.Task.make_ready_all
386
-
387
- def prepare(self):
388
- pass
389
-
390
- class QuestionTask(SCons.Taskmaster.AlwaysTask):
391
- """An SCons task for the -q (question) option."""
392
- def prepare(self):
393
- pass
394
-
395
- def execute(self):
396
- if self.targets[0].get_state() != SCons.Node.up_to_date or \
397
- (self.top and not self.targets[0].exists()):
398
- global exit_status
399
- global this_build_status
400
- exit_status = 1
401
- this_build_status = 1
402
- self.tm.stop()
403
-
404
- def executed(self):
405
- pass
406
-
407
-
408
- class TreePrinter:
409
- def __init__(self, derived=False, prune=False, status=False):
410
- self.derived = derived
411
- self.prune = prune
412
- self.status = status
413
- def get_all_children(self, node):
414
- return node.all_children()
415
- def get_derived_children(self, node):
416
- children = node.all_children(None)
417
- return filter(lambda x: x.has_builder(), children)
418
- def display(self, t):
419
- if self.derived:
420
- func = self.get_derived_children
421
- else:
422
- func = self.get_all_children
423
- s = self.status and 2 or 0
424
- SCons.Util.print_tree(t, func, prune=self.prune, showtags=s)
425
-
426
-
427
- def python_version_string():
428
- return string.split(sys.version)[0]
429
-
430
- def python_version_unsupported(version=sys.version_info):
431
- return version < (1, 5, 2)
432
-
433
- def python_version_deprecated(version=sys.version_info):
434
- return version < (2, 4, 0)
435
-
436
-
437
- # Global variables
438
-
439
- print_objects = 0
440
- print_memoizer = 0
441
- print_stacktrace = 0
442
- print_time = 0
443
- sconscript_time = 0
444
- cumulative_command_time = 0
445
- exit_status = 0 # final exit status, assume success by default
446
- this_build_status = 0 # "exit status" of an individual build
447
- num_jobs = None
448
- delayed_warnings = []
449
-
450
- class FakeOptionParser:
451
- """
452
- A do-nothing option parser, used for the initial OptionsParser variable.
453
-
454
- During normal SCons operation, the OptionsParser is created right
455
- away by the main() function. Certain tests scripts however, can
456
- introspect on different Tool modules, the initialization of which
457
- can try to add a new, local option to an otherwise uninitialized
458
- OptionsParser object. This allows that introspection to happen
459
- without blowing up.
460
-
461
- """
462
- class FakeOptionValues:
463
- def __getattr__(self, attr):
464
- return None
465
- values = FakeOptionValues()
466
- def add_local_option(self, *args, **kw):
467
- pass
468
-
469
- OptionsParser = FakeOptionParser()
470
-
471
- def AddOption(*args, **kw):
472
- if not kw.has_key('default'):
473
- kw['default'] = None
474
- result = apply(OptionsParser.add_local_option, args, kw)
475
- return result
476
-
477
- def GetOption(name):
478
- return getattr(OptionsParser.values, name)
479
-
480
- def SetOption(name, value):
481
- return OptionsParser.values.set_option(name, value)
482
-
483
- #
484
- class Stats:
485
- def __init__(self):
486
- self.stats = []
487
- self.labels = []
488
- self.append = self.do_nothing
489
- self.print_stats = self.do_nothing
490
- def enable(self, outfp):
491
- self.outfp = outfp
492
- self.append = self.do_append
493
- self.print_stats = self.do_print
494
- def do_nothing(self, *args, **kw):
495
- pass
496
-
497
- class CountStats(Stats):
498
- def do_append(self, label):
499
- self.labels.append(label)
500
- self.stats.append(SCons.Debug.fetchLoggedInstances())
501
- def do_print(self):
502
- stats_table = {}
503
- for s in self.stats:
504
- for n in map(lambda t: t[0], s):
505
- stats_table[n] = [0, 0, 0, 0]
506
- i = 0
507
- for s in self.stats:
508
- for n, c in s:
509
- stats_table[n][i] = c
510
- i = i + 1
511
- keys = stats_table.keys()
512
- keys.sort()
513
- self.outfp.write("Object counts:\n")
514
- pre = [" "]
515
- post = [" %s\n"]
516
- l = len(self.stats)
517
- fmt1 = string.join(pre + [' %7s']*l + post, '')
518
- fmt2 = string.join(pre + [' %7d']*l + post, '')
519
- labels = self.labels[:l]
520
- labels.append(("", "Class"))
521
- self.outfp.write(fmt1 % tuple(map(lambda x: x[0], labels)))
522
- self.outfp.write(fmt1 % tuple(map(lambda x: x[1], labels)))
523
- for k in keys:
524
- r = stats_table[k][:l] + [k]
525
- self.outfp.write(fmt2 % tuple(r))
526
-
527
- count_stats = CountStats()
528
-
529
- class MemStats(Stats):
530
- def do_append(self, label):
531
- self.labels.append(label)
532
- self.stats.append(SCons.Debug.memory())
533
- def do_print(self):
534
- fmt = 'Memory %-32s %12d\n'
535
- for label, stats in map(None, self.labels, self.stats):
536
- self.outfp.write(fmt % (label, stats))
537
-
538
- memory_stats = MemStats()
539
-
540
- # utility functions
541
-
542
- def _scons_syntax_error(e):
543
- """Handle syntax errors. Print out a message and show where the error
544
- occurred.
545
- """
546
- etype, value, tb = sys.exc_info()
547
- lines = traceback.format_exception_only(etype, value)
548
- for line in lines:
549
- sys.stderr.write(line+'\n')
550
- sys.exit(2)
551
-
552
- def find_deepest_user_frame(tb):
553
- """
554
- Find the deepest stack frame that is not part of SCons.
555
-
556
- Input is a "pre-processed" stack trace in the form
557
- returned by traceback.extract_tb() or traceback.extract_stack()
558
- """
559
-
560
- tb.reverse()
561
-
562
- # find the deepest traceback frame that is not part
563
- # of SCons:
564
- for frame in tb:
565
- filename = frame[0]
566
- if string.find(filename, os.sep+'SCons'+os.sep) == -1:
567
- return frame
568
- return tb[0]
569
-
570
- def _scons_user_error(e):
571
- """Handle user errors. Print out a message and a description of the
572
- error, along with the line number and routine where it occured.
573
- The file and line number will be the deepest stack frame that is
574
- not part of SCons itself.
575
- """
576
- global print_stacktrace
577
- etype, value, tb = sys.exc_info()
578
- if print_stacktrace:
579
- traceback.print_exception(etype, value, tb)
580
- filename, lineno, routine, dummy = find_deepest_user_frame(traceback.extract_tb(tb))
581
- sys.stderr.write("\nscons: *** %s\n" % value)
582
- sys.stderr.write('File "%s", line %d, in %s\n' % (filename, lineno, routine))
583
- sys.exit(2)
584
-
585
- def _scons_user_warning(e):
586
- """Handle user warnings. Print out a message and a description of
587
- the warning, along with the line number and routine where it occured.
588
- The file and line number will be the deepest stack frame that is
589
- not part of SCons itself.
590
- """
591
- etype, value, tb = sys.exc_info()
592
- filename, lineno, routine, dummy = find_deepest_user_frame(traceback.extract_tb(tb))
593
- sys.stderr.write("\nscons: warning: %s\n" % e)
594
- sys.stderr.write('File "%s", line %d, in %s\n' % (filename, lineno, routine))
595
-
596
- def _scons_internal_warning(e):
597
- """Slightly different from _scons_user_warning in that we use the
598
- *current call stack* rather than sys.exc_info() to get our stack trace.
599
- This is used by the warnings framework to print warnings."""
600
- filename, lineno, routine, dummy = find_deepest_user_frame(traceback.extract_stack())
601
- sys.stderr.write("\nscons: warning: %s\n" % e[0])
602
- sys.stderr.write('File "%s", line %d, in %s\n' % (filename, lineno, routine))
603
-
604
- def _scons_internal_error():
605
- """Handle all errors but user errors. Print out a message telling
606
- the user what to do in this case and print a normal trace.
607
- """
608
- print 'internal error'
609
- traceback.print_exc()
610
- sys.exit(2)
611
-
612
- def _SConstruct_exists(dirname='', repositories=[], filelist=None):
613
- """This function checks that an SConstruct file exists in a directory.
614
- If so, it returns the path of the file. By default, it checks the
615
- current directory.
616
- """
617
- if not filelist:
618
- filelist = ['SConstruct', 'Sconstruct', 'sconstruct']
619
- for file in filelist:
620
- sfile = os.path.join(dirname, file)
621
- if os.path.isfile(sfile):
622
- return sfile
623
- if not os.path.isabs(sfile):
624
- for rep in repositories:
625
- if os.path.isfile(os.path.join(rep, sfile)):
626
- return sfile
627
- return None
628
-
629
- def _set_debug_values(options):
630
- global print_memoizer, print_objects, print_stacktrace, print_time
631
-
632
- debug_values = options.debug
633
-
634
- if "count" in debug_values:
635
- # All of the object counts are within "if __debug__:" blocks,
636
- # which get stripped when running optimized (with python -O or
637
- # from compiled *.pyo files). Provide a warning if __debug__ is
638
- # stripped, so it doesn't just look like --debug=count is broken.
639
- enable_count = False
640
- if __debug__: enable_count = True
641
- if enable_count:
642
- count_stats.enable(sys.stdout)
643
- else:
644
- msg = "--debug=count is not supported when running SCons\n" + \
645
- "\twith the python -O option or optimized (.pyo) modules."
646
- SCons.Warnings.warn(SCons.Warnings.NoObjectCountWarning, msg)
647
- if "dtree" in debug_values:
648
- options.tree_printers.append(TreePrinter(derived=True))
649
- options.debug_explain = ("explain" in debug_values)
650
- if "findlibs" in debug_values:
651
- SCons.Scanner.Prog.print_find_libs = "findlibs"
652
- options.debug_includes = ("includes" in debug_values)
653
- print_memoizer = ("memoizer" in debug_values)
654
- if "memory" in debug_values:
655
- memory_stats.enable(sys.stdout)
656
- print_objects = ("objects" in debug_values)
657
- if "presub" in debug_values:
658
- SCons.Action.print_actions_presub = 1
659
- if "stacktrace" in debug_values:
660
- print_stacktrace = 1
661
- if "stree" in debug_values:
662
- options.tree_printers.append(TreePrinter(status=True))
663
- if "time" in debug_values:
664
- print_time = 1
665
- if "tree" in debug_values:
666
- options.tree_printers.append(TreePrinter())
667
-
668
- def _create_path(plist):
669
- path = '.'
670
- for d in plist:
671
- if os.path.isabs(d):
672
- path = d
673
- else:
674
- path = path + '/' + d
675
- return path
676
-
677
- def _load_site_scons_dir(topdir, site_dir_name=None):
678
- """Load the site_scons dir under topdir.
679
- Adds site_scons to sys.path, imports site_scons/site_init.py,
680
- and adds site_scons/site_tools to default toolpath."""
681
- if site_dir_name:
682
- err_if_not_found = True # user specified: err if missing
683
- else:
684
- site_dir_name = "site_scons"
685
- err_if_not_found = False
686
-
687
- site_dir = os.path.join(topdir.path, site_dir_name)
688
- if not os.path.exists(site_dir):
689
- if err_if_not_found:
690
- raise SCons.Errors.UserError, "site dir %s not found."%site_dir
691
- return
692
-
693
- site_init_filename = "site_init.py"
694
- site_init_modname = "site_init"
695
- site_tools_dirname = "site_tools"
696
- sys.path = [os.path.abspath(site_dir)] + sys.path
697
- site_init_file = os.path.join(site_dir, site_init_filename)
698
- site_tools_dir = os.path.join(site_dir, site_tools_dirname)
699
- if os.path.exists(site_init_file):
700
- import imp
701
- # TODO(2.4): turn this into try:-except:-finally:
702
- try:
703
- try:
704
- fp, pathname, description = imp.find_module(site_init_modname,
705
- [site_dir])
706
- # Load the file into SCons.Script namespace. This is
707
- # opaque and clever; m is the module object for the
708
- # SCons.Script module, and the exec ... in call executes a
709
- # file (or string containing code) in the context of the
710
- # module's dictionary, so anything that code defines ends
711
- # up adding to that module. This is really short, but all
712
- # the error checking makes it longer.
713
- try:
714
- m = sys.modules['SCons.Script']
715
- except Exception, e:
716
- fmt = 'cannot import site_init.py: missing SCons.Script module %s'
717
- raise SCons.Errors.InternalError, fmt % repr(e)
718
- try:
719
- # This is the magic.
720
- exec fp in m.__dict__
721
- except KeyboardInterrupt:
722
- raise
723
- except Exception, e:
724
- fmt = '*** Error loading site_init file %s:\n'
725
- sys.stderr.write(fmt % repr(site_init_file))
726
- raise
727
- except KeyboardInterrupt:
728
- raise
729
- except ImportError, e:
730
- fmt = '*** cannot import site init file %s:\n'
731
- sys.stderr.write(fmt % repr(site_init_file))
732
- raise
733
- finally:
734
- if fp:
735
- fp.close()
736
- if os.path.exists(site_tools_dir):
737
- SCons.Tool.DefaultToolpath.append(os.path.abspath(site_tools_dir))
738
-
739
- def version_string(label, module):
740
- version = module.__version__
741
- build = module.__build__
742
- if build:
743
- if build[0] != '.':
744
- build = '.' + build
745
- version = version + build
746
- fmt = "\t%s: v%s, %s, by %s on %s\n"
747
- return fmt % (label,
748
- version,
749
- module.__date__,
750
- module.__developer__,
751
- module.__buildsys__)
752
-
753
- def _main(parser):
754
- global exit_status
755
- global this_build_status
756
-
757
- options = parser.values
758
-
759
- # Here's where everything really happens.
760
-
761
- # First order of business: set up default warnings and then
762
- # handle the user's warning options, so that we can issue (or
763
- # suppress) appropriate warnings about anything that might happen,
764
- # as configured by the user.
765
-
766
- default_warnings = [ SCons.Warnings.CorruptSConsignWarning,
767
- SCons.Warnings.DeprecatedWarning,
768
- SCons.Warnings.DuplicateEnvironmentWarning,
769
- SCons.Warnings.FutureReservedVariableWarning,
770
- SCons.Warnings.LinkWarning,
771
- SCons.Warnings.MissingSConscriptWarning,
772
- SCons.Warnings.NoMD5ModuleWarning,
773
- SCons.Warnings.NoMetaclassSupportWarning,
774
- SCons.Warnings.NoObjectCountWarning,
775
- SCons.Warnings.NoParallelSupportWarning,
776
- SCons.Warnings.MisleadingKeywordsWarning,
777
- SCons.Warnings.ReservedVariableWarning,
778
- SCons.Warnings.StackSizeWarning,
779
- SCons.Warnings.VisualVersionMismatch,
780
- SCons.Warnings.VisualCMissingWarning,
781
- ]
782
-
783
- for warning in default_warnings:
784
- SCons.Warnings.enableWarningClass(warning)
785
- SCons.Warnings._warningOut = _scons_internal_warning
786
- SCons.Warnings.process_warn_strings(options.warn)
787
-
788
- # Now that we have the warnings configuration set up, we can actually
789
- # issue (or suppress) any warnings about warning-worthy things that
790
- # occurred while the command-line options were getting parsed.
791
- try:
792
- dw = options.delayed_warnings
793
- except AttributeError:
794
- pass
795
- else:
796
- delayed_warnings.extend(dw)
797
- for warning_type, message in delayed_warnings:
798
- SCons.Warnings.warn(warning_type, message)
799
-
800
- if options.diskcheck:
801
- SCons.Node.FS.set_diskcheck(options.diskcheck)
802
-
803
- # Next, we want to create the FS object that represents the outside
804
- # world's file system, as that's central to a lot of initialization.
805
- # To do this, however, we need to be in the directory from which we
806
- # want to start everything, which means first handling any relevant
807
- # options that might cause us to chdir somewhere (-C, -D, -U, -u).
808
- if options.directory:
809
- script_dir = os.path.abspath(_create_path(options.directory))
810
- else:
811
- script_dir = os.getcwd()
812
-
813
- target_top = None
814
- if options.climb_up:
815
- target_top = '.' # directory to prepend to targets
816
- while script_dir and not _SConstruct_exists(script_dir,
817
- options.repository,
818
- options.file):
819
- script_dir, last_part = os.path.split(script_dir)
820
- if last_part:
821
- target_top = os.path.join(last_part, target_top)
822
- else:
823
- script_dir = ''
824
-
825
- if script_dir and script_dir != os.getcwd():
826
- display("scons: Entering directory `%s'" % script_dir)
827
- try:
828
- os.chdir(script_dir)
829
- except OSError:
830
- sys.stderr.write("Could not change directory to %s\n" % script_dir)
831
-
832
- # Now that we're in the top-level SConstruct directory, go ahead
833
- # and initialize the FS object that represents the file system,
834
- # and make it the build engine default.
835
- fs = SCons.Node.FS.get_default_fs()
836
-
837
- for rep in options.repository:
838
- fs.Repository(rep)
839
-
840
- # Now that we have the FS object, the next order of business is to
841
- # check for an SConstruct file (or other specified config file).
842
- # If there isn't one, we can bail before doing any more work.
843
- scripts = []
844
- if options.file:
845
- scripts.extend(options.file)
846
- if not scripts:
847
- sfile = _SConstruct_exists(repositories=options.repository,
848
- filelist=options.file)
849
- if sfile:
850
- scripts.append(sfile)
851
-
852
- if not scripts:
853
- if options.help:
854
- # There's no SConstruct, but they specified -h.
855
- # Give them the options usage now, before we fail
856
- # trying to read a non-existent SConstruct file.
857
- raise SConsPrintHelpException
858
- raise SCons.Errors.UserError, "No SConstruct file found."
859
-
860
- if scripts[0] == "-":
861
- d = fs.getcwd()
862
- else:
863
- d = fs.File(scripts[0]).dir
864
- fs.set_SConstruct_dir(d)
865
-
866
- _set_debug_values(options)
867
- SCons.Node.implicit_cache = options.implicit_cache
868
- SCons.Node.implicit_deps_changed = options.implicit_deps_changed
869
- SCons.Node.implicit_deps_unchanged = options.implicit_deps_unchanged
870
-
871
- if options.no_exec:
872
- SCons.SConf.dryrun = 1
873
- SCons.Action.execute_actions = None
874
- if options.question:
875
- SCons.SConf.dryrun = 1
876
- if options.clean:
877
- SCons.SConf.SetBuildType('clean')
878
- if options.help:
879
- SCons.SConf.SetBuildType('help')
880
- SCons.SConf.SetCacheMode(options.config)
881
- SCons.SConf.SetProgressDisplay(progress_display)
882
-
883
- if options.no_progress or options.silent:
884
- progress_display.set_mode(0)
885
-
886
- if options.site_dir:
887
- _load_site_scons_dir(d, options.site_dir)
888
- elif not options.no_site_dir:
889
- _load_site_scons_dir(d)
890
-
891
- if options.include_dir:
892
- sys.path = options.include_dir + sys.path
893
-
894
- # That should cover (most of) the options. Next, set up the variables
895
- # that hold command-line arguments, so the SConscript files that we
896
- # read and execute have access to them.
897
- targets = []
898
- xmit_args = []
899
- for a in parser.largs:
900
- if a[:1] == '-':
901
- continue
902
- if '=' in a:
903
- xmit_args.append(a)
904
- else:
905
- targets.append(a)
906
- SCons.Script._Add_Targets(targets + parser.rargs)
907
- SCons.Script._Add_Arguments(xmit_args)
908
-
909
- # If stdout is not a tty, replace it with a wrapper object to call flush
910
- # after every write.
911
- #
912
- # Tty devices automatically flush after every newline, so the replacement
913
- # isn't necessary. Furthermore, if we replace sys.stdout, the readline
914
- # module will no longer work. This affects the behavior during
915
- # --interactive mode. --interactive should only be used when stdin and
916
- # stdout refer to a tty.
917
- if not hasattr(sys.stdout, 'isatty') or not sys.stdout.isatty():
918
- sys.stdout = SCons.Util.Unbuffered(sys.stdout)
919
- if not hasattr(sys.stderr, 'isatty') or not sys.stderr.isatty():
920
- sys.stderr = SCons.Util.Unbuffered(sys.stderr)
921
-
922
- memory_stats.append('before reading SConscript files:')
923
- count_stats.append(('pre-', 'read'))
924
-
925
- # And here's where we (finally) read the SConscript files.
926
-
927
- progress_display("scons: Reading SConscript files ...")
928
-
929
- start_time = time.time()
930
- try:
931
- for script in scripts:
932
- SCons.Script._SConscript._SConscript(fs, script)
933
- except SCons.Errors.StopError, e:
934
- # We had problems reading an SConscript file, such as it
935
- # couldn't be copied in to the VariantDir. Since we're just
936
- # reading SConscript files and haven't started building
937
- # things yet, stop regardless of whether they used -i or -k
938
- # or anything else.
939
- sys.stderr.write("scons: *** %s Stop.\n" % e)
940
- exit_status = 2
941
- sys.exit(exit_status)
942
- global sconscript_time
943
- sconscript_time = time.time() - start_time
944
-
945
- progress_display("scons: done reading SConscript files.")
946
-
947
- memory_stats.append('after reading SConscript files:')
948
- count_stats.append(('post-', 'read'))
949
-
950
- # Re-{enable,disable} warnings in case they disabled some in
951
- # the SConscript file.
952
- #
953
- # We delay enabling the PythonVersionWarning class until here so that,
954
- # if they explicity disabled it in either in the command line or in
955
- # $SCONSFLAGS, or in the SConscript file, then the search through
956
- # the list of deprecated warning classes will find that disabling
957
- # first and not issue the warning.
958
- SCons.Warnings.enableWarningClass(SCons.Warnings.PythonVersionWarning)
959
- SCons.Warnings.process_warn_strings(options.warn)
960
-
961
- # Now that we've read the SConscript files, we can check for the
962
- # warning about deprecated Python versions--delayed until here
963
- # in case they disabled the warning in the SConscript files.
964
- if python_version_deprecated():
965
- msg = "Support for pre-2.4 Python (%s) is deprecated.\n" + \
966
- " If this will cause hardship, contact dev@scons.tigris.org."
967
- SCons.Warnings.warn(SCons.Warnings.PythonVersionWarning,
968
- msg % python_version_string())
969
-
970
- if not options.help:
971
- SCons.SConf.CreateConfigHBuilder(SCons.Defaults.DefaultEnvironment())
972
-
973
- # Now re-parse the command-line options (any to the left of a '--'
974
- # argument, that is) with any user-defined command-line options that
975
- # the SConscript files may have added to the parser object. This will
976
- # emit the appropriate error message and exit if any unknown option
977
- # was specified on the command line.
978
-
979
- parser.preserve_unknown_options = False
980
- parser.parse_args(parser.largs, options)
981
-
982
- if options.help:
983
- help_text = SCons.Script.help_text
984
- if help_text is None:
985
- # They specified -h, but there was no Help() inside the
986
- # SConscript files. Give them the options usage.
987
- raise SConsPrintHelpException
988
- else:
989
- print help_text
990
- print "Use scons -H for help about command-line options."
991
- exit_status = 0
992
- return
993
-
994
- # Change directory to the top-level SConstruct directory, then tell
995
- # the Node.FS subsystem that we're all done reading the SConscript
996
- # files and calling Repository() and VariantDir() and changing
997
- # directories and the like, so it can go ahead and start memoizing
998
- # the string values of file system nodes.
999
-
1000
- fs.chdir(fs.Top)
1001
-
1002
- SCons.Node.FS.save_strings(1)
1003
-
1004
- # Now that we've read the SConscripts we can set the options
1005
- # that are SConscript settable:
1006
- SCons.Node.implicit_cache = options.implicit_cache
1007
- SCons.Node.FS.set_duplicate(options.duplicate)
1008
- fs.set_max_drift(options.max_drift)
1009
-
1010
- SCons.Job.explicit_stack_size = options.stack_size
1011
-
1012
- if options.md5_chunksize:
1013
- SCons.Node.FS.File.md5_chunksize = options.md5_chunksize
1014
-
1015
- platform = SCons.Platform.platform_module()
1016
-
1017
- if options.interactive:
1018
- SCons.Script.Interactive.interact(fs, OptionsParser, options,
1019
- targets, target_top)
1020
-
1021
- else:
1022
-
1023
- # Build the targets
1024
- nodes = _build_targets(fs, options, targets, target_top)
1025
- if not nodes:
1026
- exit_status = 2
1027
-
1028
- def _build_targets(fs, options, targets, target_top):
1029
-
1030
- global this_build_status
1031
- this_build_status = 0
1032
-
1033
- progress_display.set_mode(not (options.no_progress or options.silent))
1034
- display.set_mode(not options.silent)
1035
- SCons.Action.print_actions = not options.silent
1036
- SCons.Action.execute_actions = not options.no_exec
1037
- SCons.Node.FS.do_store_info = not options.no_exec
1038
- SCons.SConf.dryrun = options.no_exec
1039
-
1040
- if options.diskcheck:
1041
- SCons.Node.FS.set_diskcheck(options.diskcheck)
1042
-
1043
- SCons.CacheDir.cache_enabled = not options.cache_disable
1044
- SCons.CacheDir.cache_debug = options.cache_debug
1045
- SCons.CacheDir.cache_force = options.cache_force
1046
- SCons.CacheDir.cache_show = options.cache_show
1047
-
1048
- if options.no_exec:
1049
- CleanTask.execute = CleanTask.show
1050
- else:
1051
- CleanTask.execute = CleanTask.remove
1052
-
1053
- lookup_top = None
1054
- if targets or SCons.Script.BUILD_TARGETS != SCons.Script._build_plus_default:
1055
- # They specified targets on the command line or modified
1056
- # BUILD_TARGETS in the SConscript file(s), so if they used -u,
1057
- # -U or -D, we have to look up targets relative to the top,
1058
- # but we build whatever they specified.
1059
- if target_top:
1060
- lookup_top = fs.Dir(target_top)
1061
- target_top = None
1062
-
1063
- targets = SCons.Script.BUILD_TARGETS
1064
- else:
1065
- # There are no targets specified on the command line,
1066
- # so if they used -u, -U or -D, we may have to restrict
1067
- # what actually gets built.
1068
- d = None
1069
- if target_top:
1070
- if options.climb_up == 1:
1071
- # -u, local directory and below
1072
- target_top = fs.Dir(target_top)
1073
- lookup_top = target_top
1074
- elif options.climb_up == 2:
1075
- # -D, all Default() targets
1076
- target_top = None
1077
- lookup_top = None
1078
- elif options.climb_up == 3:
1079
- # -U, local SConscript Default() targets
1080
- target_top = fs.Dir(target_top)
1081
- def check_dir(x, target_top=target_top):
1082
- if hasattr(x, 'cwd') and not x.cwd is None:
1083
- cwd = x.cwd.srcnode()
1084
- return cwd == target_top
1085
- else:
1086
- # x doesn't have a cwd, so it's either not a target,
1087
- # or not a file, so go ahead and keep it as a default
1088
- # target and let the engine sort it out:
1089
- return 1
1090
- d = filter(check_dir, SCons.Script.DEFAULT_TARGETS)
1091
- SCons.Script.DEFAULT_TARGETS[:] = d
1092
- target_top = None
1093
- lookup_top = None
1094
-
1095
- targets = SCons.Script._Get_Default_Targets(d, fs)
1096
-
1097
- if not targets:
1098
- sys.stderr.write("scons: *** No targets specified and no Default() targets found. Stop.\n")
1099
- return None
1100
-
1101
- def Entry(x, ltop=lookup_top, ttop=target_top, fs=fs):
1102
- if isinstance(x, SCons.Node.Node):
1103
- node = x
1104
- else:
1105
- node = None
1106
- # Why would ltop be None? Unfortunately this happens.
1107
- if ltop is None: ltop = ''
1108
- # Curdir becomes important when SCons is called with -u, -C,
1109
- # or similar option that changes directory, and so the paths
1110
- # of targets given on the command line need to be adjusted.
1111
- curdir = os.path.join(os.getcwd(), str(ltop))
1112
- for lookup in SCons.Node.arg2nodes_lookups:
1113
- node = lookup(x, curdir=curdir)
1114
- if node is not None:
1115
- break
1116
- if node is None:
1117
- node = fs.Entry(x, directory=ltop, create=1)
1118
- if ttop and not node.is_under(ttop):
1119
- if isinstance(node, SCons.Node.FS.Dir) and ttop.is_under(node):
1120
- node = ttop
1121
- else:
1122
- node = None
1123
- return node
1124
-
1125
- nodes = filter(None, map(Entry, targets))
1126
-
1127
- task_class = BuildTask # default action is to build targets
1128
- opening_message = "Building targets ..."
1129
- closing_message = "done building targets."
1130
- if options.keep_going:
1131
- failure_message = "done building targets (errors occurred during build)."
1132
- else:
1133
- failure_message = "building terminated because of errors."
1134
- if options.question:
1135
- task_class = QuestionTask
1136
- try:
1137
- if options.clean:
1138
- task_class = CleanTask
1139
- opening_message = "Cleaning targets ..."
1140
- closing_message = "done cleaning targets."
1141
- if options.keep_going:
1142
- failure_message = "done cleaning targets (errors occurred during clean)."
1143
- else:
1144
- failure_message = "cleaning terminated because of errors."
1145
- except AttributeError:
1146
- pass
1147
-
1148
- task_class.progress = ProgressObject
1149
-
1150
- if options.random:
1151
- def order(dependencies):
1152
- """Randomize the dependencies."""
1153
- import random
1154
- # This is cribbed from the implementation of
1155
- # random.shuffle() in Python 2.X.
1156
- d = dependencies
1157
- for i in xrange(len(d)-1, 0, -1):
1158
- j = int(random.random() * (i+1))
1159
- d[i], d[j] = d[j], d[i]
1160
- return d
1161
- else:
1162
- def order(dependencies):
1163
- """Leave the order of dependencies alone."""
1164
- return dependencies
1165
-
1166
- if options.taskmastertrace_file == '-':
1167
- tmtrace = sys.stdout
1168
- elif options.taskmastertrace_file:
1169
- tmtrace = open(options.taskmastertrace_file, 'wb')
1170
- else:
1171
- tmtrace = None
1172
- taskmaster = SCons.Taskmaster.Taskmaster(nodes, task_class, order, tmtrace)
1173
-
1174
- # Let the BuildTask objects get at the options to respond to the
1175
- # various print_* settings, tree_printer list, etc.
1176
- BuildTask.options = options
1177
-
1178
- global num_jobs
1179
- num_jobs = options.num_jobs
1180
- jobs = SCons.Job.Jobs(num_jobs, taskmaster)
1181
- if num_jobs > 1:
1182
- msg = None
1183
- if jobs.num_jobs == 1:
1184
- msg = "parallel builds are unsupported by this version of Python;\n" + \
1185
- "\tignoring -j or num_jobs option.\n"
1186
- elif sys.platform == 'win32':
1187
- msg = fetch_win32_parallel_msg()
1188
- if msg:
1189
- SCons.Warnings.warn(SCons.Warnings.NoParallelSupportWarning, msg)
1190
-
1191
- memory_stats.append('before building targets:')
1192
- count_stats.append(('pre-', 'build'))
1193
-
1194
- def jobs_postfunc(
1195
- jobs=jobs,
1196
- options=options,
1197
- closing_message=closing_message,
1198
- failure_message=failure_message
1199
- ):
1200
- if jobs.were_interrupted():
1201
- if not options.no_progress and not options.silent:
1202
- sys.stderr.write("scons: Build interrupted.\n")
1203
- global exit_status
1204
- global this_build_status
1205
- exit_status = 2
1206
- this_build_status = 2
1207
-
1208
- if this_build_status:
1209
- progress_display("scons: " + failure_message)
1210
- else:
1211
- progress_display("scons: " + closing_message)
1212
- if not options.no_exec:
1213
- if jobs.were_interrupted():
1214
- progress_display("scons: writing .sconsign file.")
1215
- SCons.SConsign.write()
1216
-
1217
- progress_display("scons: " + opening_message)
1218
- jobs.run(postfunc = jobs_postfunc)
1219
-
1220
- memory_stats.append('after building targets:')
1221
- count_stats.append(('post-', 'build'))
1222
-
1223
- return nodes
1224
-
1225
- def _exec_main(parser, values):
1226
- sconsflags = os.environ.get('SCONSFLAGS', '')
1227
- all_args = string.split(sconsflags) + sys.argv[1:]
1228
-
1229
- options, args = parser.parse_args(all_args, values)
1230
-
1231
- if type(options.debug) == type([]) and "pdb" in options.debug:
1232
- import pdb
1233
- pdb.Pdb().runcall(_main, parser)
1234
- elif options.profile_file:
1235
- try:
1236
- from cProfile import Profile
1237
- except ImportError, e:
1238
- from profile import Profile
1239
-
1240
- # Some versions of Python 2.4 shipped a profiler that had the
1241
- # wrong 'c_exception' entry in its dispatch table. Make sure
1242
- # we have the right one. (This may put an unnecessary entry
1243
- # in the table in earlier versions of Python, but its presence
1244
- # shouldn't hurt anything).
1245
- try:
1246
- dispatch = Profile.dispatch
1247
- except AttributeError:
1248
- pass
1249
- else:
1250
- dispatch['c_exception'] = Profile.trace_dispatch_return
1251
-
1252
- prof = Profile()
1253
- try:
1254
- prof.runcall(_main, parser)
1255
- except SConsPrintHelpException, e:
1256
- prof.dump_stats(options.profile_file)
1257
- raise e
1258
- except SystemExit:
1259
- pass
1260
- prof.dump_stats(options.profile_file)
1261
- else:
1262
- _main(parser)
1263
-
1264
- def main():
1265
- global OptionsParser
1266
- global exit_status
1267
- global first_command_start
1268
-
1269
- # Check up front for a Python version we do not support. We
1270
- # delay the check for deprecated Python versions until later,
1271
- # after the SConscript files have been read, in case they
1272
- # disable that warning.
1273
- if python_version_unsupported():
1274
- msg = "scons: *** SCons version %s does not run under Python version %s.\n"
1275
- sys.stderr.write(msg % (SCons.__version__, python_version_string()))
1276
- sys.exit(1)
1277
-
1278
- parts = ["SCons by Steven Knight et al.:\n"]
1279
- try:
1280
- import __main__
1281
- parts.append(version_string("script", __main__))
1282
- except (ImportError, AttributeError):
1283
- # On Windows there is no scons.py, so there is no
1284
- # __main__.__version__, hence there is no script version.
1285
- pass
1286
- parts.append(version_string("engine", SCons))
1287
- parts.append("Copyright (c) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 The SCons Foundation")
1288
- version = string.join(parts, '')
1289
-
1290
- import SConsOptions
1291
- parser = SConsOptions.Parser(version)
1292
- values = SConsOptions.SConsValues(parser.get_default_values())
1293
-
1294
- OptionsParser = parser
1295
-
1296
- try:
1297
- _exec_main(parser, values)
1298
- except SystemExit, s:
1299
- if s:
1300
- exit_status = s
1301
- except KeyboardInterrupt:
1302
- print("scons: Build interrupted.")
1303
- sys.exit(2)
1304
- except SyntaxError, e:
1305
- _scons_syntax_error(e)
1306
- except SCons.Errors.InternalError:
1307
- _scons_internal_error()
1308
- except SCons.Errors.UserError, e:
1309
- _scons_user_error(e)
1310
- except SConsPrintHelpException:
1311
- parser.print_help()
1312
- exit_status = 0
1313
- except SCons.Errors.BuildError, e:
1314
- exit_status = e.exitstatus
1315
- except:
1316
- # An exception here is likely a builtin Python exception Python
1317
- # code in an SConscript file. Show them precisely what the
1318
- # problem was and where it happened.
1319
- SCons.Script._SConscript.SConscript_exception()
1320
- sys.exit(2)
1321
-
1322
- memory_stats.print_stats()
1323
- count_stats.print_stats()
1324
-
1325
- if print_objects:
1326
- SCons.Debug.listLoggedInstances('*')
1327
- #SCons.Debug.dumpLoggedInstances('*')
1328
-
1329
- if print_memoizer:
1330
- SCons.Memoize.Dump("Memoizer (memory cache) hits and misses:")
1331
-
1332
- # Dump any development debug info that may have been enabled.
1333
- # These are purely for internal debugging during development, so
1334
- # there's no need to control them with --debug= options; they're
1335
- # controlled by changing the source code.
1336
- SCons.Debug.dump_caller_counts()
1337
- SCons.Taskmaster.dump_stats()
1338
-
1339
- if print_time:
1340
- total_time = time.time() - SCons.Script.start_time
1341
- if num_jobs == 1:
1342
- ct = cumulative_command_time
1343
- else:
1344
- if last_command_end is None or first_command_start is None:
1345
- ct = 0.0
1346
- else:
1347
- ct = last_command_end - first_command_start
1348
- scons_time = total_time - sconscript_time - ct
1349
- print "Total build time: %f seconds"%total_time
1350
- print "Total SConscript file execution time: %f seconds"%sconscript_time
1351
- print "Total SCons execution time: %f seconds"%scons_time
1352
- print "Total command execution time: %f seconds"%ct
1353
-
1354
- sys.exit(exit_status)
1355
-
1356
- # Local Variables:
1357
- # tab-width:4
1358
- # indent-tabs-mode:nil
1359
- # End:
1360
- # vim: set expandtab tabstop=4 shiftwidth=4: