shoesgem 0.1424.0 → 0.1426.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (320) hide show
  1. data/README.rdoc +3 -0
  2. data/shoes/CHANGELOG.txt +21 -21
  3. data/shoes/COPYING.txt +30 -30
  4. data/shoes/VERSION.txt +1 -1
  5. data/shoes/freetype6.dll +0 -0
  6. data/shoes/lib/shoes/cache.rb +54 -54
  7. data/shoes/lib/shoes/data.rb +39 -39
  8. data/shoes/lib/shoes/help.rb +421 -421
  9. data/shoes/lib/shoes/image.rb +25 -25
  10. data/shoes/lib/shoes/inspect.rb +128 -128
  11. data/shoes/lib/shoes/log.rb +48 -48
  12. data/shoes/lib/shoes/minitar.rb +986 -986
  13. data/shoes/lib/shoes/override.rb +38 -38
  14. data/shoes/lib/shoes/pack.rb +503 -503
  15. data/shoes/lib/shoes/search.rb +46 -46
  16. data/shoes/lib/shoes/setup.rb +329 -329
  17. data/shoes/lib/shoes/shy.rb +131 -131
  18. data/shoes/lib/shoes/shybuilder.rb +44 -44
  19. data/shoes/lib/shoes.rb +522 -522
  20. data/shoes/libcairo-2.dll +0 -0
  21. data/shoes/libeay32.dll +0 -0
  22. data/shoes/libexpat-1.dll +0 -0
  23. data/shoes/libfontconfig-1.dll +0 -0
  24. data/shoes/libgio-2.0-0.dll +0 -0
  25. data/shoes/libglib-2.0-0.dll +0 -0
  26. data/shoes/libgmodule-2.0-0.dll +0 -0
  27. data/shoes/libgobject-2.0-0.dll +0 -0
  28. data/shoes/libgthread-2.0-0.dll +0 -0
  29. data/shoes/libiconv2.dll +0 -0
  30. data/shoes/libjpeg-8.dll +0 -0
  31. data/shoes/libpango-1.0-0.dll +0 -0
  32. data/shoes/libpangocairo-1.0-0.dll +0 -0
  33. data/shoes/libpangoft2-1.0-0.dll +0 -0
  34. data/shoes/libpangowin32-1.0-0.dll +0 -0
  35. data/shoes/libpng14-14.dll +0 -0
  36. data/shoes/libportaudio-2.dll +0 -0
  37. data/shoes/libshoes.dll +0 -0
  38. data/shoes/libssl32.dll +0 -0
  39. data/shoes/libungif4.dll +0 -0
  40. data/shoes/msvcrt-ruby191.dll +0 -0
  41. data/shoes/nsis/base.nsi +644 -0
  42. data/shoes/nsis/installer-1.bmp +0 -0
  43. data/shoes/nsis/installer-2.bmp +0 -0
  44. data/shoes/nsis/setup.ico +0 -0
  45. data/shoes/nsis/shoes.exe.manifest +17 -0
  46. data/shoes/nsis/shoes.ico +0 -0
  47. data/shoes/nsis/shoes.nsi +644 -0
  48. data/shoes/nsis/stub-inject.c +59 -0
  49. data/shoes/nsis/stub.c +271 -0
  50. data/shoes/nsis/stub32.h +14 -0
  51. data/shoes/nsis/stub32.rc +16 -0
  52. data/shoes/readline5.dll +0 -0
  53. data/shoes/ruby/gems/1.9.1/gems/hpricot-0.8.1/lib/fast_xs.so +0 -0
  54. data/shoes/ruby/gems/1.9.1/gems/hpricot-0.8.1/lib/hpricot/blankslate.rb +63 -63
  55. data/shoes/ruby/gems/1.9.1/gems/hpricot-0.8.1/lib/hpricot/builder.rb +216 -216
  56. data/shoes/ruby/gems/1.9.1/gems/hpricot-0.8.1/lib/hpricot/elements.rb +510 -510
  57. data/shoes/ruby/gems/1.9.1/gems/hpricot-0.8.1/lib/hpricot/htmlinfo.rb +691 -691
  58. data/shoes/ruby/gems/1.9.1/gems/hpricot-0.8.1/lib/hpricot/inspect.rb +103 -103
  59. data/shoes/ruby/gems/1.9.1/gems/hpricot-0.8.1/lib/hpricot/modules.rb +40 -40
  60. data/shoes/ruby/gems/1.9.1/gems/hpricot-0.8.1/lib/hpricot/parse.rb +38 -38
  61. data/shoes/ruby/gems/1.9.1/gems/hpricot-0.8.1/lib/hpricot/tag.rb +202 -202
  62. data/shoes/ruby/gems/1.9.1/gems/hpricot-0.8.1/lib/hpricot/tags.rb +164 -164
  63. data/shoes/ruby/gems/1.9.1/gems/hpricot-0.8.1/lib/hpricot/traverse.rb +838 -838
  64. data/shoes/ruby/gems/1.9.1/gems/hpricot-0.8.1/lib/hpricot/xchar.rb +94 -94
  65. data/shoes/ruby/gems/1.9.1/gems/hpricot-0.8.1/lib/hpricot.rb +26 -26
  66. data/shoes/ruby/gems/1.9.1/gems/hpricot-0.8.1/lib/hpricot_scan.so +0 -0
  67. data/shoes/ruby/gems/1.9.1/gems/json-shoes-1.1.3/lib/json/add/core.rb +135 -135
  68. data/shoes/ruby/gems/1.9.1/gems/json-shoes-1.1.3/lib/json/add/rails.rb +58 -58
  69. data/shoes/ruby/gems/1.9.1/gems/json-shoes-1.1.3/lib/json/common.rb +354 -354
  70. data/shoes/ruby/gems/1.9.1/gems/json-shoes-1.1.3/lib/json/ext/generator.so +0 -0
  71. data/shoes/ruby/gems/1.9.1/gems/json-shoes-1.1.3/lib/json/ext/parser.so +0 -0
  72. data/shoes/ruby/gems/1.9.1/gems/json-shoes-1.1.3/lib/json/ext.rb +13 -13
  73. data/shoes/ruby/gems/1.9.1/gems/json-shoes-1.1.3/lib/json/version.rb +9 -9
  74. data/shoes/ruby/gems/1.9.1/gems/json-shoes-1.1.3/lib/json.rb +8 -8
  75. data/shoes/ruby/gems/1.9.1/gems/sqlite3-ruby-1.2.5-x86-mswin32/lib/sqlite3/constants.rb +49 -49
  76. data/shoes/ruby/gems/1.9.1/gems/sqlite3-ruby-1.2.5-x86-mswin32/lib/sqlite3/database.rb +721 -721
  77. data/shoes/ruby/gems/1.9.1/gems/sqlite3-ruby-1.2.5-x86-mswin32/lib/sqlite3/driver/dl/api.rb +152 -152
  78. data/shoes/ruby/gems/1.9.1/gems/sqlite3-ruby-1.2.5-x86-mswin32/lib/sqlite3/driver/dl/driver.rb +307 -307
  79. data/shoes/ruby/gems/1.9.1/gems/sqlite3-ruby-1.2.5-x86-mswin32/lib/sqlite3/driver/native/driver.rb +219 -219
  80. data/shoes/ruby/gems/1.9.1/gems/sqlite3-ruby-1.2.5-x86-mswin32/lib/sqlite3/errors.rb +68 -68
  81. data/shoes/ruby/gems/1.9.1/gems/sqlite3-ruby-1.2.5-x86-mswin32/lib/sqlite3/pragmas.rb +271 -271
  82. data/shoes/ruby/gems/1.9.1/gems/sqlite3-ruby-1.2.5-x86-mswin32/lib/sqlite3/resultset.rb +180 -180
  83. data/shoes/ruby/gems/1.9.1/gems/sqlite3-ruby-1.2.5-x86-mswin32/lib/sqlite3/statement.rb +231 -231
  84. data/shoes/ruby/gems/1.9.1/gems/sqlite3-ruby-1.2.5-x86-mswin32/lib/sqlite3/translator.rb +109 -109
  85. data/shoes/ruby/gems/1.9.1/gems/sqlite3-ruby-1.2.5-x86-mswin32/lib/sqlite3/value.rb +57 -57
  86. data/shoes/ruby/gems/1.9.1/gems/sqlite3-ruby-1.2.5-x86-mswin32/lib/sqlite3/version.rb +16 -16
  87. data/shoes/ruby/gems/1.9.1/gems/sqlite3-ruby-1.2.5-x86-mswin32/lib/sqlite3.rb +1 -1
  88. data/shoes/ruby/gems/1.9.1/gems/sqlite3-ruby-1.2.5-x86-mswin32/lib/sqlite3_api.so +0 -0
  89. data/shoes/ruby/gems/1.9.1/specifications/hpricot-0.8.1.gemspec +32 -32
  90. data/shoes/ruby/gems/1.9.1/specifications/json-shoes-1.1.3.gemspec +34 -34
  91. data/shoes/ruby/gems/1.9.1/specifications/sqlite3-ruby-1.2.5-x86-mswin32.gemspec +46 -46
  92. data/shoes/ruby/lib/ftsearch/analysis/analyzer.rb +16 -16
  93. data/shoes/ruby/lib/ftsearch/analysis/simple_identifier_analyzer.rb +23 -23
  94. data/shoes/ruby/lib/ftsearch/analysis/whitespace_analyzer.rb +22 -22
  95. data/shoes/ruby/lib/ftsearch/document_map_reader.rb +106 -106
  96. data/shoes/ruby/lib/ftsearch/document_map_writer.rb +46 -46
  97. data/shoes/ruby/lib/ftsearch/field_infos.rb +46 -46
  98. data/shoes/ruby/lib/ftsearch/fragment_writer.rb +114 -114
  99. data/shoes/ruby/lib/ftsearch/fulltext_reader.rb +52 -52
  100. data/shoes/ruby/lib/ftsearch/fulltext_writer.rb +75 -75
  101. data/shoes/ruby/lib/ftsearch/suffix_array_reader.rb +275 -275
  102. data/shoes/ruby/lib/ftsearch/suffix_array_writer.rb +99 -99
  103. data/shoes/ruby/lib/ftsearch/util.rb +21 -21
  104. data/shoes/ruby/lib/i386-mingw32/bigdecimal.so +0 -0
  105. data/shoes/ruby/lib/i386-mingw32/binject.so +0 -0
  106. data/shoes/ruby/lib/i386-mingw32/bloops.so +0 -0
  107. data/shoes/ruby/lib/i386-mingw32/continuation.so +0 -0
  108. data/shoes/ruby/lib/i386-mingw32/coverage.so +0 -0
  109. data/shoes/ruby/lib/i386-mingw32/curses.so +0 -0
  110. data/shoes/ruby/lib/i386-mingw32/digest/bubblebabble.so +0 -0
  111. data/shoes/ruby/lib/i386-mingw32/digest/md5.so +0 -0
  112. data/shoes/ruby/lib/i386-mingw32/digest/rmd160.so +0 -0
  113. data/shoes/ruby/lib/i386-mingw32/digest/sha1.so +0 -0
  114. data/shoes/ruby/lib/i386-mingw32/digest/sha2.so +0 -0
  115. data/shoes/ruby/lib/i386-mingw32/digest.so +0 -0
  116. data/shoes/ruby/lib/i386-mingw32/dl.so +0 -0
  117. data/shoes/ruby/lib/i386-mingw32/enc/big5.so +0 -0
  118. data/shoes/ruby/lib/i386-mingw32/enc/cp949.so +0 -0
  119. data/shoes/ruby/lib/i386-mingw32/enc/emacs_mule.so +0 -0
  120. data/shoes/ruby/lib/i386-mingw32/enc/encdb.so +0 -0
  121. data/shoes/ruby/lib/i386-mingw32/enc/euc_jp.so +0 -0
  122. data/shoes/ruby/lib/i386-mingw32/enc/euc_kr.so +0 -0
  123. data/shoes/ruby/lib/i386-mingw32/enc/euc_tw.so +0 -0
  124. data/shoes/ruby/lib/i386-mingw32/enc/gb18030.so +0 -0
  125. data/shoes/ruby/lib/i386-mingw32/enc/gb2312.so +0 -0
  126. data/shoes/ruby/lib/i386-mingw32/enc/gbk.so +0 -0
  127. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_1.so +0 -0
  128. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_10.so +0 -0
  129. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_11.so +0 -0
  130. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_13.so +0 -0
  131. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_14.so +0 -0
  132. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_15.so +0 -0
  133. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_16.so +0 -0
  134. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_2.so +0 -0
  135. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_3.so +0 -0
  136. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_4.so +0 -0
  137. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_5.so +0 -0
  138. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_6.so +0 -0
  139. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_7.so +0 -0
  140. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_8.so +0 -0
  141. data/shoes/ruby/lib/i386-mingw32/enc/iso_8859_9.so +0 -0
  142. data/shoes/ruby/lib/i386-mingw32/enc/koi8_r.so +0 -0
  143. data/shoes/ruby/lib/i386-mingw32/enc/koi8_u.so +0 -0
  144. data/shoes/ruby/lib/i386-mingw32/enc/shift_jis.so +0 -0
  145. data/shoes/ruby/lib/i386-mingw32/enc/trans/big5.so +0 -0
  146. data/shoes/ruby/lib/i386-mingw32/enc/trans/chinese.so +0 -0
  147. data/shoes/ruby/lib/i386-mingw32/enc/trans/escape.so +0 -0
  148. data/shoes/ruby/lib/i386-mingw32/enc/trans/gb18030.so +0 -0
  149. data/shoes/ruby/lib/i386-mingw32/enc/trans/gbk.so +0 -0
  150. data/shoes/ruby/lib/i386-mingw32/enc/trans/iso2022.so +0 -0
  151. data/shoes/ruby/lib/i386-mingw32/enc/trans/japanese.so +0 -0
  152. data/shoes/ruby/lib/i386-mingw32/enc/trans/japanese_euc.so +0 -0
  153. data/shoes/ruby/lib/i386-mingw32/enc/trans/japanese_sjis.so +0 -0
  154. data/shoes/ruby/lib/i386-mingw32/enc/trans/korean.so +0 -0
  155. data/shoes/ruby/lib/i386-mingw32/enc/trans/single_byte.so +0 -0
  156. data/shoes/ruby/lib/i386-mingw32/enc/trans/transdb.so +0 -0
  157. data/shoes/ruby/lib/i386-mingw32/enc/trans/utf_16_32.so +0 -0
  158. data/shoes/ruby/lib/i386-mingw32/enc/utf_16be.so +0 -0
  159. data/shoes/ruby/lib/i386-mingw32/enc/utf_16le.so +0 -0
  160. data/shoes/ruby/lib/i386-mingw32/enc/utf_32be.so +0 -0
  161. data/shoes/ruby/lib/i386-mingw32/enc/utf_32le.so +0 -0
  162. data/shoes/ruby/lib/i386-mingw32/enc/windows_1251.so +0 -0
  163. data/shoes/ruby/lib/i386-mingw32/etc.so +0 -0
  164. data/shoes/ruby/lib/i386-mingw32/fcntl.so +0 -0
  165. data/shoes/ruby/lib/i386-mingw32/fiber.so +0 -0
  166. data/shoes/ruby/lib/i386-mingw32/ftsearchrt.so +0 -0
  167. data/shoes/ruby/lib/i386-mingw32/gdbm.so +0 -0
  168. data/shoes/ruby/lib/i386-mingw32/iconv.so +0 -0
  169. data/shoes/ruby/lib/i386-mingw32/io/wait.so +0 -0
  170. data/shoes/ruby/lib/i386-mingw32/json/ext/generator.so +0 -0
  171. data/shoes/ruby/lib/i386-mingw32/json/ext/parser.so +0 -0
  172. data/shoes/ruby/lib/i386-mingw32/mathn/complex.so +0 -0
  173. data/shoes/ruby/lib/i386-mingw32/mathn/rational.so +0 -0
  174. data/shoes/ruby/lib/i386-mingw32/nkf.so +0 -0
  175. data/shoes/ruby/lib/i386-mingw32/openssl.so +0 -0
  176. data/shoes/ruby/lib/i386-mingw32/racc/cparse.so +0 -0
  177. data/shoes/ruby/lib/i386-mingw32/rbconfig.rb +2 -2
  178. data/shoes/ruby/lib/i386-mingw32/readline.so +0 -0
  179. data/shoes/ruby/lib/i386-mingw32/ripper.so +0 -0
  180. data/shoes/ruby/lib/i386-mingw32/sdbm.so +0 -0
  181. data/shoes/ruby/lib/i386-mingw32/socket.so +0 -0
  182. data/shoes/ruby/lib/i386-mingw32/stringio.so +0 -0
  183. data/shoes/ruby/lib/i386-mingw32/strscan.so +0 -0
  184. data/shoes/ruby/lib/i386-mingw32/syck.so +0 -0
  185. data/shoes/ruby/lib/i386-mingw32/win32ole.so +0 -0
  186. data/shoes/ruby/lib/i386-mingw32/zlib.so +0 -0
  187. data/shoes/ruby/lib/rbconfig/datadir.rb +24 -24
  188. data/shoes/ruby/lib/rubygems/builder.rb +88 -88
  189. data/shoes/ruby/lib/rubygems/command.rb +406 -406
  190. data/shoes/ruby/lib/rubygems/command_manager.rb +146 -146
  191. data/shoes/ruby/lib/rubygems/commands/build_command.rb +53 -53
  192. data/shoes/ruby/lib/rubygems/commands/cert_command.rb +86 -86
  193. data/shoes/ruby/lib/rubygems/commands/check_command.rb +75 -75
  194. data/shoes/ruby/lib/rubygems/commands/cleanup_command.rb +91 -91
  195. data/shoes/ruby/lib/rubygems/commands/contents_command.rb +74 -74
  196. data/shoes/ruby/lib/rubygems/commands/dependency_command.rb +188 -188
  197. data/shoes/ruby/lib/rubygems/commands/environment_command.rb +128 -128
  198. data/shoes/ruby/lib/rubygems/commands/fetch_command.rb +62 -62
  199. data/shoes/ruby/lib/rubygems/commands/generate_index_command.rb +57 -57
  200. data/shoes/ruby/lib/rubygems/commands/help_command.rb +172 -172
  201. data/shoes/ruby/lib/rubygems/commands/install_command.rb +148 -148
  202. data/shoes/ruby/lib/rubygems/commands/list_command.rb +35 -35
  203. data/shoes/ruby/lib/rubygems/commands/lock_command.rb +110 -110
  204. data/shoes/ruby/lib/rubygems/commands/mirror_command.rb +111 -111
  205. data/shoes/ruby/lib/rubygems/commands/outdated_command.rb +33 -33
  206. data/shoes/ruby/lib/rubygems/commands/pristine_command.rb +93 -93
  207. data/shoes/ruby/lib/rubygems/commands/query_command.rb +233 -233
  208. data/shoes/ruby/lib/rubygems/commands/rdoc_command.rb +82 -82
  209. data/shoes/ruby/lib/rubygems/commands/search_command.rb +37 -37
  210. data/shoes/ruby/lib/rubygems/commands/server_command.rb +48 -48
  211. data/shoes/ruby/lib/rubygems/commands/sources_command.rb +152 -152
  212. data/shoes/ruby/lib/rubygems/commands/specification_command.rb +77 -77
  213. data/shoes/ruby/lib/rubygems/commands/stale_command.rb +27 -27
  214. data/shoes/ruby/lib/rubygems/commands/uninstall_command.rb +73 -73
  215. data/shoes/ruby/lib/rubygems/commands/unpack_command.rb +95 -95
  216. data/shoes/ruby/lib/rubygems/commands/update_command.rb +181 -181
  217. data/shoes/ruby/lib/rubygems/commands/which_command.rb +87 -87
  218. data/shoes/ruby/lib/rubygems/config_file.rb +266 -266
  219. data/shoes/ruby/lib/rubygems/custom_require.rb +46 -46
  220. data/shoes/ruby/lib/rubygems/defaults.rb +89 -89
  221. data/shoes/ruby/lib/rubygems/dependency.rb +119 -119
  222. data/shoes/ruby/lib/rubygems/dependency_installer.rb +258 -258
  223. data/shoes/ruby/lib/rubygems/dependency_list.rb +165 -165
  224. data/shoes/ruby/lib/rubygems/digest/digest_adapter.rb +39 -39
  225. data/shoes/ruby/lib/rubygems/digest/md5.rb +23 -23
  226. data/shoes/ruby/lib/rubygems/digest/sha1.rb +16 -16
  227. data/shoes/ruby/lib/rubygems/digest/sha2.rb +17 -17
  228. data/shoes/ruby/lib/rubygems/doc_manager.rb +214 -214
  229. data/shoes/ruby/lib/rubygems/exceptions.rb +84 -84
  230. data/shoes/ruby/lib/rubygems/ext/builder.rb +56 -56
  231. data/shoes/ruby/lib/rubygems/ext/configure_builder.rb +24 -24
  232. data/shoes/ruby/lib/rubygems/ext/ext_conf_builder.rb +23 -23
  233. data/shoes/ruby/lib/rubygems/ext/rake_builder.rb +27 -27
  234. data/shoes/ruby/lib/rubygems/ext.rb +18 -18
  235. data/shoes/ruby/lib/rubygems/format.rb +87 -87
  236. data/shoes/ruby/lib/rubygems/gem_openssl.rb +83 -83
  237. data/shoes/ruby/lib/rubygems/gem_path_searcher.rb +100 -100
  238. data/shoes/ruby/lib/rubygems/gem_runner.rb +58 -58
  239. data/shoes/ruby/lib/rubygems/indexer.rb +370 -370
  240. data/shoes/ruby/lib/rubygems/install_update_options.rb +113 -113
  241. data/shoes/ruby/lib/rubygems/installer.rb +578 -578
  242. data/shoes/ruby/lib/rubygems/local_remote_options.rb +134 -134
  243. data/shoes/ruby/lib/rubygems/old_format.rb +148 -148
  244. data/shoes/ruby/lib/rubygems/package/f_sync_dir.rb +24 -24
  245. data/shoes/ruby/lib/rubygems/package/tar_header.rb +245 -245
  246. data/shoes/ruby/lib/rubygems/package/tar_input.rb +219 -219
  247. data/shoes/ruby/lib/rubygems/package/tar_output.rb +143 -143
  248. data/shoes/ruby/lib/rubygems/package/tar_reader/entry.rb +99 -99
  249. data/shoes/ruby/lib/rubygems/package/tar_reader.rb +86 -86
  250. data/shoes/ruby/lib/rubygems/package/tar_writer.rb +180 -180
  251. data/shoes/ruby/lib/rubygems/package.rb +95 -95
  252. data/shoes/ruby/lib/rubygems/platform.rb +178 -178
  253. data/shoes/ruby/lib/rubygems/remote_fetcher.rb +344 -344
  254. data/shoes/ruby/lib/rubygems/require_paths_builder.rb +14 -14
  255. data/shoes/ruby/lib/rubygems/requirement.rb +163 -163
  256. data/shoes/ruby/lib/rubygems/rubygems_version.rb +6 -6
  257. data/shoes/ruby/lib/rubygems/security.rb +786 -786
  258. data/shoes/ruby/lib/rubygems/server.rb +629 -629
  259. data/shoes/ruby/lib/rubygems/source_index.rb +559 -559
  260. data/shoes/ruby/lib/rubygems/source_info_cache.rb +393 -393
  261. data/shoes/ruby/lib/rubygems/source_info_cache_entry.rb +56 -56
  262. data/shoes/ruby/lib/rubygems/spec_fetcher.rb +249 -249
  263. data/shoes/ruby/lib/rubygems/specification.rb +1262 -1262
  264. data/shoes/ruby/lib/rubygems/test_utilities.rb +131 -131
  265. data/shoes/ruby/lib/rubygems/timer.rb +25 -25
  266. data/shoes/ruby/lib/rubygems/uninstaller.rb +242 -242
  267. data/shoes/ruby/lib/rubygems/user_interaction.rb +360 -360
  268. data/shoes/ruby/lib/rubygems/validator.rb +208 -208
  269. data/shoes/ruby/lib/rubygems/version.rb +167 -167
  270. data/shoes/ruby/lib/rubygems/version_option.rb +48 -48
  271. data/shoes/ruby/lib/rubygems.rb +888 -888
  272. data/shoes/ruby/lib/ubygems.rb +10 -10
  273. data/shoes/samples/class-book.rb +43 -43
  274. data/shoes/samples/class-book.yaml +387 -387
  275. data/shoes/samples/expert-definr.rb +23 -23
  276. data/shoes/samples/expert-funnies.rb +51 -51
  277. data/shoes/samples/expert-irb.rb +112 -112
  278. data/shoes/samples/expert-minesweeper.rb +267 -267
  279. data/shoes/samples/expert-othello.rb +319 -319
  280. data/shoes/samples/expert-pong.rb +62 -62
  281. data/shoes/samples/expert-tankspank.rb +385 -385
  282. data/shoes/samples/good-arc.rb +37 -37
  283. data/shoes/samples/good-clock.rb +51 -51
  284. data/shoes/samples/good-follow.rb +26 -26
  285. data/shoes/samples/good-reminder.rb +174 -174
  286. data/shoes/samples/good-vjot.rb +56 -56
  287. data/shoes/samples/simple-accordion.rb +75 -75
  288. data/shoes/samples/simple-anim-shapes.rb +17 -17
  289. data/shoes/samples/simple-anim-text.rb +13 -13
  290. data/shoes/samples/simple-arc.rb +23 -23
  291. data/shoes/samples/simple-bounce.rb +24 -24
  292. data/shoes/samples/simple-calc.rb +70 -70
  293. data/shoes/samples/simple-control-sizes.rb +24 -24
  294. data/shoes/samples/simple-curve.rb +26 -26
  295. data/shoes/samples/simple-dialogs.rb +29 -29
  296. data/shoes/samples/simple-downloader.rb +27 -27
  297. data/shoes/samples/simple-draw.rb +13 -13
  298. data/shoes/samples/simple-editor.rb +28 -28
  299. data/shoes/samples/simple-form.rb +28 -28
  300. data/shoes/samples/simple-mask.rb +21 -21
  301. data/shoes/samples/simple-menu.rb +31 -31
  302. data/shoes/samples/simple-menu1.rb +35 -35
  303. data/shoes/samples/simple-rubygems.rb +29 -29
  304. data/shoes/samples/simple-slide.rb +45 -45
  305. data/shoes/samples/simple-sphere.rb +28 -28
  306. data/shoes/samples/simple-timer.rb +13 -13
  307. data/shoes/samples/simple-video.rb +13 -13
  308. data/shoes/shoes.exe +0 -0
  309. data/shoes/sqlite3.dll +0 -0
  310. data/shoes/static/code_highlighter.js +188 -188
  311. data/shoes/static/code_highlighter_ruby.js +26 -26
  312. data/shoes/static/manual-en.txt +2783 -2783
  313. data/shoes/static/manual-ja.txt +2780 -2780
  314. data/shoes/static/manual.css +167 -167
  315. data/shoes/static/stubs/blank.run +375 -375
  316. data/shoes/static/stubs/sh-install +48 -48
  317. data/shoes/zlib.dll +0 -0
  318. data/shoes/zlib1.dll +0 -0
  319. metadata +15 -5
  320. data/shoes/static/Thumbs.db +0 -0
@@ -1,888 +1,888 @@
1
- # -*- ruby -*-
2
- #--
3
- # Copyright 2006 by Chad Fowler, Rich Kilmer, Jim Weirich and others.
4
- # All rights reserved.
5
- # See LICENSE.txt for permissions.
6
- #++
7
-
8
- require 'rubygems/rubygems_version'
9
- require 'rubygems/defaults'
10
- require 'thread'
11
-
12
- module Gem
13
- class LoadError < ::LoadError
14
- attr_accessor :name, :version_requirement
15
- end
16
- end
17
-
18
- module Kernel
19
-
20
- ##
21
- # Use Kernel#gem to activate a specific version of +gem_name+.
22
- #
23
- # +version_requirements+ is a list of version requirements that the
24
- # specified gem must match, most commonly "= example.version.number". See
25
- # Gem::Requirement for how to specify a version requirement.
26
- #
27
- # If you will be activating the latest version of a gem, there is no need to
28
- # call Kernel#gem, Kernel#require will do the right thing for you.
29
- #
30
- # Kernel#gem returns true if the gem was activated, otherwise false. If the
31
- # gem could not be found, didn't match the version requirements, or a
32
- # different version was already activated, an exception will be raised.
33
- #
34
- # Kernel#gem should be called *before* any require statements (otherwise
35
- # RubyGems may load a conflicting library version).
36
- #
37
- # In older RubyGems versions, the environment variable GEM_SKIP could be
38
- # used to skip activation of specified gems, for example to test out changes
39
- # that haven't been installed yet. Now RubyGems defers to -I and the
40
- # RUBYLIB environment variable to skip activation of a gem.
41
- #
42
- # Example:
43
- #
44
- # GEM_SKIP=libA:libB ruby -I../libA -I../libB ./mycode.rb
45
-
46
- def gem(gem_name, *version_requirements) # :doc:
47
- skip_list = (ENV['GEM_SKIP'] || "").split(/:/)
48
- raise Gem::LoadError, "skipping #{gem_name}" if skip_list.include? gem_name
49
- Gem.activate(gem_name, *version_requirements)
50
- end
51
-
52
- private :gem
53
-
54
- end
55
-
56
- ##
57
- # Main module to hold all RubyGem classes/modules.
58
-
59
- module Gem
60
-
61
- ConfigMap = {} unless defined?(ConfigMap)
62
- require 'rbconfig'
63
- RbConfig = Config unless defined? ::RbConfig
64
-
65
- ConfigMap.merge!(
66
- :BASERUBY => RbConfig::CONFIG["BASERUBY"],
67
- :EXEEXT => RbConfig::CONFIG["EXEEXT"],
68
- :RUBY_INSTALL_NAME => RbConfig::CONFIG["RUBY_INSTALL_NAME"],
69
- :RUBY_SO_NAME => RbConfig::CONFIG["RUBY_SO_NAME"],
70
- :arch => RbConfig::CONFIG["arch"],
71
- :bindir => RbConfig::CONFIG["bindir"],
72
- :datadir => RbConfig::CONFIG["datadir"],
73
- :libdir => RbConfig::CONFIG["libdir"],
74
- :ruby_install_name => RbConfig::CONFIG["ruby_install_name"],
75
- :ruby_version => RbConfig::CONFIG["ruby_version"],
76
- :sitedir => RbConfig::CONFIG["sitedir"],
77
- :sitelibdir => RbConfig::CONFIG["sitelibdir"],
78
- :vendordir => RbConfig::CONFIG["vendordir"] ,
79
- :vendorlibdir => RbConfig::CONFIG["vendorlibdir"]
80
- )
81
-
82
- DIRECTORIES = %w[cache doc gems specifications] unless defined?(DIRECTORIES)
83
-
84
- MUTEX = Mutex.new
85
-
86
- RubyGemsPackageVersion = RubyGemsVersion
87
-
88
- ##
89
- # An Array of Regexps that match windows ruby platforms.
90
-
91
- WIN_PATTERNS = [
92
- /bccwin/i,
93
- /cygwin/i,
94
- /djgpp/i,
95
- /mingw/i,
96
- /mswin/i,
97
- /wince/i,
98
- ]
99
-
100
- @@source_index = nil
101
- @@win_platform = nil
102
-
103
- @configuration = nil
104
- @loaded_specs = {}
105
- @platforms = []
106
- @ruby = nil
107
- @sources = []
108
-
109
- @post_install_hooks ||= []
110
- @post_uninstall_hooks ||= []
111
- @pre_uninstall_hooks ||= []
112
- @pre_install_hooks ||= []
113
-
114
- ##
115
- # Activates an installed gem matching +gem+. The gem must satisfy
116
- # +version_requirements+.
117
- #
118
- # Returns true if the gem is activated, false if it is already
119
- # loaded, or an exception otherwise.
120
- #
121
- # Gem#activate adds the library paths in +gem+ to $LOAD_PATH. Before a Gem
122
- # is activated its required Gems are activated. If the version information
123
- # is omitted, the highest version Gem of the supplied name is loaded. If a
124
- # Gem is not found that meets the version requirements or a required Gem is
125
- # not found, a Gem::LoadError is raised.
126
- #
127
- # More information on version requirements can be found in the
128
- # Gem::Requirement and Gem::Version documentation.
129
-
130
- def self.activate(gem, *version_requirements)
131
- if version_requirements.empty? then
132
- version_requirements = Gem::Requirement.default
133
- end
134
-
135
- unless gem.respond_to?(:name) and
136
- gem.respond_to?(:version_requirements) then
137
- gem = Gem::Dependency.new(gem, version_requirements)
138
- end
139
-
140
- matches = Gem.source_index.find_name(gem.name, gem.version_requirements)
141
- report_activate_error(gem) if matches.empty?
142
-
143
- if @loaded_specs[gem.name] then
144
- # This gem is already loaded. If the currently loaded gem is not in the
145
- # list of candidate gems, then we have a version conflict.
146
- existing_spec = @loaded_specs[gem.name]
147
-
148
- unless matches.any? { |spec| spec.version == existing_spec.version } then
149
- raise Gem::Exception,
150
- "can't activate #{gem}, already activated #{existing_spec.full_name}"
151
- end
152
-
153
- return false
154
- end
155
-
156
- # new load
157
- spec = matches.last
158
- return false if spec.loaded?
159
-
160
- spec.loaded = true
161
- @loaded_specs[spec.name] = spec
162
-
163
- # Load dependent gems first
164
- spec.runtime_dependencies.each do |dep_gem|
165
- activate dep_gem
166
- end
167
-
168
- # bin directory must come before library directories
169
- spec.require_paths.unshift spec.bindir if spec.bindir
170
-
171
- require_paths = spec.require_paths.map do |path|
172
- File.join spec.full_gem_path, path
173
- end
174
-
175
- sitelibdir = ConfigMap[:sitelibdir]
176
-
177
- # gem directories must come after -I and ENV['RUBYLIB']
178
- insert_index = load_path_insert_index
179
-
180
- if insert_index then
181
- # gem directories must come after -I and ENV['RUBYLIB']
182
- $LOAD_PATH.insert(insert_index, *require_paths)
183
- else
184
- # we are probably testing in core, -I and RUBYLIB don't apply
185
- $LOAD_PATH.unshift(*require_paths)
186
- end
187
-
188
- return true
189
- end
190
-
191
- ##
192
- # An Array of all possible load paths for all versions of all gems in the
193
- # Gem installation.
194
-
195
- def self.all_load_paths
196
- result = []
197
-
198
- Gem.path.each do |gemdir|
199
- each_load_path all_partials(gemdir) do |load_path|
200
- result << load_path
201
- end
202
- end
203
-
204
- result
205
- end
206
-
207
- ##
208
- # Return all the partial paths in +gemdir+.
209
-
210
- def self.all_partials(gemdir)
211
- Dir[File.join(gemdir, 'gems/*')]
212
- end
213
-
214
- private_class_method :all_partials
215
-
216
- ##
217
- # See if a given gem is available.
218
-
219
- def self.available?(gem, *requirements)
220
- requirements = Gem::Requirement.default if requirements.empty?
221
-
222
- unless gem.respond_to?(:name) and
223
- gem.respond_to?(:version_requirements) then
224
- gem = Gem::Dependency.new gem, requirements
225
- end
226
-
227
- !Gem.source_index.search(gem).empty?
228
- end
229
-
230
- ##
231
- # The mode needed to read a file as straight binary.
232
-
233
- def self.binary_mode
234
- @binary_mode ||= RUBY_VERSION > '1.9' ? 'rb:ascii-8bit' : 'rb'
235
- end
236
-
237
- ##
238
- # The path where gem executables are to be installed.
239
-
240
- def self.bindir(install_dir=Gem.dir)
241
- return File.join(install_dir, 'bin') unless
242
- install_dir.to_s == Gem.default_dir
243
- Gem.default_bindir
244
- end
245
-
246
- ##
247
- # Reset the +dir+ and +path+ values. The next time +dir+ or +path+
248
- # is requested, the values will be calculated from scratch. This is
249
- # mainly used by the unit tests to provide test isolation.
250
-
251
- def self.clear_paths
252
- @gem_home = nil
253
- @gem_path = nil
254
- @user_home = nil
255
-
256
- @@source_index = nil
257
-
258
- MUTEX.synchronize do
259
- @searcher = nil
260
- end
261
- end
262
-
263
- ##
264
- # The path to standard location of the user's .gemrc file.
265
-
266
- def self.config_file
267
- File.join Gem.user_home, '.gemrc'
268
- end
269
-
270
- ##
271
- # The standard configuration object for gems.
272
-
273
- def self.configuration
274
- @configuration ||= Gem::ConfigFile.new []
275
- end
276
-
277
- ##
278
- # Use the given configuration object (which implements the ConfigFile
279
- # protocol) as the standard configuration object.
280
-
281
- def self.configuration=(config)
282
- @configuration = config
283
- end
284
-
285
- ##
286
- # The path the the data directory specified by the gem name. If the
287
- # package is not available as a gem, return nil.
288
-
289
- def self.datadir(gem_name)
290
- spec = @loaded_specs[gem_name]
291
- return nil if spec.nil?
292
- File.join(spec.full_gem_path, 'data', gem_name)
293
- end
294
-
295
- ##
296
- # A Zlib::Deflate.deflate wrapper
297
-
298
- def self.deflate(data)
299
- require 'zlib'
300
- Zlib::Deflate.deflate data
301
- end
302
-
303
- ##
304
- # The path where gems are to be installed.
305
-
306
- def self.dir
307
- @gem_home ||= nil
308
- set_home(ENV['GEM_HOME'] || Gem.configuration.home || default_dir) unless @gem_home
309
- @gem_home
310
- end
311
-
312
- ##
313
- # Expand each partial gem path with each of the required paths specified
314
- # in the Gem spec. Each expanded path is yielded.
315
-
316
- def self.each_load_path(partials)
317
- partials.each do |gp|
318
- base = File.basename(gp)
319
- specfn = File.join(dir, "specifications", base + ".gemspec")
320
- if File.exist?(specfn)
321
- spec = eval(File.read(specfn))
322
- spec.require_paths.each do |rp|
323
- yield(File.join(gp, rp))
324
- end
325
- else
326
- filename = File.join(gp, 'lib')
327
- yield(filename) if File.exist?(filename)
328
- end
329
- end
330
- end
331
-
332
- private_class_method :each_load_path
333
-
334
- ##
335
- # Quietly ensure the named Gem directory contains all the proper
336
- # subdirectories. If we can't create a directory due to a permission
337
- # problem, then we will silently continue.
338
-
339
- def self.ensure_gem_subdirectories(gemdir)
340
- require 'fileutils'
341
-
342
- Gem::DIRECTORIES.each do |filename|
343
- fn = File.join gemdir, filename
344
- FileUtils.mkdir_p fn rescue nil unless File.exist? fn
345
- end
346
- end
347
-
348
- ##
349
- # Returns a list of paths matching +file+ that can be used by a gem to pick
350
- # up features from other gems. For example:
351
- #
352
- # Gem.find_files('rdoc/discover').each do |path| load path end
353
- #
354
- # find_files does not search $LOAD_PATH for files, only gems.
355
-
356
- def self.find_files(path)
357
- specs = searcher.find_all path
358
-
359
- specs.map do |spec|
360
- searcher.matching_files spec, path
361
- end.flatten
362
- end
363
-
364
- ##
365
- # Finds the user's home directory.
366
- #--
367
- # Some comments from the ruby-talk list regarding finding the home
368
- # directory:
369
- #
370
- # I have HOME, USERPROFILE and HOMEDRIVE + HOMEPATH. Ruby seems
371
- # to be depending on HOME in those code samples. I propose that
372
- # it should fallback to USERPROFILE and HOMEDRIVE + HOMEPATH (at
373
- # least on Win32).
374
-
375
- def self.find_home
376
- ['HOME', 'USERPROFILE'].each do |homekey|
377
- return ENV[homekey] if ENV[homekey]
378
- end
379
-
380
- if ENV['HOMEDRIVE'] && ENV['HOMEPATH'] then
381
- return "#{ENV['HOMEDRIVE']}#{ENV['HOMEPATH']}"
382
- end
383
-
384
- begin
385
- File.expand_path("~")
386
- rescue
387
- if File::ALT_SEPARATOR then
388
- "C:/"
389
- else
390
- "/"
391
- end
392
- end
393
- end
394
-
395
- private_class_method :find_home
396
-
397
- ##
398
- # Zlib::GzipReader wrapper that unzips +data+.
399
-
400
- def self.gunzip(data)
401
- require 'stringio'
402
- require 'zlib'
403
- data = StringIO.new data
404
-
405
- Zlib::GzipReader.new(data).read
406
- end
407
-
408
- ##
409
- # Zlib::GzipWriter wrapper that zips +data+.
410
-
411
- def self.gzip(data)
412
- require 'stringio'
413
- require 'zlib'
414
- zipped = StringIO.new
415
-
416
- Zlib::GzipWriter.wrap zipped do |io| io.write data end
417
-
418
- zipped.string
419
- end
420
-
421
- ##
422
- # A Zlib::Inflate#inflate wrapper
423
-
424
- def self.inflate(data)
425
- require 'zlib'
426
- Zlib::Inflate.inflate data
427
- end
428
-
429
- ##
430
- # Return a list of all possible load paths for the latest version for all
431
- # gems in the Gem installation.
432
-
433
- def self.latest_load_paths
434
- result = []
435
-
436
- Gem.path.each do |gemdir|
437
- each_load_path(latest_partials(gemdir)) do |load_path|
438
- result << load_path
439
- end
440
- end
441
-
442
- result
443
- end
444
-
445
- ##
446
- # Return only the latest partial paths in the given +gemdir+.
447
-
448
- def self.latest_partials(gemdir)
449
- latest = {}
450
- all_partials(gemdir).each do |gp|
451
- base = File.basename(gp)
452
- if base =~ /(.*)-((\d+\.)*\d+)/ then
453
- name, version = $1, $2
454
- ver = Gem::Version.new(version)
455
- if latest[name].nil? || ver > latest[name][0]
456
- latest[name] = [ver, gp]
457
- end
458
- end
459
- end
460
- latest.collect { |k,v| v[1] }
461
- end
462
-
463
- private_class_method :latest_partials
464
-
465
- ##
466
- # The index to insert activated gem paths into the $LOAD_PATH.
467
- #
468
- # Defaults to the site lib directory unless gem_prelude.rb has loaded paths,
469
- # then it inserts the activated gem's paths before the gem_prelude.rb paths
470
- # so you can override the gem_prelude.rb default $LOAD_PATH paths.
471
-
472
- def self.load_path_insert_index
473
- index = $LOAD_PATH.index ConfigMap[:sitelibdir]
474
-
475
- $LOAD_PATH.each_with_index do |path, i|
476
- if path.instance_variables.include?(:@gem_prelude_index) or
477
- path.instance_variables.include?('@gem_prelude_index') then
478
- index = i
479
- break
480
- end
481
- end
482
-
483
- index
484
- end
485
-
486
- ##
487
- # The file name and line number of the caller of the caller of this method.
488
-
489
- def self.location_of_caller
490
- caller[1] =~ /(.*?):(\d+)$/i
491
- file = $1
492
- lineno = $2.to_i
493
-
494
- [file, lineno]
495
- end
496
-
497
- ##
498
- # manage_gems is useless and deprecated. Don't call it anymore.
499
-
500
- def self.manage_gems # :nodoc:
501
- file, lineno = location_of_caller
502
-
503
- warn "#{file}:#{lineno}:Warning: Gem::manage_gems is deprecated and will be removed on or after March 2009."
504
- end
505
-
506
- ##
507
- # The version of the Marshal format for your Ruby.
508
-
509
- def self.marshal_version
510
- "#{Marshal::MAJOR_VERSION}.#{Marshal::MINOR_VERSION}"
511
- end
512
-
513
- ##
514
- # Array of paths to search for Gems.
515
-
516
- def self.path
517
- @gem_path ||= nil
518
-
519
- unless @gem_path then
520
- paths = [ENV['GEM_PATH'] || Gem.configuration.path || default_path]
521
-
522
- if defined?(APPLE_GEM_HOME) and not ENV['GEM_PATH'] then
523
- paths << APPLE_GEM_HOME
524
- end
525
-
526
- set_paths paths.compact.join(File::PATH_SEPARATOR)
527
- end
528
-
529
- @gem_path
530
- end
531
-
532
- ##
533
- # Set array of platforms this RubyGems supports (primarily for testing).
534
-
535
- def self.platforms=(platforms)
536
- @platforms = platforms
537
- end
538
-
539
- ##
540
- # Array of platforms this RubyGems supports.
541
-
542
- def self.platforms
543
- @platforms ||= []
544
- if @platforms.empty?
545
- @platforms = [Gem::Platform::RUBY, Gem::Platform.local]
546
- end
547
- @platforms
548
- end
549
-
550
- ##
551
- # Adds a post-install hook that will be passed an Gem::Installer instance
552
- # when Gem::Installer#install is called
553
-
554
- def self.post_install(&hook)
555
- @post_install_hooks << hook
556
- end
557
-
558
- ##
559
- # Adds a post-uninstall hook that will be passed a Gem::Uninstaller instance
560
- # and the spec that was uninstalled when Gem::Uninstaller#uninstall is
561
- # called
562
-
563
- def self.post_uninstall(&hook)
564
- @post_uninstall_hooks << hook
565
- end
566
-
567
- ##
568
- # Adds a pre-install hook that will be passed an Gem::Installer instance
569
- # when Gem::Installer#install is called
570
-
571
- def self.pre_install(&hook)
572
- @pre_install_hooks << hook
573
- end
574
-
575
- ##
576
- # Adds a pre-uninstall hook that will be passed an Gem::Uninstaller instance
577
- # and the spec that will be uninstalled when Gem::Uninstaller#uninstall is
578
- # called
579
-
580
- def self.pre_uninstall(&hook)
581
- @pre_uninstall_hooks << hook
582
- end
583
-
584
- ##
585
- # The directory prefix this RubyGems was installed at.
586
-
587
- def self.prefix
588
- prefix = File.dirname File.expand_path(__FILE__)
589
-
590
- if File.dirname(prefix) == File.expand_path(ConfigMap[:sitelibdir]) or
591
- File.dirname(prefix) == File.expand_path(ConfigMap[:libdir]) or
592
- 'lib' != File.basename(prefix) then
593
- nil
594
- else
595
- File.dirname prefix
596
- end
597
- end
598
-
599
- ##
600
- # Refresh source_index from disk and clear searcher.
601
-
602
- def self.refresh
603
- source_index.refresh!
604
-
605
- MUTEX.synchronize do
606
- @searcher = nil
607
- end
608
- end
609
-
610
- ##
611
- # Safely read a file in binary mode on all platforms.
612
-
613
- def self.read_binary(path)
614
- File.open path, binary_mode do |f| f.read end
615
- end
616
-
617
- ##
618
- # Report a load error during activation. The message of load error
619
- # depends on whether it was a version mismatch or if there are not gems of
620
- # any version by the requested name.
621
-
622
- def self.report_activate_error(gem)
623
- matches = Gem.source_index.find_name(gem.name)
624
-
625
- if matches.empty? then
626
- error = Gem::LoadError.new(
627
- "Could not find RubyGem #{gem.name} (#{gem.version_requirements})\n")
628
- else
629
- error = Gem::LoadError.new(
630
- "RubyGem version error: " +
631
- "#{gem.name}(#{matches.first.version} not #{gem.version_requirements})\n")
632
- end
633
-
634
- error.name = gem.name
635
- error.version_requirement = gem.version_requirements
636
- raise error
637
- end
638
-
639
- private_class_method :report_activate_error
640
-
641
- def self.required_location(gemname, libfile, *version_constraints)
642
- version_constraints = Gem::Requirement.default if version_constraints.empty?
643
- matches = Gem.source_index.find_name(gemname, version_constraints)
644
- return nil if matches.empty?
645
- spec = matches.last
646
- spec.require_paths.each do |path|
647
- result = File.join(spec.full_gem_path, path, libfile)
648
- return result if File.exist?(result)
649
- end
650
- nil
651
- end
652
-
653
- ##
654
- # The path to the running Ruby interpreter.
655
-
656
- def self.ruby
657
- if @ruby.nil? then
658
- @ruby = File.join(ConfigMap[:bindir],
659
- ConfigMap[:ruby_install_name])
660
- @ruby << ConfigMap[:EXEEXT]
661
-
662
- # escape string in case path to ruby executable contain spaces.
663
- @ruby.sub!(/.*\s.*/m, '"\&"')
664
- end
665
-
666
- @ruby
667
- end
668
-
669
- ##
670
- # A Gem::Version for the currently running ruby.
671
-
672
- def self.ruby_version
673
- return @ruby_version if defined? @ruby_version
674
- version = RUBY_VERSION.dup
675
- version << ".#{RUBY_PATCHLEVEL}" if defined? RUBY_PATCHLEVEL
676
- @ruby_version = Gem::Version.new version
677
- end
678
-
679
- ##
680
- # The GemPathSearcher object used to search for matching installed gems.
681
-
682
- def self.searcher
683
- MUTEX.synchronize do
684
- @searcher ||= Gem::GemPathSearcher.new
685
- end
686
- end
687
-
688
- ##
689
- # Set the Gem home directory (as reported by Gem.dir).
690
-
691
- def self.set_home(home)
692
- home = home.gsub(File::ALT_SEPARATOR, File::SEPARATOR) if File::ALT_SEPARATOR
693
- @gem_home = home
694
- ensure_gem_subdirectories(@gem_home)
695
- end
696
-
697
- private_class_method :set_home
698
-
699
- ##
700
- # Set the Gem search path (as reported by Gem.path).
701
-
702
- def self.set_paths(gpaths)
703
- if gpaths
704
- @gem_path = gpaths.split(File::PATH_SEPARATOR)
705
-
706
- if File::ALT_SEPARATOR then
707
- @gem_path.map! do |path|
708
- path.gsub File::ALT_SEPARATOR, File::SEPARATOR
709
- end
710
- end
711
-
712
- @gem_path << Gem.dir
713
- else
714
- # TODO: should this be Gem.default_path instead?
715
- @gem_path = [Gem.dir]
716
- end
717
-
718
- @gem_path.uniq!
719
- @gem_path.each do |path|
720
- if 0 == File.expand_path(path).index(Gem.user_home)
721
- unless win_platform? then
722
- # only create by matching user
723
- next if Etc.getpwuid.uid != File::Stat.new(Gem.user_home).uid
724
- end
725
- end
726
- ensure_gem_subdirectories path
727
- end
728
- end
729
-
730
- private_class_method :set_paths
731
-
732
- ##
733
- # Returns the Gem::SourceIndex of specifications that are in the Gem.path
734
-
735
- def self.source_index
736
- @@source_index ||= SourceIndex.from_installed_gems
737
- end
738
-
739
- ##
740
- # Returns an Array of sources to fetch remote gems from. If the sources
741
- # list is empty, attempts to load the "sources" gem, then uses
742
- # default_sources if it is not installed.
743
-
744
- def self.sources
745
- if @sources.empty? then
746
- begin
747
- gem 'sources', '> 0.0.1'
748
- require 'sources'
749
- rescue LoadError
750
- @sources = default_sources
751
- end
752
- end
753
-
754
- @sources
755
- end
756
-
757
- ##
758
- # Need to be able to set the sources without calling
759
- # Gem.sources.replace since that would cause an infinite loop.
760
-
761
- def self.sources=(new_sources)
762
- @sources = new_sources
763
- end
764
-
765
- ##
766
- # Glob pattern for require-able path suffixes.
767
-
768
- def self.suffix_pattern
769
- @suffix_pattern ||= "{#{suffixes.join(',')}}"
770
- end
771
-
772
- ##
773
- # Suffixes for require-able paths.
774
-
775
- def self.suffixes
776
- ['', '.rb', '.rbw', '.so', '.bundle', '.dll', '.sl', '.jar']
777
- end
778
-
779
- ##
780
- # Use the +home+ and +paths+ values for Gem.dir and Gem.path. Used mainly
781
- # by the unit tests to provide environment isolation.
782
-
783
- def self.use_paths(home, paths=[])
784
- clear_paths
785
- set_home(home) if home
786
- set_paths(paths.join(File::PATH_SEPARATOR)) if paths
787
- end
788
-
789
- ##
790
- # The home directory for the user.
791
-
792
- def self.user_home
793
- @user_home ||= find_home
794
- end
795
-
796
- ##
797
- # Is this a windows platform?
798
-
799
- def self.win_platform?
800
- if @@win_platform.nil? then
801
- @@win_platform = !!WIN_PATTERNS.find { |r| RUBY_PLATFORM =~ r }
802
- end
803
-
804
- @@win_platform
805
- end
806
-
807
- class << self
808
-
809
- attr_reader :loaded_specs
810
-
811
- ##
812
- # The list of hooks to be run before Gem::Install#install does any work
813
-
814
- attr_reader :post_install_hooks
815
-
816
- ##
817
- # The list of hooks to be run before Gem::Uninstall#uninstall does any
818
- # work
819
-
820
- attr_reader :post_uninstall_hooks
821
-
822
- ##
823
- # The list of hooks to be run after Gem::Install#install is finished
824
-
825
- attr_reader :pre_install_hooks
826
-
827
- ##
828
- # The list of hooks to be run after Gem::Uninstall#uninstall is finished
829
-
830
- attr_reader :pre_uninstall_hooks
831
-
832
- # :stopdoc:
833
-
834
- alias cache source_index # an alias for the old name
835
-
836
- # :startdoc:
837
-
838
- end
839
-
840
- MARSHAL_SPEC_DIR = "quick/Marshal.#{Gem.marshal_version}/"
841
-
842
- YAML_SPEC_DIR = 'quick/'
843
-
844
- end
845
-
846
- module Config
847
- # :stopdoc:
848
- class << self
849
- # Return the path to the data directory associated with the named
850
- # package. If the package is loaded as a gem, return the gem
851
- # specific data directory. Otherwise return a path to the share
852
- # area as define by "#{ConfigMap[:datadir]}/#{package_name}".
853
- def datadir(package_name)
854
- Gem.datadir(package_name) ||
855
- File.join(Gem::ConfigMap[:datadir], package_name)
856
- end
857
- end
858
- # :startdoc:
859
- end
860
-
861
- require 'rubygems/exceptions'
862
- require 'rubygems/version'
863
- require 'rubygems/requirement'
864
- require 'rubygems/dependency'
865
- require 'rubygems/gem_path_searcher' # Needed for Kernel#gem
866
- require 'rubygems/source_index' # Needed for Kernel#gem
867
- require 'rubygems/platform'
868
- require 'rubygems/builder' # HACK: Needed for rake's package task.
869
-
870
- begin
871
- require 'rubygems/defaults/operating_system'
872
- rescue LoadError
873
- end
874
-
875
- if defined?(RUBY_ENGINE) then
876
- begin
877
- require "rubygems/defaults/#{RUBY_ENGINE}"
878
- rescue LoadError
879
- end
880
- end
881
-
882
- require 'rubygems/config_file'
883
-
884
- if RUBY_VERSION < '1.9' then
885
- require 'rubygems/custom_require'
886
- end
887
-
888
- Gem.clear_paths
1
+ # -*- ruby -*-
2
+ #--
3
+ # Copyright 2006 by Chad Fowler, Rich Kilmer, Jim Weirich and others.
4
+ # All rights reserved.
5
+ # See LICENSE.txt for permissions.
6
+ #++
7
+
8
+ require 'rubygems/rubygems_version'
9
+ require 'rubygems/defaults'
10
+ require 'thread'
11
+
12
+ module Gem
13
+ class LoadError < ::LoadError
14
+ attr_accessor :name, :version_requirement
15
+ end
16
+ end
17
+
18
+ module Kernel
19
+
20
+ ##
21
+ # Use Kernel#gem to activate a specific version of +gem_name+.
22
+ #
23
+ # +version_requirements+ is a list of version requirements that the
24
+ # specified gem must match, most commonly "= example.version.number". See
25
+ # Gem::Requirement for how to specify a version requirement.
26
+ #
27
+ # If you will be activating the latest version of a gem, there is no need to
28
+ # call Kernel#gem, Kernel#require will do the right thing for you.
29
+ #
30
+ # Kernel#gem returns true if the gem was activated, otherwise false. If the
31
+ # gem could not be found, didn't match the version requirements, or a
32
+ # different version was already activated, an exception will be raised.
33
+ #
34
+ # Kernel#gem should be called *before* any require statements (otherwise
35
+ # RubyGems may load a conflicting library version).
36
+ #
37
+ # In older RubyGems versions, the environment variable GEM_SKIP could be
38
+ # used to skip activation of specified gems, for example to test out changes
39
+ # that haven't been installed yet. Now RubyGems defers to -I and the
40
+ # RUBYLIB environment variable to skip activation of a gem.
41
+ #
42
+ # Example:
43
+ #
44
+ # GEM_SKIP=libA:libB ruby -I../libA -I../libB ./mycode.rb
45
+
46
+ def gem(gem_name, *version_requirements) # :doc:
47
+ skip_list = (ENV['GEM_SKIP'] || "").split(/:/)
48
+ raise Gem::LoadError, "skipping #{gem_name}" if skip_list.include? gem_name
49
+ Gem.activate(gem_name, *version_requirements)
50
+ end
51
+
52
+ private :gem
53
+
54
+ end
55
+
56
+ ##
57
+ # Main module to hold all RubyGem classes/modules.
58
+
59
+ module Gem
60
+
61
+ ConfigMap = {} unless defined?(ConfigMap)
62
+ require 'rbconfig'
63
+ RbConfig = Config unless defined? ::RbConfig
64
+
65
+ ConfigMap.merge!(
66
+ :BASERUBY => RbConfig::CONFIG["BASERUBY"],
67
+ :EXEEXT => RbConfig::CONFIG["EXEEXT"],
68
+ :RUBY_INSTALL_NAME => RbConfig::CONFIG["RUBY_INSTALL_NAME"],
69
+ :RUBY_SO_NAME => RbConfig::CONFIG["RUBY_SO_NAME"],
70
+ :arch => RbConfig::CONFIG["arch"],
71
+ :bindir => RbConfig::CONFIG["bindir"],
72
+ :datadir => RbConfig::CONFIG["datadir"],
73
+ :libdir => RbConfig::CONFIG["libdir"],
74
+ :ruby_install_name => RbConfig::CONFIG["ruby_install_name"],
75
+ :ruby_version => RbConfig::CONFIG["ruby_version"],
76
+ :sitedir => RbConfig::CONFIG["sitedir"],
77
+ :sitelibdir => RbConfig::CONFIG["sitelibdir"],
78
+ :vendordir => RbConfig::CONFIG["vendordir"] ,
79
+ :vendorlibdir => RbConfig::CONFIG["vendorlibdir"]
80
+ )
81
+
82
+ DIRECTORIES = %w[cache doc gems specifications] unless defined?(DIRECTORIES)
83
+
84
+ MUTEX = Mutex.new
85
+
86
+ RubyGemsPackageVersion = RubyGemsVersion
87
+
88
+ ##
89
+ # An Array of Regexps that match windows ruby platforms.
90
+
91
+ WIN_PATTERNS = [
92
+ /bccwin/i,
93
+ /cygwin/i,
94
+ /djgpp/i,
95
+ /mingw/i,
96
+ /mswin/i,
97
+ /wince/i,
98
+ ]
99
+
100
+ @@source_index = nil
101
+ @@win_platform = nil
102
+
103
+ @configuration = nil
104
+ @loaded_specs = {}
105
+ @platforms = []
106
+ @ruby = nil
107
+ @sources = []
108
+
109
+ @post_install_hooks ||= []
110
+ @post_uninstall_hooks ||= []
111
+ @pre_uninstall_hooks ||= []
112
+ @pre_install_hooks ||= []
113
+
114
+ ##
115
+ # Activates an installed gem matching +gem+. The gem must satisfy
116
+ # +version_requirements+.
117
+ #
118
+ # Returns true if the gem is activated, false if it is already
119
+ # loaded, or an exception otherwise.
120
+ #
121
+ # Gem#activate adds the library paths in +gem+ to $LOAD_PATH. Before a Gem
122
+ # is activated its required Gems are activated. If the version information
123
+ # is omitted, the highest version Gem of the supplied name is loaded. If a
124
+ # Gem is not found that meets the version requirements or a required Gem is
125
+ # not found, a Gem::LoadError is raised.
126
+ #
127
+ # More information on version requirements can be found in the
128
+ # Gem::Requirement and Gem::Version documentation.
129
+
130
+ def self.activate(gem, *version_requirements)
131
+ if version_requirements.empty? then
132
+ version_requirements = Gem::Requirement.default
133
+ end
134
+
135
+ unless gem.respond_to?(:name) and
136
+ gem.respond_to?(:version_requirements) then
137
+ gem = Gem::Dependency.new(gem, version_requirements)
138
+ end
139
+
140
+ matches = Gem.source_index.find_name(gem.name, gem.version_requirements)
141
+ report_activate_error(gem) if matches.empty?
142
+
143
+ if @loaded_specs[gem.name] then
144
+ # This gem is already loaded. If the currently loaded gem is not in the
145
+ # list of candidate gems, then we have a version conflict.
146
+ existing_spec = @loaded_specs[gem.name]
147
+
148
+ unless matches.any? { |spec| spec.version == existing_spec.version } then
149
+ raise Gem::Exception,
150
+ "can't activate #{gem}, already activated #{existing_spec.full_name}"
151
+ end
152
+
153
+ return false
154
+ end
155
+
156
+ # new load
157
+ spec = matches.last
158
+ return false if spec.loaded?
159
+
160
+ spec.loaded = true
161
+ @loaded_specs[spec.name] = spec
162
+
163
+ # Load dependent gems first
164
+ spec.runtime_dependencies.each do |dep_gem|
165
+ activate dep_gem
166
+ end
167
+
168
+ # bin directory must come before library directories
169
+ spec.require_paths.unshift spec.bindir if spec.bindir
170
+
171
+ require_paths = spec.require_paths.map do |path|
172
+ File.join spec.full_gem_path, path
173
+ end
174
+
175
+ sitelibdir = ConfigMap[:sitelibdir]
176
+
177
+ # gem directories must come after -I and ENV['RUBYLIB']
178
+ insert_index = load_path_insert_index
179
+
180
+ if insert_index then
181
+ # gem directories must come after -I and ENV['RUBYLIB']
182
+ $LOAD_PATH.insert(insert_index, *require_paths)
183
+ else
184
+ # we are probably testing in core, -I and RUBYLIB don't apply
185
+ $LOAD_PATH.unshift(*require_paths)
186
+ end
187
+
188
+ return true
189
+ end
190
+
191
+ ##
192
+ # An Array of all possible load paths for all versions of all gems in the
193
+ # Gem installation.
194
+
195
+ def self.all_load_paths
196
+ result = []
197
+
198
+ Gem.path.each do |gemdir|
199
+ each_load_path all_partials(gemdir) do |load_path|
200
+ result << load_path
201
+ end
202
+ end
203
+
204
+ result
205
+ end
206
+
207
+ ##
208
+ # Return all the partial paths in +gemdir+.
209
+
210
+ def self.all_partials(gemdir)
211
+ Dir[File.join(gemdir, 'gems/*')]
212
+ end
213
+
214
+ private_class_method :all_partials
215
+
216
+ ##
217
+ # See if a given gem is available.
218
+
219
+ def self.available?(gem, *requirements)
220
+ requirements = Gem::Requirement.default if requirements.empty?
221
+
222
+ unless gem.respond_to?(:name) and
223
+ gem.respond_to?(:version_requirements) then
224
+ gem = Gem::Dependency.new gem, requirements
225
+ end
226
+
227
+ !Gem.source_index.search(gem).empty?
228
+ end
229
+
230
+ ##
231
+ # The mode needed to read a file as straight binary.
232
+
233
+ def self.binary_mode
234
+ @binary_mode ||= RUBY_VERSION > '1.9' ? 'rb:ascii-8bit' : 'rb'
235
+ end
236
+
237
+ ##
238
+ # The path where gem executables are to be installed.
239
+
240
+ def self.bindir(install_dir=Gem.dir)
241
+ return File.join(install_dir, 'bin') unless
242
+ install_dir.to_s == Gem.default_dir
243
+ Gem.default_bindir
244
+ end
245
+
246
+ ##
247
+ # Reset the +dir+ and +path+ values. The next time +dir+ or +path+
248
+ # is requested, the values will be calculated from scratch. This is
249
+ # mainly used by the unit tests to provide test isolation.
250
+
251
+ def self.clear_paths
252
+ @gem_home = nil
253
+ @gem_path = nil
254
+ @user_home = nil
255
+
256
+ @@source_index = nil
257
+
258
+ MUTEX.synchronize do
259
+ @searcher = nil
260
+ end
261
+ end
262
+
263
+ ##
264
+ # The path to standard location of the user's .gemrc file.
265
+
266
+ def self.config_file
267
+ File.join Gem.user_home, '.gemrc'
268
+ end
269
+
270
+ ##
271
+ # The standard configuration object for gems.
272
+
273
+ def self.configuration
274
+ @configuration ||= Gem::ConfigFile.new []
275
+ end
276
+
277
+ ##
278
+ # Use the given configuration object (which implements the ConfigFile
279
+ # protocol) as the standard configuration object.
280
+
281
+ def self.configuration=(config)
282
+ @configuration = config
283
+ end
284
+
285
+ ##
286
+ # The path the the data directory specified by the gem name. If the
287
+ # package is not available as a gem, return nil.
288
+
289
+ def self.datadir(gem_name)
290
+ spec = @loaded_specs[gem_name]
291
+ return nil if spec.nil?
292
+ File.join(spec.full_gem_path, 'data', gem_name)
293
+ end
294
+
295
+ ##
296
+ # A Zlib::Deflate.deflate wrapper
297
+
298
+ def self.deflate(data)
299
+ require 'zlib'
300
+ Zlib::Deflate.deflate data
301
+ end
302
+
303
+ ##
304
+ # The path where gems are to be installed.
305
+
306
+ def self.dir
307
+ @gem_home ||= nil
308
+ set_home(ENV['GEM_HOME'] || Gem.configuration.home || default_dir) unless @gem_home
309
+ @gem_home
310
+ end
311
+
312
+ ##
313
+ # Expand each partial gem path with each of the required paths specified
314
+ # in the Gem spec. Each expanded path is yielded.
315
+
316
+ def self.each_load_path(partials)
317
+ partials.each do |gp|
318
+ base = File.basename(gp)
319
+ specfn = File.join(dir, "specifications", base + ".gemspec")
320
+ if File.exist?(specfn)
321
+ spec = eval(File.read(specfn))
322
+ spec.require_paths.each do |rp|
323
+ yield(File.join(gp, rp))
324
+ end
325
+ else
326
+ filename = File.join(gp, 'lib')
327
+ yield(filename) if File.exist?(filename)
328
+ end
329
+ end
330
+ end
331
+
332
+ private_class_method :each_load_path
333
+
334
+ ##
335
+ # Quietly ensure the named Gem directory contains all the proper
336
+ # subdirectories. If we can't create a directory due to a permission
337
+ # problem, then we will silently continue.
338
+
339
+ def self.ensure_gem_subdirectories(gemdir)
340
+ require 'fileutils'
341
+
342
+ Gem::DIRECTORIES.each do |filename|
343
+ fn = File.join gemdir, filename
344
+ FileUtils.mkdir_p fn rescue nil unless File.exist? fn
345
+ end
346
+ end
347
+
348
+ ##
349
+ # Returns a list of paths matching +file+ that can be used by a gem to pick
350
+ # up features from other gems. For example:
351
+ #
352
+ # Gem.find_files('rdoc/discover').each do |path| load path end
353
+ #
354
+ # find_files does not search $LOAD_PATH for files, only gems.
355
+
356
+ def self.find_files(path)
357
+ specs = searcher.find_all path
358
+
359
+ specs.map do |spec|
360
+ searcher.matching_files spec, path
361
+ end.flatten
362
+ end
363
+
364
+ ##
365
+ # Finds the user's home directory.
366
+ #--
367
+ # Some comments from the ruby-talk list regarding finding the home
368
+ # directory:
369
+ #
370
+ # I have HOME, USERPROFILE and HOMEDRIVE + HOMEPATH. Ruby seems
371
+ # to be depending on HOME in those code samples. I propose that
372
+ # it should fallback to USERPROFILE and HOMEDRIVE + HOMEPATH (at
373
+ # least on Win32).
374
+
375
+ def self.find_home
376
+ ['HOME', 'USERPROFILE'].each do |homekey|
377
+ return ENV[homekey] if ENV[homekey]
378
+ end
379
+
380
+ if ENV['HOMEDRIVE'] && ENV['HOMEPATH'] then
381
+ return "#{ENV['HOMEDRIVE']}#{ENV['HOMEPATH']}"
382
+ end
383
+
384
+ begin
385
+ File.expand_path("~")
386
+ rescue
387
+ if File::ALT_SEPARATOR then
388
+ "C:/"
389
+ else
390
+ "/"
391
+ end
392
+ end
393
+ end
394
+
395
+ private_class_method :find_home
396
+
397
+ ##
398
+ # Zlib::GzipReader wrapper that unzips +data+.
399
+
400
+ def self.gunzip(data)
401
+ require 'stringio'
402
+ require 'zlib'
403
+ data = StringIO.new data
404
+
405
+ Zlib::GzipReader.new(data).read
406
+ end
407
+
408
+ ##
409
+ # Zlib::GzipWriter wrapper that zips +data+.
410
+
411
+ def self.gzip(data)
412
+ require 'stringio'
413
+ require 'zlib'
414
+ zipped = StringIO.new
415
+
416
+ Zlib::GzipWriter.wrap zipped do |io| io.write data end
417
+
418
+ zipped.string
419
+ end
420
+
421
+ ##
422
+ # A Zlib::Inflate#inflate wrapper
423
+
424
+ def self.inflate(data)
425
+ require 'zlib'
426
+ Zlib::Inflate.inflate data
427
+ end
428
+
429
+ ##
430
+ # Return a list of all possible load paths for the latest version for all
431
+ # gems in the Gem installation.
432
+
433
+ def self.latest_load_paths
434
+ result = []
435
+
436
+ Gem.path.each do |gemdir|
437
+ each_load_path(latest_partials(gemdir)) do |load_path|
438
+ result << load_path
439
+ end
440
+ end
441
+
442
+ result
443
+ end
444
+
445
+ ##
446
+ # Return only the latest partial paths in the given +gemdir+.
447
+
448
+ def self.latest_partials(gemdir)
449
+ latest = {}
450
+ all_partials(gemdir).each do |gp|
451
+ base = File.basename(gp)
452
+ if base =~ /(.*)-((\d+\.)*\d+)/ then
453
+ name, version = $1, $2
454
+ ver = Gem::Version.new(version)
455
+ if latest[name].nil? || ver > latest[name][0]
456
+ latest[name] = [ver, gp]
457
+ end
458
+ end
459
+ end
460
+ latest.collect { |k,v| v[1] }
461
+ end
462
+
463
+ private_class_method :latest_partials
464
+
465
+ ##
466
+ # The index to insert activated gem paths into the $LOAD_PATH.
467
+ #
468
+ # Defaults to the site lib directory unless gem_prelude.rb has loaded paths,
469
+ # then it inserts the activated gem's paths before the gem_prelude.rb paths
470
+ # so you can override the gem_prelude.rb default $LOAD_PATH paths.
471
+
472
+ def self.load_path_insert_index
473
+ index = $LOAD_PATH.index ConfigMap[:sitelibdir]
474
+
475
+ $LOAD_PATH.each_with_index do |path, i|
476
+ if path.instance_variables.include?(:@gem_prelude_index) or
477
+ path.instance_variables.include?('@gem_prelude_index') then
478
+ index = i
479
+ break
480
+ end
481
+ end
482
+
483
+ index
484
+ end
485
+
486
+ ##
487
+ # The file name and line number of the caller of the caller of this method.
488
+
489
+ def self.location_of_caller
490
+ caller[1] =~ /(.*?):(\d+)$/i
491
+ file = $1
492
+ lineno = $2.to_i
493
+
494
+ [file, lineno]
495
+ end
496
+
497
+ ##
498
+ # manage_gems is useless and deprecated. Don't call it anymore.
499
+
500
+ def self.manage_gems # :nodoc:
501
+ file, lineno = location_of_caller
502
+
503
+ warn "#{file}:#{lineno}:Warning: Gem::manage_gems is deprecated and will be removed on or after March 2009."
504
+ end
505
+
506
+ ##
507
+ # The version of the Marshal format for your Ruby.
508
+
509
+ def self.marshal_version
510
+ "#{Marshal::MAJOR_VERSION}.#{Marshal::MINOR_VERSION}"
511
+ end
512
+
513
+ ##
514
+ # Array of paths to search for Gems.
515
+
516
+ def self.path
517
+ @gem_path ||= nil
518
+
519
+ unless @gem_path then
520
+ paths = [ENV['GEM_PATH'] || Gem.configuration.path || default_path]
521
+
522
+ if defined?(APPLE_GEM_HOME) and not ENV['GEM_PATH'] then
523
+ paths << APPLE_GEM_HOME
524
+ end
525
+
526
+ set_paths paths.compact.join(File::PATH_SEPARATOR)
527
+ end
528
+
529
+ @gem_path
530
+ end
531
+
532
+ ##
533
+ # Set array of platforms this RubyGems supports (primarily for testing).
534
+
535
+ def self.platforms=(platforms)
536
+ @platforms = platforms
537
+ end
538
+
539
+ ##
540
+ # Array of platforms this RubyGems supports.
541
+
542
+ def self.platforms
543
+ @platforms ||= []
544
+ if @platforms.empty?
545
+ @platforms = [Gem::Platform::RUBY, Gem::Platform.local]
546
+ end
547
+ @platforms
548
+ end
549
+
550
+ ##
551
+ # Adds a post-install hook that will be passed an Gem::Installer instance
552
+ # when Gem::Installer#install is called
553
+
554
+ def self.post_install(&hook)
555
+ @post_install_hooks << hook
556
+ end
557
+
558
+ ##
559
+ # Adds a post-uninstall hook that will be passed a Gem::Uninstaller instance
560
+ # and the spec that was uninstalled when Gem::Uninstaller#uninstall is
561
+ # called
562
+
563
+ def self.post_uninstall(&hook)
564
+ @post_uninstall_hooks << hook
565
+ end
566
+
567
+ ##
568
+ # Adds a pre-install hook that will be passed an Gem::Installer instance
569
+ # when Gem::Installer#install is called
570
+
571
+ def self.pre_install(&hook)
572
+ @pre_install_hooks << hook
573
+ end
574
+
575
+ ##
576
+ # Adds a pre-uninstall hook that will be passed an Gem::Uninstaller instance
577
+ # and the spec that will be uninstalled when Gem::Uninstaller#uninstall is
578
+ # called
579
+
580
+ def self.pre_uninstall(&hook)
581
+ @pre_uninstall_hooks << hook
582
+ end
583
+
584
+ ##
585
+ # The directory prefix this RubyGems was installed at.
586
+
587
+ def self.prefix
588
+ prefix = File.dirname File.expand_path(__FILE__)
589
+
590
+ if File.dirname(prefix) == File.expand_path(ConfigMap[:sitelibdir]) or
591
+ File.dirname(prefix) == File.expand_path(ConfigMap[:libdir]) or
592
+ 'lib' != File.basename(prefix) then
593
+ nil
594
+ else
595
+ File.dirname prefix
596
+ end
597
+ end
598
+
599
+ ##
600
+ # Refresh source_index from disk and clear searcher.
601
+
602
+ def self.refresh
603
+ source_index.refresh!
604
+
605
+ MUTEX.synchronize do
606
+ @searcher = nil
607
+ end
608
+ end
609
+
610
+ ##
611
+ # Safely read a file in binary mode on all platforms.
612
+
613
+ def self.read_binary(path)
614
+ File.open path, binary_mode do |f| f.read end
615
+ end
616
+
617
+ ##
618
+ # Report a load error during activation. The message of load error
619
+ # depends on whether it was a version mismatch or if there are not gems of
620
+ # any version by the requested name.
621
+
622
+ def self.report_activate_error(gem)
623
+ matches = Gem.source_index.find_name(gem.name)
624
+
625
+ if matches.empty? then
626
+ error = Gem::LoadError.new(
627
+ "Could not find RubyGem #{gem.name} (#{gem.version_requirements})\n")
628
+ else
629
+ error = Gem::LoadError.new(
630
+ "RubyGem version error: " +
631
+ "#{gem.name}(#{matches.first.version} not #{gem.version_requirements})\n")
632
+ end
633
+
634
+ error.name = gem.name
635
+ error.version_requirement = gem.version_requirements
636
+ raise error
637
+ end
638
+
639
+ private_class_method :report_activate_error
640
+
641
+ def self.required_location(gemname, libfile, *version_constraints)
642
+ version_constraints = Gem::Requirement.default if version_constraints.empty?
643
+ matches = Gem.source_index.find_name(gemname, version_constraints)
644
+ return nil if matches.empty?
645
+ spec = matches.last
646
+ spec.require_paths.each do |path|
647
+ result = File.join(spec.full_gem_path, path, libfile)
648
+ return result if File.exist?(result)
649
+ end
650
+ nil
651
+ end
652
+
653
+ ##
654
+ # The path to the running Ruby interpreter.
655
+
656
+ def self.ruby
657
+ if @ruby.nil? then
658
+ @ruby = File.join(ConfigMap[:bindir],
659
+ ConfigMap[:ruby_install_name])
660
+ @ruby << ConfigMap[:EXEEXT]
661
+
662
+ # escape string in case path to ruby executable contain spaces.
663
+ @ruby.sub!(/.*\s.*/m, '"\&"')
664
+ end
665
+
666
+ @ruby
667
+ end
668
+
669
+ ##
670
+ # A Gem::Version for the currently running ruby.
671
+
672
+ def self.ruby_version
673
+ return @ruby_version if defined? @ruby_version
674
+ version = RUBY_VERSION.dup
675
+ version << ".#{RUBY_PATCHLEVEL}" if defined? RUBY_PATCHLEVEL
676
+ @ruby_version = Gem::Version.new version
677
+ end
678
+
679
+ ##
680
+ # The GemPathSearcher object used to search for matching installed gems.
681
+
682
+ def self.searcher
683
+ MUTEX.synchronize do
684
+ @searcher ||= Gem::GemPathSearcher.new
685
+ end
686
+ end
687
+
688
+ ##
689
+ # Set the Gem home directory (as reported by Gem.dir).
690
+
691
+ def self.set_home(home)
692
+ home = home.gsub(File::ALT_SEPARATOR, File::SEPARATOR) if File::ALT_SEPARATOR
693
+ @gem_home = home
694
+ ensure_gem_subdirectories(@gem_home)
695
+ end
696
+
697
+ private_class_method :set_home
698
+
699
+ ##
700
+ # Set the Gem search path (as reported by Gem.path).
701
+
702
+ def self.set_paths(gpaths)
703
+ if gpaths
704
+ @gem_path = gpaths.split(File::PATH_SEPARATOR)
705
+
706
+ if File::ALT_SEPARATOR then
707
+ @gem_path.map! do |path|
708
+ path.gsub File::ALT_SEPARATOR, File::SEPARATOR
709
+ end
710
+ end
711
+
712
+ @gem_path << Gem.dir
713
+ else
714
+ # TODO: should this be Gem.default_path instead?
715
+ @gem_path = [Gem.dir]
716
+ end
717
+
718
+ @gem_path.uniq!
719
+ @gem_path.each do |path|
720
+ if 0 == File.expand_path(path).index(Gem.user_home)
721
+ unless win_platform? then
722
+ # only create by matching user
723
+ next if Etc.getpwuid.uid != File::Stat.new(Gem.user_home).uid
724
+ end
725
+ end
726
+ ensure_gem_subdirectories path
727
+ end
728
+ end
729
+
730
+ private_class_method :set_paths
731
+
732
+ ##
733
+ # Returns the Gem::SourceIndex of specifications that are in the Gem.path
734
+
735
+ def self.source_index
736
+ @@source_index ||= SourceIndex.from_installed_gems
737
+ end
738
+
739
+ ##
740
+ # Returns an Array of sources to fetch remote gems from. If the sources
741
+ # list is empty, attempts to load the "sources" gem, then uses
742
+ # default_sources if it is not installed.
743
+
744
+ def self.sources
745
+ if @sources.empty? then
746
+ begin
747
+ gem 'sources', '> 0.0.1'
748
+ require 'sources'
749
+ rescue LoadError
750
+ @sources = default_sources
751
+ end
752
+ end
753
+
754
+ @sources
755
+ end
756
+
757
+ ##
758
+ # Need to be able to set the sources without calling
759
+ # Gem.sources.replace since that would cause an infinite loop.
760
+
761
+ def self.sources=(new_sources)
762
+ @sources = new_sources
763
+ end
764
+
765
+ ##
766
+ # Glob pattern for require-able path suffixes.
767
+
768
+ def self.suffix_pattern
769
+ @suffix_pattern ||= "{#{suffixes.join(',')}}"
770
+ end
771
+
772
+ ##
773
+ # Suffixes for require-able paths.
774
+
775
+ def self.suffixes
776
+ ['', '.rb', '.rbw', '.so', '.bundle', '.dll', '.sl', '.jar']
777
+ end
778
+
779
+ ##
780
+ # Use the +home+ and +paths+ values for Gem.dir and Gem.path. Used mainly
781
+ # by the unit tests to provide environment isolation.
782
+
783
+ def self.use_paths(home, paths=[])
784
+ clear_paths
785
+ set_home(home) if home
786
+ set_paths(paths.join(File::PATH_SEPARATOR)) if paths
787
+ end
788
+
789
+ ##
790
+ # The home directory for the user.
791
+
792
+ def self.user_home
793
+ @user_home ||= find_home
794
+ end
795
+
796
+ ##
797
+ # Is this a windows platform?
798
+
799
+ def self.win_platform?
800
+ if @@win_platform.nil? then
801
+ @@win_platform = !!WIN_PATTERNS.find { |r| RUBY_PLATFORM =~ r }
802
+ end
803
+
804
+ @@win_platform
805
+ end
806
+
807
+ class << self
808
+
809
+ attr_reader :loaded_specs
810
+
811
+ ##
812
+ # The list of hooks to be run before Gem::Install#install does any work
813
+
814
+ attr_reader :post_install_hooks
815
+
816
+ ##
817
+ # The list of hooks to be run before Gem::Uninstall#uninstall does any
818
+ # work
819
+
820
+ attr_reader :post_uninstall_hooks
821
+
822
+ ##
823
+ # The list of hooks to be run after Gem::Install#install is finished
824
+
825
+ attr_reader :pre_install_hooks
826
+
827
+ ##
828
+ # The list of hooks to be run after Gem::Uninstall#uninstall is finished
829
+
830
+ attr_reader :pre_uninstall_hooks
831
+
832
+ # :stopdoc:
833
+
834
+ alias cache source_index # an alias for the old name
835
+
836
+ # :startdoc:
837
+
838
+ end
839
+
840
+ MARSHAL_SPEC_DIR = "quick/Marshal.#{Gem.marshal_version}/"
841
+
842
+ YAML_SPEC_DIR = 'quick/'
843
+
844
+ end
845
+
846
+ module Config
847
+ # :stopdoc:
848
+ class << self
849
+ # Return the path to the data directory associated with the named
850
+ # package. If the package is loaded as a gem, return the gem
851
+ # specific data directory. Otherwise return a path to the share
852
+ # area as define by "#{ConfigMap[:datadir]}/#{package_name}".
853
+ def datadir(package_name)
854
+ Gem.datadir(package_name) ||
855
+ File.join(Gem::ConfigMap[:datadir], package_name)
856
+ end
857
+ end
858
+ # :startdoc:
859
+ end
860
+
861
+ require 'rubygems/exceptions'
862
+ require 'rubygems/version'
863
+ require 'rubygems/requirement'
864
+ require 'rubygems/dependency'
865
+ require 'rubygems/gem_path_searcher' # Needed for Kernel#gem
866
+ require 'rubygems/source_index' # Needed for Kernel#gem
867
+ require 'rubygems/platform'
868
+ require 'rubygems/builder' # HACK: Needed for rake's package task.
869
+
870
+ begin
871
+ require 'rubygems/defaults/operating_system'
872
+ rescue LoadError
873
+ end
874
+
875
+ if defined?(RUBY_ENGINE) then
876
+ begin
877
+ require "rubygems/defaults/#{RUBY_ENGINE}"
878
+ rescue LoadError
879
+ end
880
+ end
881
+
882
+ require 'rubygems/config_file'
883
+
884
+ if RUBY_VERSION < '1.9' then
885
+ require 'rubygems/custom_require'
886
+ end
887
+
888
+ Gem.clear_paths