therubyracer 0.5.0-x86-linux → 0.11.0beta5-x86-linux

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 (721) hide show
  1. data/.gitignore +23 -11
  2. data/.travis.yml +10 -0
  3. data/Changelog.md +242 -0
  4. data/Gemfile +16 -0
  5. data/README.md +185 -0
  6. data/Rakefile +42 -51
  7. data/benchmarks.rb +217 -0
  8. data/ext/v8/accessor.cc +181 -0
  9. data/ext/v8/array.cc +26 -0
  10. data/ext/v8/backref.cc +56 -0
  11. data/ext/v8/build.rb +52 -0
  12. data/ext/v8/constants.cc +34 -0
  13. data/ext/v8/constraints.cc +52 -0
  14. data/ext/v8/context.cc +130 -0
  15. data/ext/v8/date.cc +18 -0
  16. data/ext/v8/exception.cc +38 -0
  17. data/ext/v8/extconf.rb +16 -29
  18. data/ext/v8/external.cc +43 -0
  19. data/ext/v8/function.cc +58 -0
  20. data/ext/v8/gc.cc +43 -0
  21. data/ext/v8/handles.cc +34 -0
  22. data/ext/v8/heap.cc +31 -0
  23. data/ext/v8/init.cc +39 -0
  24. data/ext/v8/init.so +0 -0
  25. data/ext/v8/invocation.cc +86 -0
  26. data/ext/v8/locker.cc +77 -0
  27. data/ext/v8/message.cc +51 -0
  28. data/ext/v8/object.cc +334 -0
  29. data/ext/v8/primitive.cc +8 -0
  30. data/ext/v8/rr.cc +83 -0
  31. data/ext/v8/rr.h +883 -0
  32. data/ext/v8/script.cc +80 -0
  33. data/ext/v8/signature.cc +18 -0
  34. data/ext/v8/stack.cc +75 -0
  35. data/ext/v8/string.cc +47 -0
  36. data/ext/v8/template.cc +175 -0
  37. data/ext/v8/trycatch.cc +86 -0
  38. data/ext/v8/v8.cc +87 -0
  39. data/ext/v8/value.cc +239 -0
  40. data/lib/v8.rb +30 -9
  41. data/lib/v8/access.rb +5 -0
  42. data/lib/v8/access/indices.rb +40 -0
  43. data/lib/v8/access/invocation.rb +47 -0
  44. data/lib/v8/access/names.rb +65 -0
  45. data/lib/v8/array.rb +26 -0
  46. data/lib/v8/context.rb +217 -75
  47. data/lib/v8/conversion.rb +35 -0
  48. data/lib/v8/conversion/array.rb +11 -0
  49. data/lib/v8/conversion/class.rb +120 -0
  50. data/lib/v8/conversion/code.rb +38 -0
  51. data/lib/v8/conversion/fundamental.rb +11 -0
  52. data/lib/v8/conversion/hash.rb +11 -0
  53. data/lib/v8/conversion/indentity.rb +31 -0
  54. data/lib/v8/conversion/method.rb +26 -0
  55. data/lib/v8/conversion/object.rb +28 -0
  56. data/lib/v8/conversion/primitive.rb +7 -0
  57. data/lib/v8/conversion/proc.rb +5 -0
  58. data/lib/v8/conversion/reference.rb +16 -0
  59. data/lib/v8/conversion/string.rb +12 -0
  60. data/lib/v8/conversion/symbol.rb +7 -0
  61. data/lib/v8/conversion/time.rb +13 -0
  62. data/lib/v8/error.rb +25 -0
  63. data/lib/v8/error/protect.rb +20 -0
  64. data/lib/v8/error/try.rb +15 -0
  65. data/lib/v8/function.rb +28 -0
  66. data/lib/v8/object.rb +69 -28
  67. data/lib/v8/util/weakcell.rb +29 -0
  68. data/lib/v8/version.rb +3 -0
  69. data/spec/c/array_spec.rb +17 -0
  70. data/spec/c/constants_spec.rb +20 -0
  71. data/spec/c/exception_spec.rb +26 -0
  72. data/spec/c/external_spec.rb +9 -0
  73. data/spec/c/function_spec.rb +46 -0
  74. data/spec/c/handles_spec.rb +35 -0
  75. data/spec/c/locker_spec.rb +38 -0
  76. data/spec/c/object_spec.rb +46 -0
  77. data/spec/c/script_spec.rb +28 -0
  78. data/spec/c/string_spec.rb +16 -0
  79. data/spec/c/template_spec.rb +30 -0
  80. data/spec/c/trycatch_spec.rb +51 -0
  81. data/spec/mem/blunt_spec.rb +42 -0
  82. data/spec/redjs_spec.rb +10 -0
  83. data/spec/spec_helper.rb +43 -12
  84. data/spec/threading_spec.rb +52 -0
  85. data/spec/v8/context_spec.rb +19 -0
  86. data/spec/v8/conversion_spec.rb +9 -0
  87. data/spec/v8/error_spec.rb +21 -0
  88. data/spec/v8/function_spec.rb +9 -0
  89. data/spec/v8/object_spec.rb +15 -0
  90. data/thefrontside.png +0 -0
  91. data/therubyracer.gemspec +15 -676
  92. metadata +146 -680
  93. data/.gitmodules +0 -3
  94. data/Doxyfile +0 -1514
  95. data/History.txt +0 -51
  96. data/README.rdoc +0 -158
  97. data/docs/data_conversion.txt +0 -18
  98. data/ext/v8/callbacks.cpp +0 -160
  99. data/ext/v8/callbacks.h +0 -14
  100. data/ext/v8/convert_ruby.cpp +0 -8
  101. data/ext/v8/convert_ruby.h +0 -99
  102. data/ext/v8/convert_string.cpp +0 -10
  103. data/ext/v8/convert_string.h +0 -73
  104. data/ext/v8/convert_v8.cpp +0 -9
  105. data/ext/v8/convert_v8.h +0 -121
  106. data/ext/v8/converters.cpp +0 -83
  107. data/ext/v8/converters.h +0 -23
  108. data/ext/v8/upstream/2.0.6/.gitignore +0 -26
  109. data/ext/v8/upstream/2.0.6/AUTHORS +0 -23
  110. data/ext/v8/upstream/2.0.6/ChangeLog +0 -1479
  111. data/ext/v8/upstream/2.0.6/LICENSE +0 -55
  112. data/ext/v8/upstream/2.0.6/SConstruct +0 -1028
  113. data/ext/v8/upstream/2.0.6/include/v8-debug.h +0 -275
  114. data/ext/v8/upstream/2.0.6/include/v8.h +0 -3236
  115. data/ext/v8/upstream/2.0.6/src/SConscript +0 -283
  116. data/ext/v8/upstream/2.0.6/src/accessors.cc +0 -695
  117. data/ext/v8/upstream/2.0.6/src/accessors.h +0 -114
  118. data/ext/v8/upstream/2.0.6/src/allocation.cc +0 -198
  119. data/ext/v8/upstream/2.0.6/src/allocation.h +0 -169
  120. data/ext/v8/upstream/2.0.6/src/api.cc +0 -3831
  121. data/ext/v8/upstream/2.0.6/src/api.h +0 -479
  122. data/ext/v8/upstream/2.0.6/src/apinatives.js +0 -110
  123. data/ext/v8/upstream/2.0.6/src/apiutils.h +0 -69
  124. data/ext/v8/upstream/2.0.6/src/arguments.h +0 -97
  125. data/ext/v8/upstream/2.0.6/src/arm/assembler-arm-inl.h +0 -277
  126. data/ext/v8/upstream/2.0.6/src/arm/assembler-arm.cc +0 -1821
  127. data/ext/v8/upstream/2.0.6/src/arm/assembler-arm.h +0 -1027
  128. data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2-inl.h +0 -267
  129. data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2.cc +0 -1821
  130. data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2.h +0 -1027
  131. data/ext/v8/upstream/2.0.6/src/arm/builtins-arm.cc +0 -1271
  132. data/ext/v8/upstream/2.0.6/src/arm/codegen-arm-inl.h +0 -74
  133. data/ext/v8/upstream/2.0.6/src/arm/codegen-arm.cc +0 -6682
  134. data/ext/v8/upstream/2.0.6/src/arm/codegen-arm.h +0 -535
  135. data/ext/v8/upstream/2.0.6/src/arm/constants-arm.cc +0 -112
  136. data/ext/v8/upstream/2.0.6/src/arm/constants-arm.h +0 -347
  137. data/ext/v8/upstream/2.0.6/src/arm/cpu-arm.cc +0 -132
  138. data/ext/v8/upstream/2.0.6/src/arm/debug-arm.cc +0 -213
  139. data/ext/v8/upstream/2.0.6/src/arm/disasm-arm.cc +0 -1166
  140. data/ext/v8/upstream/2.0.6/src/arm/fast-codegen-arm.cc +0 -1698
  141. data/ext/v8/upstream/2.0.6/src/arm/frames-arm.cc +0 -123
  142. data/ext/v8/upstream/2.0.6/src/arm/frames-arm.h +0 -162
  143. data/ext/v8/upstream/2.0.6/src/arm/ic-arm.cc +0 -849
  144. data/ext/v8/upstream/2.0.6/src/arm/jump-target-arm.cc +0 -238
  145. data/ext/v8/upstream/2.0.6/src/arm/macro-assembler-arm.cc +0 -1259
  146. data/ext/v8/upstream/2.0.6/src/arm/macro-assembler-arm.h +0 -423
  147. data/ext/v8/upstream/2.0.6/src/arm/regexp-macro-assembler-arm.cc +0 -1266
  148. data/ext/v8/upstream/2.0.6/src/arm/regexp-macro-assembler-arm.h +0 -282
  149. data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm-inl.h +0 -103
  150. data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm.cc +0 -59
  151. data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm.h +0 -43
  152. data/ext/v8/upstream/2.0.6/src/arm/simulator-arm.cc +0 -2264
  153. data/ext/v8/upstream/2.0.6/src/arm/simulator-arm.h +0 -306
  154. data/ext/v8/upstream/2.0.6/src/arm/stub-cache-arm.cc +0 -1516
  155. data/ext/v8/upstream/2.0.6/src/arm/virtual-frame-arm.cc +0 -412
  156. data/ext/v8/upstream/2.0.6/src/arm/virtual-frame-arm.h +0 -532
  157. data/ext/v8/upstream/2.0.6/src/array.js +0 -1154
  158. data/ext/v8/upstream/2.0.6/src/assembler.cc +0 -772
  159. data/ext/v8/upstream/2.0.6/src/assembler.h +0 -525
  160. data/ext/v8/upstream/2.0.6/src/ast.cc +0 -512
  161. data/ext/v8/upstream/2.0.6/src/ast.h +0 -1820
  162. data/ext/v8/upstream/2.0.6/src/bootstrapper.cc +0 -1680
  163. data/ext/v8/upstream/2.0.6/src/bootstrapper.h +0 -103
  164. data/ext/v8/upstream/2.0.6/src/builtins.cc +0 -851
  165. data/ext/v8/upstream/2.0.6/src/builtins.h +0 -245
  166. data/ext/v8/upstream/2.0.6/src/bytecodes-irregexp.h +0 -104
  167. data/ext/v8/upstream/2.0.6/src/char-predicates-inl.h +0 -86
  168. data/ext/v8/upstream/2.0.6/src/char-predicates.h +0 -65
  169. data/ext/v8/upstream/2.0.6/src/checks.cc +0 -100
  170. data/ext/v8/upstream/2.0.6/src/checks.h +0 -284
  171. data/ext/v8/upstream/2.0.6/src/code-stubs.cc +0 -164
  172. data/ext/v8/upstream/2.0.6/src/code-stubs.h +0 -164
  173. data/ext/v8/upstream/2.0.6/src/code.h +0 -68
  174. data/ext/v8/upstream/2.0.6/src/codegen-inl.h +0 -88
  175. data/ext/v8/upstream/2.0.6/src/codegen.cc +0 -504
  176. data/ext/v8/upstream/2.0.6/src/codegen.h +0 -522
  177. data/ext/v8/upstream/2.0.6/src/compilation-cache.cc +0 -490
  178. data/ext/v8/upstream/2.0.6/src/compilation-cache.h +0 -98
  179. data/ext/v8/upstream/2.0.6/src/compiler.cc +0 -1132
  180. data/ext/v8/upstream/2.0.6/src/compiler.h +0 -107
  181. data/ext/v8/upstream/2.0.6/src/contexts.cc +0 -256
  182. data/ext/v8/upstream/2.0.6/src/contexts.h +0 -345
  183. data/ext/v8/upstream/2.0.6/src/conversions-inl.h +0 -95
  184. data/ext/v8/upstream/2.0.6/src/conversions.cc +0 -709
  185. data/ext/v8/upstream/2.0.6/src/conversions.h +0 -118
  186. data/ext/v8/upstream/2.0.6/src/counters.cc +0 -78
  187. data/ext/v8/upstream/2.0.6/src/counters.h +0 -239
  188. data/ext/v8/upstream/2.0.6/src/cpu.h +0 -65
  189. data/ext/v8/upstream/2.0.6/src/d8-debug.cc +0 -345
  190. data/ext/v8/upstream/2.0.6/src/d8-debug.h +0 -155
  191. data/ext/v8/upstream/2.0.6/src/d8-posix.cc +0 -675
  192. data/ext/v8/upstream/2.0.6/src/d8-readline.cc +0 -128
  193. data/ext/v8/upstream/2.0.6/src/d8-windows.cc +0 -42
  194. data/ext/v8/upstream/2.0.6/src/d8.cc +0 -776
  195. data/ext/v8/upstream/2.0.6/src/d8.h +0 -225
  196. data/ext/v8/upstream/2.0.6/src/d8.js +0 -1625
  197. data/ext/v8/upstream/2.0.6/src/date-delay.js +0 -1138
  198. data/ext/v8/upstream/2.0.6/src/dateparser-inl.h +0 -114
  199. data/ext/v8/upstream/2.0.6/src/dateparser.cc +0 -186
  200. data/ext/v8/upstream/2.0.6/src/dateparser.h +0 -240
  201. data/ext/v8/upstream/2.0.6/src/debug-agent.cc +0 -425
  202. data/ext/v8/upstream/2.0.6/src/debug-agent.h +0 -129
  203. data/ext/v8/upstream/2.0.6/src/debug-delay.js +0 -2073
  204. data/ext/v8/upstream/2.0.6/src/debug.cc +0 -2751
  205. data/ext/v8/upstream/2.0.6/src/debug.h +0 -866
  206. data/ext/v8/upstream/2.0.6/src/disasm.h +0 -77
  207. data/ext/v8/upstream/2.0.6/src/disassembler.cc +0 -318
  208. data/ext/v8/upstream/2.0.6/src/disassembler.h +0 -56
  209. data/ext/v8/upstream/2.0.6/src/dtoa-config.c +0 -91
  210. data/ext/v8/upstream/2.0.6/src/execution.cc +0 -701
  211. data/ext/v8/upstream/2.0.6/src/execution.h +0 -312
  212. data/ext/v8/upstream/2.0.6/src/factory.cc +0 -957
  213. data/ext/v8/upstream/2.0.6/src/factory.h +0 -393
  214. data/ext/v8/upstream/2.0.6/src/fast-codegen.cc +0 -725
  215. data/ext/v8/upstream/2.0.6/src/fast-codegen.h +0 -371
  216. data/ext/v8/upstream/2.0.6/src/flag-definitions.h +0 -426
  217. data/ext/v8/upstream/2.0.6/src/flags.cc +0 -555
  218. data/ext/v8/upstream/2.0.6/src/flags.h +0 -81
  219. data/ext/v8/upstream/2.0.6/src/frame-element.cc +0 -45
  220. data/ext/v8/upstream/2.0.6/src/frame-element.h +0 -235
  221. data/ext/v8/upstream/2.0.6/src/frames-inl.h +0 -215
  222. data/ext/v8/upstream/2.0.6/src/frames.cc +0 -749
  223. data/ext/v8/upstream/2.0.6/src/frames.h +0 -659
  224. data/ext/v8/upstream/2.0.6/src/func-name-inferrer.cc +0 -76
  225. data/ext/v8/upstream/2.0.6/src/func-name-inferrer.h +0 -135
  226. data/ext/v8/upstream/2.0.6/src/global-handles.cc +0 -516
  227. data/ext/v8/upstream/2.0.6/src/global-handles.h +0 -180
  228. data/ext/v8/upstream/2.0.6/src/globals.h +0 -608
  229. data/ext/v8/upstream/2.0.6/src/handles-inl.h +0 -76
  230. data/ext/v8/upstream/2.0.6/src/handles.cc +0 -811
  231. data/ext/v8/upstream/2.0.6/src/handles.h +0 -367
  232. data/ext/v8/upstream/2.0.6/src/hashmap.cc +0 -226
  233. data/ext/v8/upstream/2.0.6/src/hashmap.h +0 -120
  234. data/ext/v8/upstream/2.0.6/src/heap-inl.h +0 -407
  235. data/ext/v8/upstream/2.0.6/src/heap-profiler.cc +0 -695
  236. data/ext/v8/upstream/2.0.6/src/heap-profiler.h +0 -277
  237. data/ext/v8/upstream/2.0.6/src/heap.cc +0 -4204
  238. data/ext/v8/upstream/2.0.6/src/heap.h +0 -1704
  239. data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32-inl.h +0 -325
  240. data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32.cc +0 -2375
  241. data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32.h +0 -914
  242. data/ext/v8/upstream/2.0.6/src/ia32/builtins-ia32.cc +0 -1222
  243. data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32-inl.h +0 -46
  244. data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32.cc +0 -9770
  245. data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32.h +0 -834
  246. data/ext/v8/upstream/2.0.6/src/ia32/cpu-ia32.cc +0 -79
  247. data/ext/v8/upstream/2.0.6/src/ia32/debug-ia32.cc +0 -208
  248. data/ext/v8/upstream/2.0.6/src/ia32/disasm-ia32.cc +0 -1357
  249. data/ext/v8/upstream/2.0.6/src/ia32/fast-codegen-ia32.cc +0 -1813
  250. data/ext/v8/upstream/2.0.6/src/ia32/frames-ia32.cc +0 -111
  251. data/ext/v8/upstream/2.0.6/src/ia32/frames-ia32.h +0 -135
  252. data/ext/v8/upstream/2.0.6/src/ia32/ic-ia32.cc +0 -1490
  253. data/ext/v8/upstream/2.0.6/src/ia32/jump-target-ia32.cc +0 -432
  254. data/ext/v8/upstream/2.0.6/src/ia32/macro-assembler-ia32.cc +0 -1517
  255. data/ext/v8/upstream/2.0.6/src/ia32/macro-assembler-ia32.h +0 -528
  256. data/ext/v8/upstream/2.0.6/src/ia32/regexp-macro-assembler-ia32.cc +0 -1219
  257. data/ext/v8/upstream/2.0.6/src/ia32/regexp-macro-assembler-ia32.h +0 -230
  258. data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32-inl.h +0 -82
  259. data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32.cc +0 -99
  260. data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32.h +0 -43
  261. data/ext/v8/upstream/2.0.6/src/ia32/simulator-ia32.cc +0 -30
  262. data/ext/v8/upstream/2.0.6/src/ia32/simulator-ia32.h +0 -62
  263. data/ext/v8/upstream/2.0.6/src/ia32/stub-cache-ia32.cc +0 -1961
  264. data/ext/v8/upstream/2.0.6/src/ia32/virtual-frame-ia32.cc +0 -1105
  265. data/ext/v8/upstream/2.0.6/src/ia32/virtual-frame-ia32.h +0 -580
  266. data/ext/v8/upstream/2.0.6/src/ic-inl.h +0 -93
  267. data/ext/v8/upstream/2.0.6/src/ic.cc +0 -1426
  268. data/ext/v8/upstream/2.0.6/src/ic.h +0 -443
  269. data/ext/v8/upstream/2.0.6/src/interpreter-irregexp.cc +0 -646
  270. data/ext/v8/upstream/2.0.6/src/interpreter-irregexp.h +0 -48
  271. data/ext/v8/upstream/2.0.6/src/json-delay.js +0 -254
  272. data/ext/v8/upstream/2.0.6/src/jsregexp.cc +0 -5234
  273. data/ext/v8/upstream/2.0.6/src/jsregexp.h +0 -1439
  274. data/ext/v8/upstream/2.0.6/src/jump-target-inl.h +0 -49
  275. data/ext/v8/upstream/2.0.6/src/jump-target.cc +0 -383
  276. data/ext/v8/upstream/2.0.6/src/jump-target.h +0 -280
  277. data/ext/v8/upstream/2.0.6/src/list-inl.h +0 -166
  278. data/ext/v8/upstream/2.0.6/src/list.h +0 -158
  279. data/ext/v8/upstream/2.0.6/src/log-inl.h +0 -126
  280. data/ext/v8/upstream/2.0.6/src/log-utils.cc +0 -503
  281. data/ext/v8/upstream/2.0.6/src/log-utils.h +0 -292
  282. data/ext/v8/upstream/2.0.6/src/log.cc +0 -1457
  283. data/ext/v8/upstream/2.0.6/src/log.h +0 -371
  284. data/ext/v8/upstream/2.0.6/src/macro-assembler.h +0 -93
  285. data/ext/v8/upstream/2.0.6/src/macros.py +0 -137
  286. data/ext/v8/upstream/2.0.6/src/mark-compact.cc +0 -2007
  287. data/ext/v8/upstream/2.0.6/src/mark-compact.h +0 -442
  288. data/ext/v8/upstream/2.0.6/src/math.js +0 -263
  289. data/ext/v8/upstream/2.0.6/src/memory.h +0 -74
  290. data/ext/v8/upstream/2.0.6/src/messages.cc +0 -177
  291. data/ext/v8/upstream/2.0.6/src/messages.h +0 -112
  292. data/ext/v8/upstream/2.0.6/src/messages.js +0 -937
  293. data/ext/v8/upstream/2.0.6/src/mirror-delay.js +0 -2332
  294. data/ext/v8/upstream/2.0.6/src/mksnapshot.cc +0 -169
  295. data/ext/v8/upstream/2.0.6/src/natives.h +0 -63
  296. data/ext/v8/upstream/2.0.6/src/objects-debug.cc +0 -1317
  297. data/ext/v8/upstream/2.0.6/src/objects-inl.h +0 -3044
  298. data/ext/v8/upstream/2.0.6/src/objects.cc +0 -8306
  299. data/ext/v8/upstream/2.0.6/src/objects.h +0 -4960
  300. data/ext/v8/upstream/2.0.6/src/oprofile-agent.cc +0 -116
  301. data/ext/v8/upstream/2.0.6/src/oprofile-agent.h +0 -69
  302. data/ext/v8/upstream/2.0.6/src/parser.cc +0 -4810
  303. data/ext/v8/upstream/2.0.6/src/parser.h +0 -195
  304. data/ext/v8/upstream/2.0.6/src/platform-freebsd.cc +0 -645
  305. data/ext/v8/upstream/2.0.6/src/platform-linux.cc +0 -808
  306. data/ext/v8/upstream/2.0.6/src/platform-macos.cc +0 -643
  307. data/ext/v8/upstream/2.0.6/src/platform-nullos.cc +0 -454
  308. data/ext/v8/upstream/2.0.6/src/platform-openbsd.cc +0 -597
  309. data/ext/v8/upstream/2.0.6/src/platform-posix.cc +0 -380
  310. data/ext/v8/upstream/2.0.6/src/platform-win32.cc +0 -1908
  311. data/ext/v8/upstream/2.0.6/src/platform.h +0 -556
  312. data/ext/v8/upstream/2.0.6/src/prettyprinter.cc +0 -1511
  313. data/ext/v8/upstream/2.0.6/src/prettyprinter.h +0 -219
  314. data/ext/v8/upstream/2.0.6/src/property.cc +0 -96
  315. data/ext/v8/upstream/2.0.6/src/property.h +0 -327
  316. data/ext/v8/upstream/2.0.6/src/regexp-delay.js +0 -406
  317. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp-inl.h +0 -78
  318. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp.cc +0 -464
  319. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp.h +0 -141
  320. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-tracer.cc +0 -356
  321. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-tracer.h +0 -103
  322. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler.cc +0 -240
  323. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler.h +0 -220
  324. data/ext/v8/upstream/2.0.6/src/regexp-stack.cc +0 -103
  325. data/ext/v8/upstream/2.0.6/src/regexp-stack.h +0 -123
  326. data/ext/v8/upstream/2.0.6/src/register-allocator-inl.h +0 -74
  327. data/ext/v8/upstream/2.0.6/src/register-allocator.cc +0 -100
  328. data/ext/v8/upstream/2.0.6/src/register-allocator.h +0 -295
  329. data/ext/v8/upstream/2.0.6/src/rewriter.cc +0 -855
  330. data/ext/v8/upstream/2.0.6/src/rewriter.h +0 -54
  331. data/ext/v8/upstream/2.0.6/src/runtime.cc +0 -8163
  332. data/ext/v8/upstream/2.0.6/src/runtime.h +0 -432
  333. data/ext/v8/upstream/2.0.6/src/runtime.js +0 -626
  334. data/ext/v8/upstream/2.0.6/src/scanner.cc +0 -1098
  335. data/ext/v8/upstream/2.0.6/src/scanner.h +0 -425
  336. data/ext/v8/upstream/2.0.6/src/scopeinfo.cc +0 -649
  337. data/ext/v8/upstream/2.0.6/src/scopeinfo.h +0 -236
  338. data/ext/v8/upstream/2.0.6/src/scopes.cc +0 -963
  339. data/ext/v8/upstream/2.0.6/src/scopes.h +0 -401
  340. data/ext/v8/upstream/2.0.6/src/serialize.cc +0 -1260
  341. data/ext/v8/upstream/2.0.6/src/serialize.h +0 -404
  342. data/ext/v8/upstream/2.0.6/src/shell.h +0 -55
  343. data/ext/v8/upstream/2.0.6/src/simulator.h +0 -41
  344. data/ext/v8/upstream/2.0.6/src/smart-pointer.h +0 -109
  345. data/ext/v8/upstream/2.0.6/src/snapshot-common.cc +0 -97
  346. data/ext/v8/upstream/2.0.6/src/snapshot-empty.cc +0 -40
  347. data/ext/v8/upstream/2.0.6/src/snapshot.h +0 -59
  348. data/ext/v8/upstream/2.0.6/src/spaces-inl.h +0 -372
  349. data/ext/v8/upstream/2.0.6/src/spaces.cc +0 -2864
  350. data/ext/v8/upstream/2.0.6/src/spaces.h +0 -2072
  351. data/ext/v8/upstream/2.0.6/src/string-stream.cc +0 -584
  352. data/ext/v8/upstream/2.0.6/src/string-stream.h +0 -189
  353. data/ext/v8/upstream/2.0.6/src/string.js +0 -901
  354. data/ext/v8/upstream/2.0.6/src/stub-cache.cc +0 -1108
  355. data/ext/v8/upstream/2.0.6/src/stub-cache.h +0 -578
  356. data/ext/v8/upstream/2.0.6/src/third_party/dtoa/COPYING +0 -15
  357. data/ext/v8/upstream/2.0.6/src/third_party/dtoa/dtoa.c +0 -3330
  358. data/ext/v8/upstream/2.0.6/src/third_party/valgrind/valgrind.h +0 -3925
  359. data/ext/v8/upstream/2.0.6/src/token.cc +0 -56
  360. data/ext/v8/upstream/2.0.6/src/token.h +0 -270
  361. data/ext/v8/upstream/2.0.6/src/top.cc +0 -991
  362. data/ext/v8/upstream/2.0.6/src/top.h +0 -459
  363. data/ext/v8/upstream/2.0.6/src/unicode-inl.h +0 -238
  364. data/ext/v8/upstream/2.0.6/src/unicode.cc +0 -749
  365. data/ext/v8/upstream/2.0.6/src/unicode.h +0 -279
  366. data/ext/v8/upstream/2.0.6/src/uri.js +0 -415
  367. data/ext/v8/upstream/2.0.6/src/usage-analyzer.cc +0 -426
  368. data/ext/v8/upstream/2.0.6/src/usage-analyzer.h +0 -40
  369. data/ext/v8/upstream/2.0.6/src/utils.cc +0 -322
  370. data/ext/v8/upstream/2.0.6/src/utils.h +0 -592
  371. data/ext/v8/upstream/2.0.6/src/v8-counters.cc +0 -55
  372. data/ext/v8/upstream/2.0.6/src/v8-counters.h +0 -198
  373. data/ext/v8/upstream/2.0.6/src/v8.cc +0 -193
  374. data/ext/v8/upstream/2.0.6/src/v8.h +0 -119
  375. data/ext/v8/upstream/2.0.6/src/v8natives.js +0 -846
  376. data/ext/v8/upstream/2.0.6/src/v8threads.cc +0 -450
  377. data/ext/v8/upstream/2.0.6/src/v8threads.h +0 -144
  378. data/ext/v8/upstream/2.0.6/src/variables.cc +0 -163
  379. data/ext/v8/upstream/2.0.6/src/variables.h +0 -235
  380. data/ext/v8/upstream/2.0.6/src/version.cc +0 -88
  381. data/ext/v8/upstream/2.0.6/src/version.h +0 -64
  382. data/ext/v8/upstream/2.0.6/src/virtual-frame.cc +0 -381
  383. data/ext/v8/upstream/2.0.6/src/virtual-frame.h +0 -44
  384. data/ext/v8/upstream/2.0.6/src/x64/assembler-x64-inl.h +0 -352
  385. data/ext/v8/upstream/2.0.6/src/x64/assembler-x64.cc +0 -2539
  386. data/ext/v8/upstream/2.0.6/src/x64/assembler-x64.h +0 -1399
  387. data/ext/v8/upstream/2.0.6/src/x64/builtins-x64.cc +0 -1255
  388. data/ext/v8/upstream/2.0.6/src/x64/codegen-x64-inl.h +0 -46
  389. data/ext/v8/upstream/2.0.6/src/x64/codegen-x64.cc +0 -8223
  390. data/ext/v8/upstream/2.0.6/src/x64/codegen-x64.h +0 -785
  391. data/ext/v8/upstream/2.0.6/src/x64/cpu-x64.cc +0 -79
  392. data/ext/v8/upstream/2.0.6/src/x64/debug-x64.cc +0 -202
  393. data/ext/v8/upstream/2.0.6/src/x64/disasm-x64.cc +0 -1596
  394. data/ext/v8/upstream/2.0.6/src/x64/fast-codegen-x64.cc +0 -1820
  395. data/ext/v8/upstream/2.0.6/src/x64/frames-x64.cc +0 -109
  396. data/ext/v8/upstream/2.0.6/src/x64/frames-x64.h +0 -121
  397. data/ext/v8/upstream/2.0.6/src/x64/ic-x64.cc +0 -1392
  398. data/ext/v8/upstream/2.0.6/src/x64/jump-target-x64.cc +0 -432
  399. data/ext/v8/upstream/2.0.6/src/x64/macro-assembler-x64.cc +0 -2409
  400. data/ext/v8/upstream/2.0.6/src/x64/macro-assembler-x64.h +0 -765
  401. data/ext/v8/upstream/2.0.6/src/x64/regexp-macro-assembler-x64.cc +0 -1337
  402. data/ext/v8/upstream/2.0.6/src/x64/regexp-macro-assembler-x64.h +0 -295
  403. data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64-inl.h +0 -86
  404. data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64.cc +0 -84
  405. data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64.h +0 -43
  406. data/ext/v8/upstream/2.0.6/src/x64/simulator-x64.cc +0 -27
  407. data/ext/v8/upstream/2.0.6/src/x64/simulator-x64.h +0 -63
  408. data/ext/v8/upstream/2.0.6/src/x64/stub-cache-x64.cc +0 -1884
  409. data/ext/v8/upstream/2.0.6/src/x64/virtual-frame-x64.cc +0 -1089
  410. data/ext/v8/upstream/2.0.6/src/x64/virtual-frame-x64.h +0 -560
  411. data/ext/v8/upstream/2.0.6/src/zone-inl.h +0 -297
  412. data/ext/v8/upstream/2.0.6/src/zone.cc +0 -193
  413. data/ext/v8/upstream/2.0.6/src/zone.h +0 -305
  414. data/ext/v8/upstream/2.0.6/tools/codemap.js +0 -258
  415. data/ext/v8/upstream/2.0.6/tools/consarray.js +0 -93
  416. data/ext/v8/upstream/2.0.6/tools/csvparser.js +0 -98
  417. data/ext/v8/upstream/2.0.6/tools/gyp/v8.gyp +0 -620
  418. data/ext/v8/upstream/2.0.6/tools/js2c.py +0 -376
  419. data/ext/v8/upstream/2.0.6/tools/jsmin.py +0 -280
  420. data/ext/v8/upstream/2.0.6/tools/linux-tick-processor +0 -24
  421. data/ext/v8/upstream/2.0.6/tools/linux-tick-processor.py +0 -78
  422. data/ext/v8/upstream/2.0.6/tools/logreader.js +0 -320
  423. data/ext/v8/upstream/2.0.6/tools/mac-nm +0 -18
  424. data/ext/v8/upstream/2.0.6/tools/mac-tick-processor +0 -6
  425. data/ext/v8/upstream/2.0.6/tools/oprofile/annotate +0 -7
  426. data/ext/v8/upstream/2.0.6/tools/oprofile/common +0 -19
  427. data/ext/v8/upstream/2.0.6/tools/oprofile/dump +0 -7
  428. data/ext/v8/upstream/2.0.6/tools/oprofile/report +0 -7
  429. data/ext/v8/upstream/2.0.6/tools/oprofile/reset +0 -7
  430. data/ext/v8/upstream/2.0.6/tools/oprofile/run +0 -14
  431. data/ext/v8/upstream/2.0.6/tools/oprofile/shutdown +0 -7
  432. data/ext/v8/upstream/2.0.6/tools/oprofile/start +0 -7
  433. data/ext/v8/upstream/2.0.6/tools/presubmit.py +0 -299
  434. data/ext/v8/upstream/2.0.6/tools/process-heap-prof.py +0 -120
  435. data/ext/v8/upstream/2.0.6/tools/profile.js +0 -621
  436. data/ext/v8/upstream/2.0.6/tools/profile_view.js +0 -224
  437. data/ext/v8/upstream/2.0.6/tools/run-valgrind.py +0 -77
  438. data/ext/v8/upstream/2.0.6/tools/splaytree.js +0 -322
  439. data/ext/v8/upstream/2.0.6/tools/splaytree.py +0 -226
  440. data/ext/v8/upstream/2.0.6/tools/stats-viewer.py +0 -456
  441. data/ext/v8/upstream/2.0.6/tools/test.py +0 -1370
  442. data/ext/v8/upstream/2.0.6/tools/tickprocessor-driver.js +0 -53
  443. data/ext/v8/upstream/2.0.6/tools/tickprocessor.js +0 -731
  444. data/ext/v8/upstream/2.0.6/tools/tickprocessor.py +0 -535
  445. data/ext/v8/upstream/2.0.6/tools/utils.py +0 -82
  446. data/ext/v8/upstream/2.0.6/tools/visual_studio/README.txt +0 -71
  447. data/ext/v8/upstream/2.0.6/tools/visual_studio/arm.vsprops +0 -14
  448. data/ext/v8/upstream/2.0.6/tools/visual_studio/common.vsprops +0 -35
  449. data/ext/v8/upstream/2.0.6/tools/visual_studio/d8.vcproj +0 -199
  450. data/ext/v8/upstream/2.0.6/tools/visual_studio/d8_arm.vcproj +0 -199
  451. data/ext/v8/upstream/2.0.6/tools/visual_studio/d8_x64.vcproj +0 -201
  452. data/ext/v8/upstream/2.0.6/tools/visual_studio/d8js2c.cmd +0 -6
  453. data/ext/v8/upstream/2.0.6/tools/visual_studio/debug.vsprops +0 -17
  454. data/ext/v8/upstream/2.0.6/tools/visual_studio/ia32.vsprops +0 -13
  455. data/ext/v8/upstream/2.0.6/tools/visual_studio/js2c.cmd +0 -6
  456. data/ext/v8/upstream/2.0.6/tools/visual_studio/release.vsprops +0 -24
  457. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8.sln +0 -101
  458. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8.vcproj +0 -223
  459. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_arm.sln +0 -74
  460. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_arm.vcproj +0 -223
  461. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base.vcproj +0 -971
  462. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base_arm.vcproj +0 -983
  463. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base_x64.vcproj +0 -959
  464. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest.vcproj +0 -255
  465. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest_arm.vcproj +0 -243
  466. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest_x64.vcproj +0 -257
  467. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_mksnapshot.vcproj +0 -151
  468. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_mksnapshot_x64.vcproj +0 -151
  469. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample.vcproj +0 -151
  470. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample_arm.vcproj +0 -151
  471. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample_x64.vcproj +0 -151
  472. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample.vcproj +0 -151
  473. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample_arm.vcproj +0 -151
  474. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample_x64.vcproj +0 -153
  475. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot.vcproj +0 -142
  476. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_cc.vcproj +0 -92
  477. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_cc_x64.vcproj +0 -92
  478. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_x64.vcproj +0 -142
  479. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_x64.sln +0 -101
  480. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_x64.vcproj +0 -223
  481. data/ext/v8/upstream/2.0.6/tools/visual_studio/x64.vsprops +0 -13
  482. data/ext/v8/upstream/2.0.6/tools/windows-tick-processor.bat +0 -5
  483. data/ext/v8/upstream/2.0.6/tools/windows-tick-processor.py +0 -137
  484. data/ext/v8/upstream/Makefile +0 -32
  485. data/ext/v8/upstream/fpic-on-linux-amd64.patch +0 -13
  486. data/ext/v8/upstream/no-strict-aliasing.patch +0 -13
  487. data/ext/v8/upstream/scons/CHANGES.txt +0 -5183
  488. data/ext/v8/upstream/scons/LICENSE.txt +0 -20
  489. data/ext/v8/upstream/scons/MANIFEST +0 -202
  490. data/ext/v8/upstream/scons/PKG-INFO +0 -13
  491. data/ext/v8/upstream/scons/README.txt +0 -273
  492. data/ext/v8/upstream/scons/RELEASE.txt +0 -1040
  493. data/ext/v8/upstream/scons/engine/SCons/Action.py +0 -1256
  494. data/ext/v8/upstream/scons/engine/SCons/Builder.py +0 -868
  495. data/ext/v8/upstream/scons/engine/SCons/CacheDir.py +0 -217
  496. data/ext/v8/upstream/scons/engine/SCons/Conftest.py +0 -794
  497. data/ext/v8/upstream/scons/engine/SCons/Debug.py +0 -237
  498. data/ext/v8/upstream/scons/engine/SCons/Defaults.py +0 -485
  499. data/ext/v8/upstream/scons/engine/SCons/Environment.py +0 -2327
  500. data/ext/v8/upstream/scons/engine/SCons/Errors.py +0 -207
  501. data/ext/v8/upstream/scons/engine/SCons/Executor.py +0 -636
  502. data/ext/v8/upstream/scons/engine/SCons/Job.py +0 -435
  503. data/ext/v8/upstream/scons/engine/SCons/Memoize.py +0 -292
  504. data/ext/v8/upstream/scons/engine/SCons/Node/Alias.py +0 -153
  505. data/ext/v8/upstream/scons/engine/SCons/Node/FS.py +0 -3220
  506. data/ext/v8/upstream/scons/engine/SCons/Node/Python.py +0 -128
  507. data/ext/v8/upstream/scons/engine/SCons/Node/__init__.py +0 -1341
  508. data/ext/v8/upstream/scons/engine/SCons/Options/BoolOption.py +0 -50
  509. data/ext/v8/upstream/scons/engine/SCons/Options/EnumOption.py +0 -50
  510. data/ext/v8/upstream/scons/engine/SCons/Options/ListOption.py +0 -50
  511. data/ext/v8/upstream/scons/engine/SCons/Options/PackageOption.py +0 -50
  512. data/ext/v8/upstream/scons/engine/SCons/Options/PathOption.py +0 -76
  513. data/ext/v8/upstream/scons/engine/SCons/Options/__init__.py +0 -74
  514. data/ext/v8/upstream/scons/engine/SCons/PathList.py +0 -232
  515. data/ext/v8/upstream/scons/engine/SCons/Platform/__init__.py +0 -236
  516. data/ext/v8/upstream/scons/engine/SCons/Platform/aix.py +0 -70
  517. data/ext/v8/upstream/scons/engine/SCons/Platform/cygwin.py +0 -55
  518. data/ext/v8/upstream/scons/engine/SCons/Platform/darwin.py +0 -46
  519. data/ext/v8/upstream/scons/engine/SCons/Platform/hpux.py +0 -46
  520. data/ext/v8/upstream/scons/engine/SCons/Platform/irix.py +0 -44
  521. data/ext/v8/upstream/scons/engine/SCons/Platform/os2.py +0 -58
  522. data/ext/v8/upstream/scons/engine/SCons/Platform/posix.py +0 -264
  523. data/ext/v8/upstream/scons/engine/SCons/Platform/sunos.py +0 -50
  524. data/ext/v8/upstream/scons/engine/SCons/Platform/win32.py +0 -386
  525. data/ext/v8/upstream/scons/engine/SCons/SConf.py +0 -1038
  526. data/ext/v8/upstream/scons/engine/SCons/SConsign.py +0 -381
  527. data/ext/v8/upstream/scons/engine/SCons/Scanner/C.py +0 -132
  528. data/ext/v8/upstream/scons/engine/SCons/Scanner/D.py +0 -74
  529. data/ext/v8/upstream/scons/engine/SCons/Scanner/Dir.py +0 -111
  530. data/ext/v8/upstream/scons/engine/SCons/Scanner/Fortran.py +0 -320
  531. data/ext/v8/upstream/scons/engine/SCons/Scanner/IDL.py +0 -48
  532. data/ext/v8/upstream/scons/engine/SCons/Scanner/LaTeX.py +0 -378
  533. data/ext/v8/upstream/scons/engine/SCons/Scanner/Prog.py +0 -103
  534. data/ext/v8/upstream/scons/engine/SCons/Scanner/RC.py +0 -55
  535. data/ext/v8/upstream/scons/engine/SCons/Scanner/__init__.py +0 -415
  536. data/ext/v8/upstream/scons/engine/SCons/Script/Interactive.py +0 -386
  537. data/ext/v8/upstream/scons/engine/SCons/Script/Main.py +0 -1360
  538. data/ext/v8/upstream/scons/engine/SCons/Script/SConsOptions.py +0 -944
  539. data/ext/v8/upstream/scons/engine/SCons/Script/SConscript.py +0 -642
  540. data/ext/v8/upstream/scons/engine/SCons/Script/__init__.py +0 -414
  541. data/ext/v8/upstream/scons/engine/SCons/Sig.py +0 -63
  542. data/ext/v8/upstream/scons/engine/SCons/Subst.py +0 -911
  543. data/ext/v8/upstream/scons/engine/SCons/Taskmaster.py +0 -1030
  544. data/ext/v8/upstream/scons/engine/SCons/Tool/386asm.py +0 -61
  545. data/ext/v8/upstream/scons/engine/SCons/Tool/BitKeeper.py +0 -65
  546. data/ext/v8/upstream/scons/engine/SCons/Tool/CVS.py +0 -73
  547. data/ext/v8/upstream/scons/engine/SCons/Tool/FortranCommon.py +0 -247
  548. data/ext/v8/upstream/scons/engine/SCons/Tool/JavaCommon.py +0 -324
  549. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/__init__.py +0 -56
  550. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/arch.py +0 -61
  551. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/common.py +0 -210
  552. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/netframework.py +0 -84
  553. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/sdk.py +0 -321
  554. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/vc.py +0 -367
  555. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/vs.py +0 -497
  556. data/ext/v8/upstream/scons/engine/SCons/Tool/Perforce.py +0 -104
  557. data/ext/v8/upstream/scons/engine/SCons/Tool/PharLapCommon.py +0 -138
  558. data/ext/v8/upstream/scons/engine/SCons/Tool/RCS.py +0 -64
  559. data/ext/v8/upstream/scons/engine/SCons/Tool/SCCS.py +0 -64
  560. data/ext/v8/upstream/scons/engine/SCons/Tool/Subversion.py +0 -71
  561. data/ext/v8/upstream/scons/engine/SCons/Tool/__init__.py +0 -675
  562. data/ext/v8/upstream/scons/engine/SCons/Tool/aixc++.py +0 -82
  563. data/ext/v8/upstream/scons/engine/SCons/Tool/aixcc.py +0 -74
  564. data/ext/v8/upstream/scons/engine/SCons/Tool/aixf77.py +0 -80
  565. data/ext/v8/upstream/scons/engine/SCons/Tool/aixlink.py +0 -76
  566. data/ext/v8/upstream/scons/engine/SCons/Tool/applelink.py +0 -71
  567. data/ext/v8/upstream/scons/engine/SCons/Tool/ar.py +0 -63
  568. data/ext/v8/upstream/scons/engine/SCons/Tool/as.py +0 -78
  569. data/ext/v8/upstream/scons/engine/SCons/Tool/bcc32.py +0 -82
  570. data/ext/v8/upstream/scons/engine/SCons/Tool/c++.py +0 -99
  571. data/ext/v8/upstream/scons/engine/SCons/Tool/cc.py +0 -114
  572. data/ext/v8/upstream/scons/engine/SCons/Tool/cvf.py +0 -58
  573. data/ext/v8/upstream/scons/engine/SCons/Tool/default.py +0 -50
  574. data/ext/v8/upstream/scons/engine/SCons/Tool/dmd.py +0 -224
  575. data/ext/v8/upstream/scons/engine/SCons/Tool/dvi.py +0 -64
  576. data/ext/v8/upstream/scons/engine/SCons/Tool/dvipdf.py +0 -125
  577. data/ext/v8/upstream/scons/engine/SCons/Tool/dvips.py +0 -94
  578. data/ext/v8/upstream/scons/engine/SCons/Tool/f77.py +0 -62
  579. data/ext/v8/upstream/scons/engine/SCons/Tool/f90.py +0 -62
  580. data/ext/v8/upstream/scons/engine/SCons/Tool/f95.py +0 -63
  581. data/ext/v8/upstream/scons/engine/SCons/Tool/filesystem.py +0 -98
  582. data/ext/v8/upstream/scons/engine/SCons/Tool/fortran.py +0 -63
  583. data/ext/v8/upstream/scons/engine/SCons/Tool/g++.py +0 -90
  584. data/ext/v8/upstream/scons/engine/SCons/Tool/g77.py +0 -73
  585. data/ext/v8/upstream/scons/engine/SCons/Tool/gas.py +0 -53
  586. data/ext/v8/upstream/scons/engine/SCons/Tool/gcc.py +0 -80
  587. data/ext/v8/upstream/scons/engine/SCons/Tool/gfortran.py +0 -64
  588. data/ext/v8/upstream/scons/engine/SCons/Tool/gnulink.py +0 -63
  589. data/ext/v8/upstream/scons/engine/SCons/Tool/gs.py +0 -81
  590. data/ext/v8/upstream/scons/engine/SCons/Tool/hpc++.py +0 -85
  591. data/ext/v8/upstream/scons/engine/SCons/Tool/hpcc.py +0 -53
  592. data/ext/v8/upstream/scons/engine/SCons/Tool/hplink.py +0 -77
  593. data/ext/v8/upstream/scons/engine/SCons/Tool/icc.py +0 -59
  594. data/ext/v8/upstream/scons/engine/SCons/Tool/icl.py +0 -52
  595. data/ext/v8/upstream/scons/engine/SCons/Tool/ifl.py +0 -72
  596. data/ext/v8/upstream/scons/engine/SCons/Tool/ifort.py +0 -90
  597. data/ext/v8/upstream/scons/engine/SCons/Tool/ilink.py +0 -59
  598. data/ext/v8/upstream/scons/engine/SCons/Tool/ilink32.py +0 -60
  599. data/ext/v8/upstream/scons/engine/SCons/Tool/install.py +0 -229
  600. data/ext/v8/upstream/scons/engine/SCons/Tool/intelc.py +0 -490
  601. data/ext/v8/upstream/scons/engine/SCons/Tool/ipkg.py +0 -71
  602. data/ext/v8/upstream/scons/engine/SCons/Tool/jar.py +0 -110
  603. data/ext/v8/upstream/scons/engine/SCons/Tool/javac.py +0 -234
  604. data/ext/v8/upstream/scons/engine/SCons/Tool/javah.py +0 -138
  605. data/ext/v8/upstream/scons/engine/SCons/Tool/latex.py +0 -79
  606. data/ext/v8/upstream/scons/engine/SCons/Tool/lex.py +0 -99
  607. data/ext/v8/upstream/scons/engine/SCons/Tool/link.py +0 -121
  608. data/ext/v8/upstream/scons/engine/SCons/Tool/linkloc.py +0 -112
  609. data/ext/v8/upstream/scons/engine/SCons/Tool/m4.py +0 -63
  610. data/ext/v8/upstream/scons/engine/SCons/Tool/masm.py +0 -77
  611. data/ext/v8/upstream/scons/engine/SCons/Tool/midl.py +0 -90
  612. data/ext/v8/upstream/scons/engine/SCons/Tool/mingw.py +0 -159
  613. data/ext/v8/upstream/scons/engine/SCons/Tool/mslib.py +0 -64
  614. data/ext/v8/upstream/scons/engine/SCons/Tool/mslink.py +0 -266
  615. data/ext/v8/upstream/scons/engine/SCons/Tool/mssdk.py +0 -50
  616. data/ext/v8/upstream/scons/engine/SCons/Tool/msvc.py +0 -269
  617. data/ext/v8/upstream/scons/engine/SCons/Tool/msvs.py +0 -1439
  618. data/ext/v8/upstream/scons/engine/SCons/Tool/mwcc.py +0 -208
  619. data/ext/v8/upstream/scons/engine/SCons/Tool/mwld.py +0 -107
  620. data/ext/v8/upstream/scons/engine/SCons/Tool/nasm.py +0 -72
  621. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/__init__.py +0 -314
  622. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/ipk.py +0 -185
  623. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/msi.py +0 -526
  624. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/rpm.py +0 -367
  625. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_tarbz2.py +0 -43
  626. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_targz.py +0 -43
  627. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_zip.py +0 -43
  628. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/tarbz2.py +0 -44
  629. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/targz.py +0 -44
  630. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/zip.py +0 -44
  631. data/ext/v8/upstream/scons/engine/SCons/Tool/pdf.py +0 -78
  632. data/ext/v8/upstream/scons/engine/SCons/Tool/pdflatex.py +0 -83
  633. data/ext/v8/upstream/scons/engine/SCons/Tool/pdftex.py +0 -108
  634. data/ext/v8/upstream/scons/engine/SCons/Tool/qt.py +0 -336
  635. data/ext/v8/upstream/scons/engine/SCons/Tool/rmic.py +0 -121
  636. data/ext/v8/upstream/scons/engine/SCons/Tool/rpcgen.py +0 -70
  637. data/ext/v8/upstream/scons/engine/SCons/Tool/rpm.py +0 -132
  638. data/ext/v8/upstream/scons/engine/SCons/Tool/sgiar.py +0 -68
  639. data/ext/v8/upstream/scons/engine/SCons/Tool/sgic++.py +0 -58
  640. data/ext/v8/upstream/scons/engine/SCons/Tool/sgicc.py +0 -53
  641. data/ext/v8/upstream/scons/engine/SCons/Tool/sgilink.py +0 -63
  642. data/ext/v8/upstream/scons/engine/SCons/Tool/sunar.py +0 -67
  643. data/ext/v8/upstream/scons/engine/SCons/Tool/sunc++.py +0 -142
  644. data/ext/v8/upstream/scons/engine/SCons/Tool/suncc.py +0 -58
  645. data/ext/v8/upstream/scons/engine/SCons/Tool/sunf77.py +0 -63
  646. data/ext/v8/upstream/scons/engine/SCons/Tool/sunf90.py +0 -64
  647. data/ext/v8/upstream/scons/engine/SCons/Tool/sunf95.py +0 -64
  648. data/ext/v8/upstream/scons/engine/SCons/Tool/sunlink.py +0 -77
  649. data/ext/v8/upstream/scons/engine/SCons/Tool/swig.py +0 -186
  650. data/ext/v8/upstream/scons/engine/SCons/Tool/tar.py +0 -73
  651. data/ext/v8/upstream/scons/engine/SCons/Tool/tex.py +0 -805
  652. data/ext/v8/upstream/scons/engine/SCons/Tool/textfile.py +0 -175
  653. data/ext/v8/upstream/scons/engine/SCons/Tool/tlib.py +0 -53
  654. data/ext/v8/upstream/scons/engine/SCons/Tool/wix.py +0 -100
  655. data/ext/v8/upstream/scons/engine/SCons/Tool/yacc.py +0 -131
  656. data/ext/v8/upstream/scons/engine/SCons/Tool/zip.py +0 -100
  657. data/ext/v8/upstream/scons/engine/SCons/Util.py +0 -1645
  658. data/ext/v8/upstream/scons/engine/SCons/Variables/BoolVariable.py +0 -91
  659. data/ext/v8/upstream/scons/engine/SCons/Variables/EnumVariable.py +0 -107
  660. data/ext/v8/upstream/scons/engine/SCons/Variables/ListVariable.py +0 -139
  661. data/ext/v8/upstream/scons/engine/SCons/Variables/PackageVariable.py +0 -109
  662. data/ext/v8/upstream/scons/engine/SCons/Variables/PathVariable.py +0 -147
  663. data/ext/v8/upstream/scons/engine/SCons/Variables/__init__.py +0 -317
  664. data/ext/v8/upstream/scons/engine/SCons/Warnings.py +0 -228
  665. data/ext/v8/upstream/scons/engine/SCons/__init__.py +0 -49
  666. data/ext/v8/upstream/scons/engine/SCons/compat/__init__.py +0 -302
  667. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_UserString.py +0 -98
  668. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_hashlib.py +0 -91
  669. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_itertools.py +0 -124
  670. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_optparse.py +0 -1725
  671. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_sets.py +0 -583
  672. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_sets15.py +0 -176
  673. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_shlex.py +0 -325
  674. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_subprocess.py +0 -1296
  675. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_textwrap.py +0 -382
  676. data/ext/v8/upstream/scons/engine/SCons/compat/builtins.py +0 -187
  677. data/ext/v8/upstream/scons/engine/SCons/cpp.py +0 -598
  678. data/ext/v8/upstream/scons/engine/SCons/dblite.py +0 -248
  679. data/ext/v8/upstream/scons/engine/SCons/exitfuncs.py +0 -77
  680. data/ext/v8/upstream/scons/os_spawnv_fix.diff +0 -83
  681. data/ext/v8/upstream/scons/scons-time.1 +0 -1017
  682. data/ext/v8/upstream/scons/scons.1 +0 -15179
  683. data/ext/v8/upstream/scons/sconsign.1 +0 -208
  684. data/ext/v8/upstream/scons/script/scons +0 -184
  685. data/ext/v8/upstream/scons/script/scons-time +0 -1529
  686. data/ext/v8/upstream/scons/script/scons.bat +0 -31
  687. data/ext/v8/upstream/scons/script/sconsign +0 -508
  688. data/ext/v8/upstream/scons/setup.cfg +0 -6
  689. data/ext/v8/upstream/scons/setup.py +0 -427
  690. data/ext/v8/v8.cpp +0 -89
  691. data/ext/v8/v8_cxt.cpp +0 -92
  692. data/ext/v8/v8_cxt.h +0 -20
  693. data/ext/v8/v8_func.cpp +0 -10
  694. data/ext/v8/v8_func.h +0 -11
  695. data/ext/v8/v8_msg.cpp +0 -54
  696. data/ext/v8/v8_msg.h +0 -18
  697. data/ext/v8/v8_obj.cpp +0 -52
  698. data/ext/v8/v8_obj.h +0 -13
  699. data/ext/v8/v8_ref.cpp +0 -26
  700. data/ext/v8/v8_ref.h +0 -31
  701. data/ext/v8/v8_script.cpp +0 -20
  702. data/ext/v8/v8_script.h +0 -8
  703. data/ext/v8/v8_standalone.cpp +0 -69
  704. data/ext/v8/v8_standalone.h +0 -31
  705. data/ext/v8/v8_str.cpp +0 -17
  706. data/ext/v8/v8_str.h +0 -9
  707. data/ext/v8/v8_template.cpp +0 -53
  708. data/ext/v8/v8_template.h +0 -13
  709. data/lib/v8/to.rb +0 -33
  710. data/lib/v8/v8.so +0 -0
  711. data/script/console +0 -10
  712. data/script/destroy +0 -14
  713. data/script/generate +0 -14
  714. data/spec/ext/cxt_spec.rb +0 -25
  715. data/spec/ext/obj_spec.rb +0 -13
  716. data/spec/redjs/jsapi_spec.rb +0 -405
  717. data/spec/redjs/tap.rb +0 -8
  718. data/spec/redjs_helper.rb +0 -3
  719. data/spec/spec.opts +0 -1
  720. data/spec/v8/to_spec.rb +0 -15
  721. data/tasks/rspec.rake +0 -21
@@ -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: