bundler 1.15.2 → 2.4.12

Sign up to get free protection for your applications and to get access to all the features.
Files changed (424) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGELOG.md +2861 -1117
  3. data/LICENSE.md +18 -19
  4. data/README.md +22 -17
  5. data/bundler.gemspec +23 -27
  6. data/exe/bundle +27 -12
  7. data/exe/bundler +1 -1
  8. data/lib/bundler/.document +1 -0
  9. data/lib/bundler/build_metadata.rb +45 -0
  10. data/lib/bundler/capistrano.rb +7 -2
  11. data/lib/bundler/cli/add.rb +33 -12
  12. data/lib/bundler/cli/binstubs.rb +25 -9
  13. data/lib/bundler/cli/cache.rb +25 -17
  14. data/lib/bundler/cli/check.rb +8 -8
  15. data/lib/bundler/cli/clean.rb +6 -7
  16. data/lib/bundler/cli/common.rb +52 -15
  17. data/lib/bundler/cli/config.rb +171 -86
  18. data/lib/bundler/cli/console.rb +5 -4
  19. data/lib/bundler/cli/doctor.rb +72 -8
  20. data/lib/bundler/cli/exec.rb +13 -29
  21. data/lib/bundler/cli/fund.rb +36 -0
  22. data/lib/bundler/cli/gem.rb +266 -48
  23. data/lib/bundler/cli/info.rb +52 -9
  24. data/lib/bundler/cli/init.rb +22 -6
  25. data/lib/bundler/cli/inject.rb +2 -1
  26. data/lib/bundler/cli/install.rb +74 -99
  27. data/lib/bundler/cli/issue.rb +9 -8
  28. data/lib/bundler/cli/list.rb +66 -0
  29. data/lib/bundler/cli/lock.rb +11 -5
  30. data/lib/bundler/cli/open.rb +14 -9
  31. data/lib/bundler/cli/outdated.rb +165 -123
  32. data/lib/bundler/cli/platform.rb +3 -2
  33. data/lib/bundler/cli/plugin.rb +20 -2
  34. data/lib/bundler/cli/pristine.rb +25 -6
  35. data/lib/bundler/cli/remove.rb +17 -0
  36. data/lib/bundler/cli/show.rb +3 -4
  37. data/lib/bundler/cli/update.rb +71 -12
  38. data/lib/bundler/cli/viz.rb +2 -1
  39. data/lib/bundler/cli.rb +394 -152
  40. data/lib/bundler/compact_index_client/cache.rb +8 -26
  41. data/lib/bundler/compact_index_client/gem_parser.rb +28 -0
  42. data/lib/bundler/compact_index_client/updater.rb +62 -51
  43. data/lib/bundler/compact_index_client.rb +29 -18
  44. data/lib/bundler/constants.rb +2 -1
  45. data/lib/bundler/current_ruby.rb +36 -13
  46. data/lib/bundler/definition.rb +417 -434
  47. data/lib/bundler/dependency.rb +34 -76
  48. data/lib/bundler/deployment.rb +2 -2
  49. data/lib/bundler/deprecate.rb +15 -3
  50. data/lib/bundler/digest.rb +71 -0
  51. data/lib/bundler/dsl.rb +135 -116
  52. data/lib/bundler/endpoint_specification.rb +26 -15
  53. data/lib/bundler/env.rb +95 -39
  54. data/lib/bundler/environment_preserver.rb +56 -8
  55. data/lib/bundler/errors.rb +32 -14
  56. data/lib/bundler/feature_flag.rb +29 -7
  57. data/lib/bundler/fetcher/base.rb +8 -9
  58. data/lib/bundler/fetcher/compact_index.rb +47 -49
  59. data/lib/bundler/fetcher/dependency.rb +5 -8
  60. data/lib/bundler/fetcher/downloader.rb +26 -17
  61. data/lib/bundler/fetcher/index.rb +5 -30
  62. data/lib/bundler/fetcher.rb +51 -46
  63. data/lib/bundler/force_platform.rb +18 -0
  64. data/lib/bundler/friendly_errors.rb +53 -53
  65. data/lib/bundler/gem_helper.rb +95 -50
  66. data/lib/bundler/gem_helpers.rb +45 -28
  67. data/lib/bundler/gem_tasks.rb +2 -1
  68. data/lib/bundler/gem_version_promoter.rb +60 -90
  69. data/lib/bundler/graph.rb +6 -5
  70. data/lib/bundler/index.rb +23 -61
  71. data/lib/bundler/injector.rb +228 -32
  72. data/lib/bundler/inline.rb +29 -32
  73. data/lib/bundler/installer/gem_installer.rb +24 -16
  74. data/lib/bundler/installer/parallel_installer.rb +94 -71
  75. data/lib/bundler/installer/standalone.rb +63 -12
  76. data/lib/bundler/installer.rb +128 -94
  77. data/lib/bundler/lazy_specification.rb +89 -52
  78. data/lib/bundler/lockfile_generator.rb +95 -0
  79. data/lib/bundler/lockfile_parser.rb +40 -66
  80. data/lib/bundler/man/bundle-add.1 +82 -0
  81. data/lib/bundler/man/bundle-add.1.ronn +58 -0
  82. data/lib/bundler/man/bundle-binstubs.1 +42 -0
  83. data/lib/bundler/man/bundle-binstubs.1.ronn +41 -0
  84. data/lib/bundler/man/bundle-cache.1 +61 -0
  85. data/{man/bundle-package.ronn → lib/bundler/man/bundle-cache.1.ronn} +26 -14
  86. data/{man → lib/bundler/man}/bundle-check.1 +4 -4
  87. data/{man/bundle-check.ronn → lib/bundler/man/bundle-check.1.ronn} +3 -3
  88. data/{man → lib/bundler/man}/bundle-clean.1 +2 -2
  89. data/{man/bundle-clean.ronn → lib/bundler/man/bundle-clean.1.ronn} +1 -1
  90. data/{man → lib/bundler/man}/bundle-config.1 +175 -57
  91. data/lib/bundler/man/bundle-config.1.ronn +408 -0
  92. data/lib/bundler/man/bundle-console.1 +53 -0
  93. data/lib/bundler/man/bundle-console.1.ronn +44 -0
  94. data/lib/bundler/man/bundle-doctor.1 +44 -0
  95. data/lib/bundler/man/bundle-doctor.1.ronn +33 -0
  96. data/{man → lib/bundler/man}/bundle-exec.1 +11 -8
  97. data/{man/bundle-exec.ronn → lib/bundler/man/bundle-exec.1.ronn} +16 -9
  98. data/lib/bundler/man/bundle-gem.1 +105 -0
  99. data/lib/bundler/man/bundle-gem.1.ronn +117 -0
  100. data/lib/bundler/man/bundle-help.1 +13 -0
  101. data/lib/bundler/man/bundle-help.1.ronn +12 -0
  102. data/{man → lib/bundler/man}/bundle-info.1 +1 -1
  103. data/lib/bundler/man/bundle-init.1 +29 -0
  104. data/lib/bundler/man/bundle-init.1.ronn +31 -0
  105. data/{man → lib/bundler/man}/bundle-inject.1 +7 -4
  106. data/{man/bundle-inject.ronn → lib/bundler/man/bundle-inject.1.ronn} +5 -3
  107. data/{man → lib/bundler/man}/bundle-install.1 +63 -55
  108. data/{man/bundle-install.ronn → lib/bundler/man/bundle-install.1.ronn} +81 -68
  109. data/lib/bundler/man/bundle-list.1 +50 -0
  110. data/lib/bundler/man/bundle-list.1.ronn +33 -0
  111. data/{man → lib/bundler/man}/bundle-lock.1 +1 -1
  112. data/{man/bundle-lock.ronn → lib/bundler/man/bundle-lock.1.ronn} +1 -1
  113. data/{man → lib/bundler/man}/bundle-open.1 +22 -2
  114. data/{man/bundle-open.ronn → lib/bundler/man/bundle-open.1.ronn} +9 -1
  115. data/{man → lib/bundler/man}/bundle-outdated.1 +8 -11
  116. data/{man/bundle-outdated.ronn → lib/bundler/man/bundle-outdated.1.ronn} +7 -12
  117. data/{man → lib/bundler/man}/bundle-platform.1 +16 -6
  118. data/{man/bundle-platform.ronn → lib/bundler/man/bundle-platform.1.ronn} +14 -7
  119. data/lib/bundler/man/bundle-plugin.1 +81 -0
  120. data/lib/bundler/man/bundle-plugin.1.ronn +59 -0
  121. data/lib/bundler/man/bundle-pristine.1 +34 -0
  122. data/lib/bundler/man/bundle-pristine.1.ronn +34 -0
  123. data/lib/bundler/man/bundle-remove.1 +31 -0
  124. data/lib/bundler/man/bundle-remove.1.ronn +23 -0
  125. data/{man → lib/bundler/man}/bundle-show.1 +3 -3
  126. data/{man/bundle-show.ronn → lib/bundler/man/bundle-show.1.ronn} +3 -2
  127. data/{man → lib/bundler/man}/bundle-update.1 +17 -13
  128. data/{man/bundle-update.ronn → lib/bundler/man/bundle-update.1.ronn} +27 -22
  129. data/lib/bundler/man/bundle-version.1 +35 -0
  130. data/lib/bundler/man/bundle-version.1.ronn +24 -0
  131. data/{man → lib/bundler/man}/bundle-viz.1 +10 -7
  132. data/{man/bundle-viz.ronn → lib/bundler/man/bundle-viz.1.ronn} +8 -6
  133. data/{man → lib/bundler/man}/bundle.1 +44 -31
  134. data/lib/bundler/man/bundle.1.ronn +116 -0
  135. data/{man → lib/bundler/man}/gemfile.5 +153 -83
  136. data/{man → lib/bundler/man}/gemfile.5.ronn +156 -93
  137. data/lib/bundler/man/index.txt +29 -0
  138. data/lib/bundler/match_metadata.rb +13 -0
  139. data/lib/bundler/match_platform.rb +2 -2
  140. data/lib/bundler/match_remote_metadata.rb +29 -0
  141. data/lib/bundler/mirror.rb +16 -15
  142. data/lib/bundler/plugin/api/source.rb +35 -14
  143. data/lib/bundler/plugin/api.rb +1 -1
  144. data/lib/bundler/plugin/dsl.rb +1 -1
  145. data/lib/bundler/plugin/events.rb +61 -0
  146. data/lib/bundler/plugin/index.rb +38 -10
  147. data/lib/bundler/plugin/installer/git.rb +0 -4
  148. data/lib/bundler/plugin/installer/rubygems.rb +1 -9
  149. data/lib/bundler/plugin/installer.rb +35 -18
  150. data/lib/bundler/plugin/source_list.rb +11 -8
  151. data/lib/bundler/plugin.rb +115 -47
  152. data/lib/bundler/process_lock.rb +24 -0
  153. data/lib/bundler/remote_specification.rb +12 -8
  154. data/lib/bundler/resolver/base.rb +107 -0
  155. data/lib/bundler/resolver/candidate.rb +94 -0
  156. data/lib/bundler/resolver/incompatibility.rb +15 -0
  157. data/lib/bundler/resolver/package.rb +72 -0
  158. data/lib/bundler/resolver/root.rb +25 -0
  159. data/lib/bundler/resolver/spec_group.rb +82 -0
  160. data/lib/bundler/resolver.rb +327 -324
  161. data/lib/bundler/retry.rb +5 -4
  162. data/lib/bundler/ruby_dsl.rb +2 -1
  163. data/lib/bundler/ruby_version.rb +11 -38
  164. data/lib/bundler/rubygems_ext.rb +236 -90
  165. data/lib/bundler/rubygems_gem_installer.rb +104 -8
  166. data/lib/bundler/rubygems_integration.rb +204 -501
  167. data/lib/bundler/runtime.rb +35 -48
  168. data/lib/bundler/self_manager.rb +168 -0
  169. data/lib/bundler/settings/validator.rb +102 -0
  170. data/lib/bundler/settings.rb +309 -142
  171. data/lib/bundler/setup.rb +15 -12
  172. data/lib/bundler/shared_helpers.rb +147 -83
  173. data/lib/bundler/similarity_detector.rb +4 -3
  174. data/lib/bundler/source/gemspec.rb +1 -0
  175. data/lib/bundler/source/git/git_proxy.rb +281 -125
  176. data/lib/bundler/source/git.rb +102 -73
  177. data/lib/bundler/source/metadata.rb +62 -0
  178. data/lib/bundler/source/path/installer.rb +13 -32
  179. data/lib/bundler/source/path.rb +36 -25
  180. data/lib/bundler/source/rubygems/remote.rb +9 -4
  181. data/lib/bundler/source/rubygems.rb +273 -226
  182. data/lib/bundler/source/rubygems_aggregate.rb +68 -0
  183. data/lib/bundler/source.rb +65 -9
  184. data/lib/bundler/source_list.rb +138 -33
  185. data/lib/bundler/source_map.rb +71 -0
  186. data/lib/bundler/spec_set.rb +101 -72
  187. data/lib/bundler/stub_specification.rb +45 -36
  188. data/lib/bundler/templates/.document +1 -0
  189. data/lib/bundler/templates/Executable +13 -3
  190. data/lib/bundler/templates/Executable.bundler +109 -0
  191. data/lib/bundler/templates/Executable.standalone +4 -4
  192. data/lib/bundler/templates/Gemfile +1 -2
  193. data/lib/bundler/templates/newgem/CHANGELOG.md.tt +5 -0
  194. data/lib/bundler/templates/newgem/CODE_OF_CONDUCT.md.tt +57 -47
  195. data/lib/bundler/templates/newgem/Cargo.toml.tt +7 -0
  196. data/lib/bundler/templates/newgem/Gemfile.tt +22 -2
  197. data/lib/bundler/templates/newgem/README.md.tt +14 -16
  198. data/lib/bundler/templates/newgem/Rakefile.tt +43 -5
  199. data/lib/bundler/templates/newgem/bin/console.tt +1 -4
  200. data/lib/bundler/templates/newgem/circleci/config.yml.tt +25 -0
  201. data/lib/bundler/templates/newgem/ext/newgem/Cargo.toml.tt +15 -0
  202. data/lib/bundler/templates/newgem/ext/newgem/extconf-c.rb.tt +10 -0
  203. data/lib/bundler/templates/newgem/ext/newgem/extconf-rust.rb.tt +6 -0
  204. data/lib/bundler/templates/newgem/ext/newgem/newgem.c.tt +1 -1
  205. data/lib/bundler/templates/newgem/ext/newgem/src/lib.rs.tt +12 -0
  206. data/lib/bundler/templates/newgem/github/workflows/main.yml.tt +37 -0
  207. data/lib/bundler/templates/newgem/gitignore.tt +3 -1
  208. data/lib/bundler/templates/newgem/gitlab-ci.yml.tt +18 -0
  209. data/lib/bundler/templates/newgem/lib/newgem/version.rb.tt +2 -0
  210. data/lib/bundler/templates/newgem/lib/newgem.rb.tt +5 -2
  211. data/lib/bundler/templates/newgem/newgem.gemspec.tt +39 -35
  212. data/lib/bundler/templates/newgem/rspec.tt +1 -0
  213. data/lib/bundler/templates/newgem/rubocop.yml.tt +13 -0
  214. data/lib/bundler/templates/newgem/sig/newgem.rbs.tt +8 -0
  215. data/lib/bundler/templates/newgem/spec/newgem_spec.rb.tt +1 -1
  216. data/lib/bundler/templates/newgem/spec/spec_helper.rb.tt +2 -1
  217. data/lib/bundler/templates/newgem/standard.yml.tt +3 -0
  218. data/lib/bundler/templates/newgem/test/minitest/test_helper.rb.tt +6 -0
  219. data/lib/bundler/templates/newgem/test/{newgem_test.rb.tt → minitest/test_newgem.rb.tt} +3 -1
  220. data/lib/bundler/templates/newgem/test/test-unit/newgem_test.rb.tt +15 -0
  221. data/lib/bundler/templates/newgem/test/test-unit/test_helper.rb.tt +6 -0
  222. data/lib/bundler/ui/rg_proxy.rb +2 -1
  223. data/lib/bundler/ui/shell.rb +49 -17
  224. data/lib/bundler/ui/silent.rb +22 -5
  225. data/lib/bundler/ui.rb +4 -3
  226. data/lib/bundler/uri_credentials_filter.rb +11 -4
  227. data/lib/bundler/uri_normalizer.rb +23 -0
  228. data/lib/bundler/vendor/.document +1 -0
  229. data/lib/bundler/vendor/connection_pool/LICENSE +20 -0
  230. data/lib/bundler/vendor/connection_pool/lib/connection_pool/timed_stack.rb +174 -0
  231. data/lib/bundler/vendor/connection_pool/lib/connection_pool/version.rb +3 -0
  232. data/lib/bundler/vendor/connection_pool/lib/connection_pool/wrapper.rb +56 -0
  233. data/lib/bundler/vendor/connection_pool/lib/connection_pool.rb +128 -0
  234. data/lib/bundler/vendor/fileutils/LICENSE.txt +22 -0
  235. data/lib/bundler/vendor/fileutils/lib/fileutils.rb +2706 -0
  236. data/lib/bundler/vendor/net-http-persistent/README.rdoc +82 -0
  237. data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent/connection.rb +40 -0
  238. data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent/pool.rb +53 -0
  239. data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent/timed_stack_multi.rb +79 -0
  240. data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent.rb +302 -462
  241. data/lib/bundler/vendor/pub_grub/LICENSE.txt +21 -0
  242. data/lib/bundler/vendor/pub_grub/lib/pub_grub/assignment.rb +20 -0
  243. data/lib/bundler/vendor/pub_grub/lib/pub_grub/basic_package_source.rb +189 -0
  244. data/lib/bundler/vendor/pub_grub/lib/pub_grub/failure_writer.rb +182 -0
  245. data/lib/bundler/vendor/pub_grub/lib/pub_grub/incompatibility.rb +150 -0
  246. data/lib/bundler/vendor/pub_grub/lib/pub_grub/package.rb +43 -0
  247. data/lib/bundler/vendor/pub_grub/lib/pub_grub/partial_solution.rb +121 -0
  248. data/lib/bundler/vendor/pub_grub/lib/pub_grub/rubygems.rb +45 -0
  249. data/lib/bundler/vendor/pub_grub/lib/pub_grub/solve_failure.rb +19 -0
  250. data/lib/bundler/vendor/pub_grub/lib/pub_grub/static_package_source.rb +60 -0
  251. data/lib/bundler/vendor/pub_grub/lib/pub_grub/term.rb +105 -0
  252. data/lib/bundler/vendor/pub_grub/lib/pub_grub/version.rb +3 -0
  253. data/lib/bundler/vendor/pub_grub/lib/pub_grub/version_constraint.rb +129 -0
  254. data/lib/bundler/vendor/pub_grub/lib/pub_grub/version_range.rb +411 -0
  255. data/lib/bundler/vendor/pub_grub/lib/pub_grub/version_solver.rb +243 -0
  256. data/lib/bundler/vendor/pub_grub/lib/pub_grub/version_union.rb +178 -0
  257. data/lib/bundler/vendor/pub_grub/lib/pub_grub.rb +31 -0
  258. data/lib/bundler/vendor/thor/LICENSE.md +20 -0
  259. data/lib/bundler/vendor/thor/lib/thor/actions/create_file.rb +2 -1
  260. data/lib/bundler/vendor/thor/lib/thor/actions/create_link.rb +4 -2
  261. data/lib/bundler/vendor/thor/lib/thor/actions/directory.rb +7 -17
  262. data/lib/bundler/vendor/thor/lib/thor/actions/empty_directory.rb +9 -1
  263. data/lib/bundler/vendor/thor/lib/thor/actions/file_manipulation.rb +64 -16
  264. data/lib/bundler/vendor/thor/lib/thor/actions/inject_into_file.rb +27 -11
  265. data/lib/bundler/vendor/thor/lib/thor/actions.rb +38 -16
  266. data/lib/bundler/vendor/thor/lib/thor/base.rb +84 -41
  267. data/lib/bundler/vendor/thor/lib/thor/command.rb +30 -21
  268. data/lib/bundler/vendor/thor/lib/thor/core_ext/hash_with_indifferent_access.rb +18 -0
  269. data/lib/bundler/vendor/thor/lib/thor/error.rb +83 -0
  270. data/lib/bundler/vendor/thor/lib/thor/group.rb +4 -4
  271. data/lib/bundler/vendor/thor/lib/thor/invocation.rb +1 -0
  272. data/lib/bundler/vendor/thor/lib/thor/line_editor/basic.rb +2 -0
  273. data/lib/bundler/vendor/thor/lib/thor/line_editor/readline.rb +6 -6
  274. data/lib/bundler/vendor/thor/lib/thor/line_editor.rb +2 -2
  275. data/lib/bundler/vendor/thor/lib/thor/nested_context.rb +29 -0
  276. data/lib/bundler/vendor/thor/lib/thor/parser/arguments.rb +7 -3
  277. data/lib/bundler/vendor/thor/lib/thor/parser/option.rb +22 -9
  278. data/lib/bundler/vendor/thor/lib/thor/parser/options.rb +45 -10
  279. data/lib/bundler/vendor/thor/lib/thor/parser.rb +4 -4
  280. data/lib/bundler/vendor/thor/lib/thor/rake_compat.rb +1 -0
  281. data/lib/bundler/vendor/thor/lib/thor/runner.rb +17 -14
  282. data/lib/bundler/vendor/thor/lib/thor/shell/basic.rb +97 -21
  283. data/lib/bundler/vendor/thor/lib/thor/shell/color.rb +10 -2
  284. data/lib/bundler/vendor/thor/lib/thor/shell/html.rb +3 -3
  285. data/lib/bundler/vendor/thor/lib/thor/shell.rb +5 -5
  286. data/lib/bundler/vendor/thor/lib/thor/util.rb +18 -2
  287. data/lib/bundler/vendor/thor/lib/thor/version.rb +1 -1
  288. data/lib/bundler/vendor/thor/lib/thor.rb +39 -15
  289. data/lib/bundler/vendor/tsort/LICENSE.txt +22 -0
  290. data/lib/bundler/vendor/tsort/lib/tsort.rb +452 -0
  291. data/lib/bundler/vendor/uri/LICENSE.txt +22 -0
  292. data/lib/bundler/vendor/uri/lib/uri/common.rb +729 -0
  293. data/lib/bundler/vendor/uri/lib/uri/file.rb +100 -0
  294. data/lib/bundler/vendor/uri/lib/uri/ftp.rb +267 -0
  295. data/lib/bundler/vendor/uri/lib/uri/generic.rb +1587 -0
  296. data/lib/bundler/vendor/uri/lib/uri/http.rb +125 -0
  297. data/lib/bundler/vendor/uri/lib/uri/https.rb +23 -0
  298. data/lib/bundler/vendor/uri/lib/uri/ldap.rb +261 -0
  299. data/lib/bundler/vendor/uri/lib/uri/ldaps.rb +22 -0
  300. data/lib/bundler/vendor/uri/lib/uri/mailto.rb +293 -0
  301. data/lib/bundler/vendor/uri/lib/uri/rfc2396_parser.rb +539 -0
  302. data/lib/bundler/vendor/uri/lib/uri/rfc3986_parser.rb +119 -0
  303. data/lib/bundler/vendor/uri/lib/uri/version.rb +6 -0
  304. data/lib/bundler/vendor/uri/lib/uri/ws.rb +83 -0
  305. data/lib/bundler/vendor/uri/lib/uri/wss.rb +23 -0
  306. data/lib/bundler/vendor/uri/lib/uri.rb +104 -0
  307. data/lib/bundler/vendored_fileutils.rb +4 -0
  308. data/lib/bundler/vendored_persistent.rb +6 -8
  309. data/lib/bundler/{vendored_molinillo.rb → vendored_pub_grub.rb} +2 -1
  310. data/lib/bundler/vendored_thor.rb +3 -2
  311. data/lib/bundler/vendored_tsort.rb +4 -0
  312. data/lib/bundler/vendored_uri.rb +4 -0
  313. data/lib/bundler/version.rb +8 -19
  314. data/lib/bundler/vlad.rb +6 -1
  315. data/lib/bundler/worker.rb +26 -14
  316. data/lib/bundler/yaml_serializer.rb +6 -7
  317. data/lib/bundler.rb +336 -199
  318. metadata +174 -236
  319. data/.codeclimate.yml +0 -25
  320. data/.gitignore +0 -18
  321. data/.rspec +0 -3
  322. data/.rubocop.yml +0 -131
  323. data/.rubocop_todo.yml +0 -418
  324. data/.travis.yml +0 -122
  325. data/CODE_OF_CONDUCT.md +0 -42
  326. data/CONTRIBUTING.md +0 -17
  327. data/Rakefile +0 -338
  328. data/bin/rake +0 -19
  329. data/bin/rspec +0 -15
  330. data/bin/rubocop +0 -17
  331. data/bin/with_rubygems +0 -39
  332. data/doc/README.md +0 -30
  333. data/doc/TROUBLESHOOTING.md +0 -64
  334. data/doc/contributing/BUG_TRIAGE.md +0 -36
  335. data/doc/contributing/COMMUNITY.md +0 -13
  336. data/doc/contributing/GETTING_HELP.md +0 -11
  337. data/doc/contributing/HOW_YOU_CAN_HELP.md +0 -27
  338. data/doc/contributing/ISSUES.md +0 -51
  339. data/doc/contributing/README.md +0 -38
  340. data/doc/development/NEW_FEATURES.md +0 -10
  341. data/doc/development/PULL_REQUESTS.md +0 -40
  342. data/doc/development/README.md +0 -19
  343. data/doc/development/RELEASING.md +0 -9
  344. data/doc/development/SETUP.md +0 -27
  345. data/doc/documentation/README.md +0 -29
  346. data/doc/documentation/VISION.md +0 -26
  347. data/doc/documentation/WRITING.md +0 -54
  348. data/exe/bundle_ruby +0 -59
  349. data/lib/bundler/cli/package.rb +0 -46
  350. data/lib/bundler/dep_proxy.rb +0 -46
  351. data/lib/bundler/gem_remote_fetcher.rb +0 -42
  352. data/lib/bundler/gemdeps.rb +0 -28
  353. data/lib/bundler/psyched_yaml.rb +0 -27
  354. data/lib/bundler/ssl_certs/certificate_manager.rb +0 -65
  355. data/lib/bundler/ssl_certs/index.rubygems.org/GlobalSignRootCA.pem +0 -21
  356. data/lib/bundler/ssl_certs/rubygems.global.ssl.fastly.net/DigiCertHighAssuranceEVRootCA.pem +0 -23
  357. data/lib/bundler/ssl_certs/rubygems.org/AddTrustExternalCARoot.pem +0 -25
  358. data/lib/bundler/templates/newgem/.travis.yml.tt +0 -5
  359. data/lib/bundler/templates/newgem/ext/newgem/extconf.rb.tt +0 -3
  360. data/lib/bundler/templates/newgem/test/test_helper.rb.tt +0 -4
  361. data/lib/bundler/vendor/molinillo/lib/molinillo/delegates/resolution_state.rb +0 -50
  362. data/lib/bundler/vendor/molinillo/lib/molinillo/delegates/specification_provider.rb +0 -80
  363. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/action.rb +0 -35
  364. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb +0 -65
  365. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_vertex.rb +0 -61
  366. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/delete_edge.rb +0 -62
  367. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb +0 -60
  368. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/log.rb +0 -125
  369. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/set_payload.rb +0 -45
  370. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/tag.rb +0 -35
  371. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/vertex.rb +0 -125
  372. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph.rb +0 -222
  373. data/lib/bundler/vendor/molinillo/lib/molinillo/errors.rb +0 -75
  374. data/lib/bundler/vendor/molinillo/lib/molinillo/gem_metadata.rb +0 -5
  375. data/lib/bundler/vendor/molinillo/lib/molinillo/modules/specification_provider.rb +0 -100
  376. data/lib/bundler/vendor/molinillo/lib/molinillo/modules/ui.rb +0 -65
  377. data/lib/bundler/vendor/molinillo/lib/molinillo/resolution.rb +0 -494
  378. data/lib/bundler/vendor/molinillo/lib/molinillo/resolver.rb +0 -45
  379. data/lib/bundler/vendor/molinillo/lib/molinillo/state.rb +0 -54
  380. data/lib/bundler/vendor/molinillo/lib/molinillo.rb +0 -10
  381. data/lib/bundler/vendor/net-http-persistent/lib/net/http/faster.rb +0 -27
  382. data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent/ssl_reuse.rb +0 -129
  383. data/lib/bundler/vendor/thor/lib/thor/core_ext/io_binary_read.rb +0 -12
  384. data/lib/bundler/vendor/thor/lib/thor/core_ext/ordered_hash.rb +0 -129
  385. data/lib/bundler/version_ranges.rb +0 -75
  386. data/man/bundle-add.1 +0 -43
  387. data/man/bundle-add.1.txt +0 -40
  388. data/man/bundle-add.ronn +0 -29
  389. data/man/bundle-binstubs.1 +0 -30
  390. data/man/bundle-binstubs.1.txt +0 -33
  391. data/man/bundle-binstubs.ronn +0 -29
  392. data/man/bundle-check.1.txt +0 -32
  393. data/man/bundle-clean.1.txt +0 -26
  394. data/man/bundle-config.1.txt +0 -418
  395. data/man/bundle-config.ronn +0 -318
  396. data/man/bundle-exec.1.txt +0 -171
  397. data/man/bundle-gem.1 +0 -80
  398. data/man/bundle-gem.1.txt +0 -90
  399. data/man/bundle-gem.ronn +0 -77
  400. data/man/bundle-info.1.txt +0 -21
  401. data/man/bundle-init.1 +0 -20
  402. data/man/bundle-init.1.txt +0 -24
  403. data/man/bundle-init.ronn +0 -18
  404. data/man/bundle-inject.1.txt +0 -32
  405. data/man/bundle-install.1.txt +0 -385
  406. data/man/bundle-lock.1.txt +0 -93
  407. data/man/bundle-open.1.txt +0 -29
  408. data/man/bundle-outdated.1.txt +0 -127
  409. data/man/bundle-package.1 +0 -52
  410. data/man/bundle-package.1.txt +0 -74
  411. data/man/bundle-platform.1.txt +0 -57
  412. data/man/bundle-pristine.1 +0 -16
  413. data/man/bundle-pristine.1.txt +0 -21
  414. data/man/bundle-pristine.ronn +0 -13
  415. data/man/bundle-show.1.txt +0 -25
  416. data/man/bundle-update.1.txt +0 -388
  417. data/man/bundle-viz.1.txt +0 -37
  418. data/man/bundle.1.txt +0 -110
  419. data/man/bundle.ronn +0 -105
  420. data/man/gemfile.5.txt +0 -600
  421. data/man/index.txt +0 -15
  422. data/task/release.rake +0 -116
  423. /data/lib/bundler/{ssl_certs → man}/.document +0 -0
  424. /data/{man/bundle-info.ronn → lib/bundler/man/bundle-info.1.ronn} +0 -0
@@ -1,14 +1,12 @@
1
1
  # frozen_string_literal: true
2
- require "uri"
2
+
3
3
  require "rubygems/user_interaction"
4
4
 
5
5
  module Bundler
6
6
  class Source
7
7
  class Rubygems < Source
8
- autoload :Remote, "bundler/source/rubygems/remote"
8
+ autoload :Remote, File.expand_path("rubygems/remote", __dir__)
9
9
 
10
- # Use the API when installing less than X gems
11
- API_REQUEST_LIMIT = 500
12
10
  # Ask for X gems per API request
13
11
  API_REQUEST_SIZE = 50
14
12
 
@@ -20,17 +18,38 @@ module Bundler
20
18
  @dependency_names = []
21
19
  @allow_remote = false
22
20
  @allow_cached = false
21
+ @allow_local = options["allow_local"] || false
23
22
  @caches = [cache_path, *Bundler.rubygems.gem_cache]
24
23
 
25
- Array(options["remotes"] || []).reverse_each {|r| add_remote(r) }
24
+ Array(options["remotes"]).reverse_each {|r| add_remote(r) }
25
+ end
26
+
27
+ def local_only!
28
+ @specs = nil
29
+ @allow_local = true
30
+ @allow_cached = false
31
+ @allow_remote = false
32
+ end
33
+
34
+ def local!
35
+ return if @allow_local
36
+
37
+ @specs = nil
38
+ @allow_local = true
26
39
  end
27
40
 
28
41
  def remote!
42
+ return if @allow_remote
43
+
29
44
  @specs = nil
30
45
  @allow_remote = true
31
46
  end
32
47
 
33
48
  def cached!
49
+ return if @allow_cached
50
+
51
+ @specs = nil
52
+ @allow_local = true
34
53
  @allow_cached = true
35
54
  end
36
55
 
@@ -48,8 +67,17 @@ module Bundler
48
67
  o.is_a?(Rubygems) && (o.credless_remotes - credless_remotes).empty?
49
68
  end
50
69
 
70
+ def multiple_remotes?
71
+ @remotes.size > 1
72
+ end
73
+
74
+ def no_remotes?
75
+ @remotes.size == 0
76
+ end
77
+
51
78
  def can_lock?(spec)
52
- spec.source.is_a?(Rubygems)
79
+ return super unless multiple_remotes?
80
+ include?(spec.source)
53
81
  end
54
82
 
55
83
  def options
@@ -69,10 +97,29 @@ module Bundler
69
97
  end
70
98
 
71
99
  def to_s
72
- remote_names = remotes.map(&:to_s).join(", ")
73
- "rubygems repository #{remote_names}"
100
+ if remotes.empty?
101
+ "locally installed gems"
102
+ elsif @allow_remote && @allow_cached && @allow_local
103
+ "rubygems repository #{remote_names}, cached gems or installed locally"
104
+ elsif @allow_remote && @allow_local
105
+ "rubygems repository #{remote_names} or installed locally"
106
+ elsif @allow_remote
107
+ "rubygems repository #{remote_names}"
108
+ elsif @allow_cached && @allow_local
109
+ "cached gems or installed locally"
110
+ else
111
+ "locally installed gems"
112
+ end
113
+ end
114
+
115
+ def identifier
116
+ if remotes.empty?
117
+ "locally installed gems"
118
+ else
119
+ "rubygems repository #{remote_names}"
120
+ end
74
121
  end
75
- alias_method :name, :to_s
122
+ alias_method :name, :identifier
76
123
 
77
124
  def specs
78
125
  @specs ||= begin
@@ -81,111 +128,84 @@ module Bundler
81
128
  # small_idx.use large_idx.
82
129
  idx = @allow_remote ? remote_specs.dup : Index.new
83
130
  idx.use(cached_specs, :override_dupes) if @allow_cached || @allow_remote
84
- idx.use(installed_specs, :override_dupes)
131
+ idx.use(installed_specs, :override_dupes) if @allow_local
85
132
  idx
86
133
  end
87
134
  end
88
135
 
89
- def install(spec, opts = {})
90
- force = opts[:force]
91
- ensure_builtin_gems_cached = opts[:ensure_builtin_gems_cached]
136
+ def install(spec, options = {})
137
+ force = options[:force]
138
+ ensure_builtin_gems_cached = options[:ensure_builtin_gems_cached]
92
139
 
93
- if ensure_builtin_gems_cached && builtin_gem?(spec)
94
- if !cached_path(spec)
95
- cached_built_in_gem(spec) unless spec.remote
96
- force = true
97
- else
98
- spec.loaded_from = loaded_from(spec)
99
- end
140
+ if ensure_builtin_gems_cached && spec.default_gem? && !cached_path(spec)
141
+ cached_built_in_gem(spec) unless spec.remote
142
+ force = true
100
143
  end
101
144
 
102
- if installed?(spec) && (!force || spec.name.eql?("bundler"))
103
- Bundler.ui.info "Using #{version_message(spec)}"
145
+ if installed?(spec) && !force
146
+ print_using_message "Using #{version_message(spec, options[:previous_spec])}"
104
147
  return nil # no post-install message
105
148
  end
106
149
 
107
- # Download the gem to get the spec, because some specs that are returned
108
- # by rubygems.org are broken and wrong.
109
150
  if spec.remote
110
151
  # Check for this spec from other sources
111
- uris = [spec.remote.anonymized_uri]
112
- uris += remotes_for_spec(spec).map(&:anonymized_uri)
113
- uris.uniq!
152
+ uris = [spec.remote, *remotes_for_spec(spec)].map(&:anonymized_uri).uniq
114
153
  Installer.ambiguous_gems << [spec.name, *uris] if uris.length > 1
115
-
116
- s = Bundler.rubygems.spec_from_gem(fetch_gem(spec), Bundler.settings["trust-policy"])
117
- spec.__swap__(s)
118
154
  end
119
155
 
120
- unless Bundler.settings[:no_install]
121
- message = "Installing #{version_message(spec)}"
122
- message += " with native extensions" if spec.extensions.any?
123
- Bundler.ui.confirm message
156
+ path = fetch_gem_if_possible(spec, options[:previous_spec])
157
+ raise GemNotFound, "Could not find #{spec.file_name} for installation" unless path
124
158
 
125
- path = cached_gem(spec)
126
- if requires_sudo?
127
- install_path = Bundler.tmp(spec.full_name)
128
- bin_path = install_path.join("bin")
129
- else
130
- install_path = rubygems_dir
131
- bin_path = Bundler.system_bindir
132
- end
159
+ return if Bundler.settings[:no_install]
133
160
 
134
- installed_spec = nil
135
- Bundler.rubygems.preserve_paths do
136
- installed_spec = Bundler::RubyGemsGemInstaller.at(
137
- path,
138
- :install_dir => install_path.to_s,
139
- :bin_dir => bin_path.to_s,
140
- :ignore_dependencies => true,
141
- :wrappers => true,
142
- :env_shebang => true,
143
- :build_args => opts[:build_args],
144
- :bundler_expected_checksum => spec.respond_to?(:checksum) && spec.checksum
145
- ).install
146
- end
147
- spec.full_gem_path = installed_spec.full_gem_path
148
-
149
- # SUDO HAX
150
- if requires_sudo?
151
- Bundler.rubygems.repository_subdirectories.each do |name|
152
- src = File.join(install_path, name, "*")
153
- dst = File.join(rubygems_dir, name)
154
- if name == "extensions" && Dir.glob(src).any?
155
- src = File.join(src, "*/*")
156
- ext_src = Dir.glob(src).first
157
- ext_src.gsub!(src[0..-6], "")
158
- dst = File.dirname(File.join(dst, ext_src))
159
- end
160
- SharedHelpers.filesystem_access(dst) do |p|
161
- Bundler.mkdir_p(p)
162
- end
163
- Bundler.sudo "cp -R #{src} #{dst}" if Dir[src].any?
164
- end
161
+ install_path = rubygems_dir
162
+ bin_path = Bundler.system_bindir
165
163
 
166
- spec.executables.each do |exe|
167
- SharedHelpers.filesystem_access(Bundler.system_bindir) do |p|
168
- Bundler.mkdir_p(p)
169
- end
170
- Bundler.sudo "cp -R #{install_path}/bin/#{exe} #{Bundler.system_bindir}/"
171
- end
164
+ require_relative "../rubygems_gem_installer"
165
+
166
+ installer = Bundler::RubyGemsGemInstaller.at(
167
+ path,
168
+ :security_policy => Bundler.rubygems.security_policies[Bundler.settings["trust-policy"]],
169
+ :install_dir => install_path.to_s,
170
+ :bin_dir => bin_path.to_s,
171
+ :ignore_dependencies => true,
172
+ :wrappers => true,
173
+ :env_shebang => true,
174
+ :build_args => options[:build_args],
175
+ :bundler_expected_checksum => spec.respond_to?(:checksum) && spec.checksum,
176
+ :bundler_extension_cache_path => extension_cache_path(spec)
177
+ )
178
+
179
+ if spec.remote
180
+ s = begin
181
+ installer.spec
182
+ rescue Gem::Package::FormatError
183
+ Bundler.rm_rf(path)
184
+ raise
185
+ rescue Gem::Security::Exception => e
186
+ raise SecurityError,
187
+ "The gem #{File.basename(path, ".gem")} can't be installed because " \
188
+ "the security policy didn't allow it, with the message: #{e.message}"
172
189
  end
173
- installed_spec.loaded_from = loaded_from(spec)
190
+
191
+ spec.__swap__(s)
174
192
  end
175
- spec.loaded_from = loaded_from(spec)
193
+
194
+ message = "Installing #{version_message(spec, options[:previous_spec])}"
195
+ message += " with native extensions" if spec.extensions.any?
196
+ Bundler.ui.confirm message
197
+
198
+ installed_spec = installer.install
199
+
200
+ spec.full_gem_path = installed_spec.full_gem_path
201
+ spec.loaded_from = installed_spec.loaded_from
176
202
 
177
203
  spec.post_install_message
178
- ensure
179
- Bundler.rm_rf(install_path) if requires_sudo?
180
204
  end
181
205
 
182
206
  def cache(spec, custom_path = nil)
183
- if builtin_gem?(spec)
184
- cached_path = cached_built_in_gem(spec)
185
- else
186
- cached_path = cached_gem(spec)
187
- end
188
- raise GemNotFound, "Missing gem file '#{spec.full_name}.gem'." unless cached_path
207
+ cached_path = Bundler.settings[:cache_all_platforms] ? fetch_gem_if_possible(spec) : cached_gem(spec)
208
+ raise GemNotFound, "Missing gem file '#{spec.file_name}'." unless cached_path
189
209
  return if File.dirname(cached_path) == Bundler.app_cache.to_s
190
210
  Bundler.ui.info " * #{File.basename(cached_path)}"
191
211
  FileUtils.cp(cached_path, Bundler.app_cache(custom_path))
@@ -212,17 +232,16 @@ module Bundler
212
232
  @remotes.unshift(uri) unless @remotes.include?(uri)
213
233
  end
214
234
 
215
- def replace_remotes(other_remotes)
216
- return false if other_remotes == @remotes
217
-
218
- @remotes = []
219
- other_remotes.reverse_each do |r|
220
- add_remote r.to_s
235
+ def spec_names
236
+ if @allow_remote && dependency_api_available?
237
+ remote_specs.spec_names
238
+ else
239
+ []
221
240
  end
222
241
  end
223
242
 
224
243
  def unmet_deps
225
- if @allow_remote && api_fetchers.any?
244
+ if @allow_remote && dependency_api_available?
226
245
  remote_specs.unmet_dependency_names
227
246
  else
228
247
  []
@@ -236,10 +255,56 @@ module Bundler
236
255
  end
237
256
  end
238
257
 
239
- protected
258
+ def double_check_for(unmet_dependency_names)
259
+ return unless @allow_remote
260
+ return unless dependency_api_available?
261
+
262
+ unmet_dependency_names = unmet_dependency_names.call
263
+ unless unmet_dependency_names.nil?
264
+ if api_fetchers.size <= 1
265
+ # can't do this when there are multiple fetchers because then we might not fetch from _all_
266
+ # of them
267
+ unmet_dependency_names -= remote_specs.spec_names # avoid re-fetching things we've already gotten
268
+ end
269
+ return if unmet_dependency_names.empty?
270
+ end
271
+
272
+ Bundler.ui.debug "Double checking for #{unmet_dependency_names || "all specs (due to the size of the request)"} in #{self}"
273
+
274
+ fetch_names(api_fetchers, unmet_dependency_names, specs, false)
275
+ end
276
+
277
+ def dependency_names_to_double_check
278
+ names = []
279
+ remote_specs.each do |spec|
280
+ case spec
281
+ when EndpointSpecification, Gem::Specification, StubSpecification, LazySpecification
282
+ names.concat(spec.runtime_dependencies.map(&:name))
283
+ when RemoteSpecification # from the full index
284
+ return nil
285
+ else
286
+ raise "unhandled spec type (#{spec.inspect})"
287
+ end
288
+ end
289
+ names
290
+ end
291
+
292
+ def dependency_api_available?
293
+ @allow_remote && api_fetchers.any?
294
+ end
295
+
296
+ protected
297
+
298
+ def remote_names
299
+ remotes.map(&:to_s).join(", ")
300
+ end
240
301
 
241
302
  def credless_remotes
242
- remotes.map(&method(:suppress_configured_credentials))
303
+ if Bundler.settings[:allow_deployment_source_credential_changes]
304
+ remotes.map(&method(:remove_auth))
305
+ else
306
+ remotes.map(&method(:suppress_configured_credentials))
307
+ end
243
308
  end
244
309
 
245
310
  def remotes_for_spec(spec)
@@ -249,34 +314,37 @@ module Bundler
249
314
  end
250
315
  end
251
316
 
252
- def loaded_from(spec)
253
- "#{rubygems_dir}/specifications/#{spec.full_name}.gemspec"
254
- end
255
-
256
317
  def cached_gem(spec)
257
- cached_gem = cached_path(spec)
258
- unless cached_gem
259
- raise Bundler::GemNotFound, "Could not find #{spec.file_name} for installation"
318
+ if spec.default_gem?
319
+ cached_built_in_gem(spec)
320
+ else
321
+ cached_path(spec)
260
322
  end
261
- cached_gem
262
323
  end
263
324
 
264
325
  def cached_path(spec)
265
- possibilities = @caches.map {|p| "#{p}/#{spec.file_name}" }
326
+ global_cache_path = download_cache_path(spec)
327
+ @caches << global_cache_path if global_cache_path
328
+
329
+ possibilities = @caches.map {|p| package_path(p, spec) }
266
330
  possibilities.find {|p| File.exist?(p) }
267
331
  end
268
332
 
333
+ def package_path(cache_path, spec)
334
+ "#{cache_path}/#{spec.file_name}"
335
+ end
336
+
269
337
  def normalize_uri(uri)
270
- uri = uri.to_s
271
- uri = "#{uri}/" unless uri =~ %r{/$}
272
- uri = URI(uri)
338
+ uri = URINormalizer.normalize_suffix(uri.to_s)
339
+ require_relative "../vendored_uri"
340
+ uri = Bundler::URI(uri)
273
341
  raise ArgumentError, "The source must be an absolute URI. For example:\n" \
274
- "source 'https://rubygems.org'" if !uri.absolute? || (uri.is_a?(URI::HTTP) && uri.host.nil?)
342
+ "source 'https://rubygems.org'" if !uri.absolute? || (uri.is_a?(Bundler::URI::HTTP) && uri.host.nil?)
275
343
  uri
276
344
  end
277
345
 
278
346
  def suppress_configured_credentials(remote)
279
- remote_nouser = remote.dup.tap {|uri| uri.user = uri.password = nil }.to_s
347
+ remote_nouser = remove_auth(remote)
280
348
  if remote.userinfo && remote.userinfo == Bundler.settings[remote_nouser]
281
349
  remote_nouser
282
350
  else
@@ -284,15 +352,17 @@ module Bundler
284
352
  end
285
353
  end
286
354
 
355
+ def remove_auth(remote)
356
+ if remote.user || remote.password
357
+ remote.dup.tap {|uri| uri.user = uri.password = nil }.to_s
358
+ else
359
+ remote.to_s
360
+ end
361
+ end
362
+
287
363
  def installed_specs
288
- @installed_specs ||= begin
289
- idx = Index.new
290
- have_bundler = false
364
+ @installed_specs ||= Index.build do |idx|
291
365
  Bundler.rubygems.all_specs.reverse_each do |spec|
292
- if spec.name == "bundler"
293
- next unless spec.version.to_s == VERSION
294
- have_bundler = true
295
- end
296
366
  spec.source = self
297
367
  if Bundler.rubygems.spec_missing_extensions?(spec, false)
298
368
  Bundler.ui.debug "Source #{self} is ignoring #{spec} because it is missing extensions"
@@ -300,43 +370,22 @@ module Bundler
300
370
  end
301
371
  idx << spec
302
372
  end
303
-
304
- # Always have bundler locally
305
- unless have_bundler
306
- # We're running bundler directly from the source
307
- # so, let's create a fake gemspec for it (it's a path)
308
- # gemspec
309
- bundler = Gem::Specification.new do |s|
310
- s.name = "bundler"
311
- s.version = VERSION
312
- s.platform = Gem::Platform::RUBY
313
- s.source = self
314
- s.authors = ["bundler team"]
315
- s.loaded_from = File.expand_path("..", __FILE__)
316
- end
317
- idx << bundler
318
- end
319
- idx
320
373
  end
321
374
  end
322
375
 
323
376
  def cached_specs
324
377
  @cached_specs ||= begin
325
- idx = installed_specs.dup
378
+ idx = @allow_local ? installed_specs.dup : Index.new
326
379
 
327
380
  Dir["#{cache_path}/*.gem"].each do |gemfile|
328
- next if gemfile =~ /^bundler\-[\d\.]+?\.gem/
381
+ next if /^bundler\-[\d\.]+?\.gem/.match?(gemfile)
329
382
  s ||= Bundler.rubygems.spec_from_gem(gemfile)
330
383
  s.source = self
331
- if Bundler.rubygems.spec_missing_extensions?(s, false)
332
- Bundler.ui.debug "Source #{self} is ignoring #{s} because it is missing extensions"
333
- next
334
- end
335
384
  idx << s
336
385
  end
337
- end
338
386
 
339
- idx
387
+ idx
388
+ end
340
389
  end
341
390
 
342
391
  def api_fetchers
@@ -348,115 +397,113 @@ module Bundler
348
397
  index_fetchers = fetchers - api_fetchers
349
398
 
350
399
  # gather lists from non-api sites
351
- index_fetchers.each do |f|
352
- Bundler.ui.info "Fetching source index from #{f.uri}"
353
- idx.use f.specs_with_retry(nil, self)
354
- end
400
+ fetch_names(index_fetchers, nil, idx, false)
355
401
 
356
- # because ensuring we have all the gems we need involves downloading
357
- # the gemspecs of those gems, if the non-api sites contain more than
358
- # about 100 gems, we treat all sites as non-api for speed.
359
- allow_api = idx.size < API_REQUEST_LIMIT && dependency_names.size < API_REQUEST_LIMIT
360
- Bundler.ui.debug "Need to query more than #{API_REQUEST_LIMIT} gems." \
361
- " Downloading full index instead..." unless allow_api
362
-
363
- if allow_api
364
- api_fetchers.each do |f|
365
- Bundler.ui.info "Fetching gem metadata from #{f.uri}", Bundler.ui.debug?
366
- idx.use f.specs_with_retry(dependency_names, self)
367
- Bundler.ui.info "" unless Bundler.ui.debug? # new line now that the dots are over
368
- end
402
+ # legacy multi-remote sources need special logic to figure out
403
+ # dependency names and that logic can be very costly if one remote
404
+ # uses the dependency API but others don't. So use full indexes
405
+ # consistently in that particular case.
406
+ allow_api = !multiple_remotes?
369
407
 
370
- # Suppose the gem Foo depends on the gem Bar. Foo exists in Source A. Bar has some versions that exist in both
371
- # sources A and B. At this point, the API request will have found all the versions of Bar in source A,
372
- # but will not have found any versions of Bar from source B, which is a problem if the requested version
373
- # of Foo specifically depends on a version of Bar that is only found in source B. This ensures that for
374
- # each spec we found, we add all possible versions from all sources to the index.
375
- loop do
376
- idxcount = idx.size
377
- api_fetchers.each do |f|
378
- Bundler.ui.info "Fetching version metadata from #{f.uri}", Bundler.ui.debug?
379
- idx.use f.specs_with_retry(idx.dependency_names, self), true
380
- Bundler.ui.info "" unless Bundler.ui.debug? # new line now that the dots are over
381
- end
382
- break if idxcount == idx.size
383
- end
408
+ fetch_names(api_fetchers, allow_api && dependency_names, idx, false)
409
+ end
410
+ end
384
411
 
385
- if api_fetchers.any?
386
- # it's possible that gems from one source depend on gems from some
387
- # other source, so now we download gemspecs and iterate over those
388
- # dependencies, looking for gems we don't have info on yet.
389
- unmet = idx.unmet_dependency_names
390
-
391
- # if there are any cross-site gems we missed, get them now
392
- api_fetchers.each do |f|
393
- Bundler.ui.info "Fetching dependency metadata from #{f.uri}", Bundler.ui.debug?
394
- idx.use f.specs_with_retry(unmet, self)
395
- Bundler.ui.info "" unless Bundler.ui.debug? # new line now that the dots are over
396
- end if unmet.any?
397
- else
398
- allow_api = false
399
- end
412
+ def fetch_names(fetchers, dependency_names, index, override_dupes)
413
+ fetchers.each do |f|
414
+ if dependency_names
415
+ Bundler.ui.info "Fetching gem metadata from #{URICredentialsFilter.credential_filtered_uri(f.uri)}", Bundler.ui.debug?
416
+ index.use f.specs_with_retry(dependency_names, self), override_dupes
417
+ Bundler.ui.info "" unless Bundler.ui.debug? # new line now that the dots are over
418
+ else
419
+ Bundler.ui.info "Fetching source index from #{URICredentialsFilter.credential_filtered_uri(f.uri)}"
420
+ index.use f.specs_with_retry(nil, self), override_dupes
400
421
  end
422
+ end
423
+ end
401
424
 
402
- unless allow_api
403
- api_fetchers.each do |f|
404
- Bundler.ui.info "Fetching source index from #{f.uri}"
405
- idx.use f.specs_with_retry(nil, self)
406
- end
407
- end
425
+ def fetch_gem_if_possible(spec, previous_spec = nil)
426
+ if spec.remote
427
+ fetch_gem(spec, previous_spec)
428
+ else
429
+ cached_gem(spec)
408
430
  end
409
431
  end
410
432
 
411
- def fetch_gem(spec)
412
- return false unless spec.remote
413
- uri = spec.remote.uri
433
+ def fetch_gem(spec, previous_spec = nil)
414
434
  spec.fetch_platform
415
- Bundler.ui.confirm("Fetching #{version_message(spec)}")
416
435
 
417
- download_path = requires_sudo? ? Bundler.tmp(spec.full_name) : rubygems_dir
418
- gem_path = "#{rubygems_dir}/cache/#{spec.full_name}.gem"
436
+ cache_path = download_cache_path(spec) || default_cache_path_for(rubygems_dir)
437
+ gem_path = package_path(cache_path, spec)
438
+ return gem_path if File.exist?(gem_path)
419
439
 
420
- SharedHelpers.filesystem_access("#{download_path}/cache") do |p|
440
+ SharedHelpers.filesystem_access(cache_path) do |p|
421
441
  FileUtils.mkdir_p(p)
422
442
  end
423
- Bundler.rubygems.download_gem(spec, uri, download_path)
424
-
425
- if requires_sudo?
426
- SharedHelpers.filesystem_access("#{rubygems_dir}/cache") do |p|
427
- Bundler.mkdir_p(p)
428
- end
429
- Bundler.sudo "mv #{download_path}/cache/#{spec.full_name}.gem #{gem_path}"
430
- end
443
+ download_gem(spec, cache_path, previous_spec)
431
444
 
432
445
  gem_path
433
- ensure
434
- Bundler.rm_rf(download_path) if requires_sudo?
435
- end
436
-
437
- def builtin_gem?(spec)
438
- # Ruby 2.1, where all included gems have this summary
439
- return true if spec.summary =~ /is bundled with Ruby/
440
-
441
- # Ruby 2.0, where gemspecs are stored in specifications/default/
442
- spec.loaded_from && spec.loaded_from.include?("specifications/default/")
443
446
  end
444
447
 
445
448
  def installed?(spec)
446
- installed_specs[spec].any?
449
+ installed_specs[spec].any? && !spec.deleted_gem?
447
450
  end
448
451
 
449
- def requires_sudo?
450
- Bundler.requires_sudo?
452
+ def rubygems_dir
453
+ Bundler.bundle_path
451
454
  end
452
455
 
453
- def rubygems_dir
454
- Bundler.rubygems.gem_dir
456
+ def default_cache_path_for(dir)
457
+ "#{dir}/cache"
455
458
  end
456
459
 
457
460
  def cache_path
458
461
  Bundler.app_cache
459
462
  end
463
+
464
+ private
465
+
466
+ # Checks if the requested spec exists in the global cache. If it does,
467
+ # we copy it to the download path, and if it does not, we download it.
468
+ #
469
+ # @param [Specification] spec
470
+ # the spec we want to download or retrieve from the cache.
471
+ #
472
+ # @param [String] download_cache_path
473
+ # the local directory the .gem will end up in.
474
+ #
475
+ # @param [Specification] previous_spec
476
+ # the spec previously locked
477
+ #
478
+ def download_gem(spec, download_cache_path, previous_spec = nil)
479
+ uri = spec.remote.uri
480
+ Bundler.ui.confirm("Fetching #{version_message(spec, previous_spec)}")
481
+ Bundler.rubygems.download_gem(spec, uri, download_cache_path)
482
+ end
483
+
484
+ # Returns the global cache path of the calling Rubygems::Source object.
485
+ #
486
+ # Note that the Source determines the path's subdirectory. We use this
487
+ # subdirectory in the global cache path so that gems with the same name
488
+ # -- and possibly different versions -- from different sources are saved
489
+ # to their respective subdirectories and do not override one another.
490
+ #
491
+ # @param [Gem::Specification] specification
492
+ #
493
+ # @return [Pathname] The global cache path.
494
+ #
495
+ def download_cache_path(spec)
496
+ return unless Bundler.feature_flag.global_gem_cache?
497
+ return unless remote = spec.remote
498
+ return unless cache_slug = remote.cache_slug
499
+
500
+ Bundler.user_cache.join("gems", cache_slug)
501
+ end
502
+
503
+ def extension_cache_slug(spec)
504
+ return unless remote = spec.remote
505
+ remote.cache_slug
506
+ end
460
507
  end
461
508
  end
462
509
  end