bundler 2.2.29 → 2.5.16

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (330) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +1129 -4
  3. data/README.md +4 -8
  4. data/bundler.gemspec +11 -11
  5. data/exe/bundle +5 -26
  6. data/exe/bundler +1 -1
  7. data/lib/bundler/.document +1 -0
  8. data/lib/bundler/build_metadata.rb +4 -4
  9. data/lib/bundler/capistrano.rb +1 -1
  10. data/lib/bundler/checksum.rb +254 -0
  11. data/lib/bundler/ci_detector.rb +75 -0
  12. data/lib/bundler/cli/add.rb +4 -4
  13. data/lib/bundler/cli/binstubs.rb +10 -6
  14. data/lib/bundler/cli/cache.rb +1 -1
  15. data/lib/bundler/cli/check.rb +3 -3
  16. data/lib/bundler/cli/common.rb +13 -3
  17. data/lib/bundler/cli/config.rb +18 -8
  18. data/lib/bundler/cli/console.rb +5 -4
  19. data/lib/bundler/cli/doctor.rb +12 -5
  20. data/lib/bundler/cli/exec.rb +1 -1
  21. data/lib/bundler/cli/fund.rb +1 -1
  22. data/lib/bundler/cli/gem.rb +141 -48
  23. data/lib/bundler/cli/info.rb +27 -17
  24. data/lib/bundler/cli/init.rb +6 -2
  25. data/lib/bundler/cli/install.rb +22 -39
  26. data/lib/bundler/cli/issue.rb +5 -4
  27. data/lib/bundler/cli/lock.rb +36 -29
  28. data/lib/bundler/cli/open.rb +9 -9
  29. data/lib/bundler/cli/outdated.rb +19 -12
  30. data/lib/bundler/cli/platform.rb +8 -6
  31. data/lib/bundler/cli/plugin.rb +9 -15
  32. data/lib/bundler/cli/pristine.rb +38 -30
  33. data/lib/bundler/cli/show.rb +3 -3
  34. data/lib/bundler/cli/update.rb +12 -7
  35. data/lib/bundler/cli/viz.rb +1 -1
  36. data/lib/bundler/cli.rb +266 -285
  37. data/lib/bundler/compact_index_client/cache.rb +53 -67
  38. data/lib/bundler/compact_index_client/cache_file.rb +153 -0
  39. data/lib/bundler/compact_index_client/gem_parser.rb +7 -3
  40. data/lib/bundler/compact_index_client/parser.rb +84 -0
  41. data/lib/bundler/compact_index_client/updater.rb +83 -76
  42. data/lib/bundler/compact_index_client.rb +59 -87
  43. data/lib/bundler/constants.rb +9 -2
  44. data/lib/bundler/current_ruby.rb +12 -16
  45. data/lib/bundler/definition.rb +509 -319
  46. data/lib/bundler/dependency.rb +33 -71
  47. data/lib/bundler/digest.rb +71 -0
  48. data/lib/bundler/dsl.rb +88 -69
  49. data/lib/bundler/endpoint_specification.rb +32 -15
  50. data/lib/bundler/env.rb +5 -7
  51. data/lib/bundler/environment_preserver.rb +8 -22
  52. data/lib/bundler/errors.rb +101 -13
  53. data/lib/bundler/feature_flag.rb +0 -2
  54. data/lib/bundler/fetcher/base.rb +11 -11
  55. data/lib/bundler/fetcher/compact_index.rb +32 -52
  56. data/lib/bundler/fetcher/dependency.rb +3 -7
  57. data/lib/bundler/fetcher/downloader.rb +17 -16
  58. data/lib/bundler/fetcher/gem_remote_fetcher.rb +16 -0
  59. data/lib/bundler/fetcher/index.rb +2 -29
  60. data/lib/bundler/fetcher.rb +87 -79
  61. data/lib/bundler/force_platform.rb +18 -0
  62. data/lib/bundler/friendly_errors.rb +29 -40
  63. data/lib/bundler/gem_helper.rb +11 -23
  64. data/lib/bundler/gem_helpers.rb +30 -6
  65. data/lib/bundler/gem_version_promoter.rb +68 -109
  66. data/lib/bundler/graph.rb +9 -9
  67. data/lib/bundler/index.rb +71 -79
  68. data/lib/bundler/injector.rb +23 -11
  69. data/lib/bundler/inline.rb +11 -23
  70. data/lib/bundler/installer/gem_installer.rb +18 -11
  71. data/lib/bundler/installer/parallel_installer.rb +17 -65
  72. data/lib/bundler/installer/standalone.rb +56 -15
  73. data/lib/bundler/installer.rb +35 -61
  74. data/lib/bundler/lazy_specification.rb +92 -61
  75. data/lib/bundler/lockfile_generator.rb +12 -3
  76. data/lib/bundler/lockfile_parser.rb +137 -70
  77. data/lib/bundler/man/bundle-add.1 +19 -26
  78. data/lib/bundler/man/bundle-add.1.ronn +16 -4
  79. data/lib/bundler/man/bundle-binstubs.1 +4 -16
  80. data/lib/bundler/man/bundle-cache.1 +9 -24
  81. data/lib/bundler/man/bundle-cache.1.ronn +9 -2
  82. data/lib/bundler/man/bundle-check.1 +5 -12
  83. data/lib/bundler/man/bundle-check.1.ronn +3 -0
  84. data/lib/bundler/man/bundle-clean.1 +4 -11
  85. data/lib/bundler/man/bundle-clean.1.ronn +1 -1
  86. data/lib/bundler/man/bundle-config.1 +47 -224
  87. data/lib/bundler/man/bundle-config.1.ronn +40 -28
  88. data/lib/bundler/man/bundle-console.1 +35 -0
  89. data/lib/bundler/man/bundle-console.1.ronn +44 -0
  90. data/lib/bundler/man/bundle-doctor.1 +4 -18
  91. data/lib/bundler/man/bundle-exec.1 +16 -77
  92. data/lib/bundler/man/bundle-exec.1.ronn +8 -9
  93. data/lib/bundler/man/bundle-gem.1 +45 -72
  94. data/lib/bundler/man/bundle-gem.1.ronn +32 -5
  95. data/lib/bundler/man/bundle-help.1 +9 -0
  96. data/lib/bundler/man/bundle-help.1.ronn +12 -0
  97. data/lib/bundler/man/bundle-info.1 +5 -11
  98. data/lib/bundler/man/bundle-info.1.ronn +3 -3
  99. data/lib/bundler/man/bundle-init.1 +6 -11
  100. data/lib/bundler/man/bundle-init.1.ronn +2 -0
  101. data/lib/bundler/man/bundle-inject.1 +8 -18
  102. data/lib/bundler/man/bundle-inject.1.ronn +3 -1
  103. data/lib/bundler/man/bundle-install.1 +32 -155
  104. data/lib/bundler/man/bundle-install.1.ronn +11 -33
  105. data/lib/bundler/man/bundle-list.1 +4 -19
  106. data/lib/bundler/man/bundle-lock.1 +5 -29
  107. data/lib/bundler/man/bundle-open.1 +18 -18
  108. data/lib/bundler/man/bundle-open.1.ronn +9 -1
  109. data/lib/bundler/man/bundle-outdated.1 +17 -72
  110. data/lib/bundler/man/bundle-outdated.1.ronn +13 -18
  111. data/lib/bundler/man/bundle-platform.1 +16 -28
  112. data/lib/bundler/man/bundle-platform.1.ronn +14 -7
  113. data/lib/bundler/man/bundle-plugin.1 +58 -0
  114. data/lib/bundler/man/bundle-plugin.1.ronn +63 -0
  115. data/lib/bundler/man/bundle-pristine.1 +5 -16
  116. data/lib/bundler/man/bundle-remove.1 +4 -14
  117. data/lib/bundler/man/bundle-show.1 +3 -10
  118. data/lib/bundler/man/bundle-update.1 +19 -138
  119. data/lib/bundler/man/bundle-update.1.ronn +2 -1
  120. data/lib/bundler/man/bundle-version.1 +22 -0
  121. data/lib/bundler/man/bundle-version.1.ronn +24 -0
  122. data/lib/bundler/man/bundle-viz.1 +6 -15
  123. data/lib/bundler/man/bundle-viz.1.ronn +2 -0
  124. data/lib/bundler/man/bundle.1 +17 -51
  125. data/lib/bundler/man/bundle.1.ronn +12 -7
  126. data/lib/bundler/man/gemfile.5 +130 -346
  127. data/lib/bundler/man/gemfile.5.ronn +121 -86
  128. data/lib/bundler/man/index.txt +4 -0
  129. data/lib/bundler/match_metadata.rb +17 -0
  130. data/lib/bundler/match_platform.rb +1 -2
  131. data/lib/bundler/match_remote_metadata.rb +29 -0
  132. data/lib/bundler/mirror.rb +8 -10
  133. data/lib/bundler/plugin/api/source.rb +9 -13
  134. data/lib/bundler/plugin/index.rb +13 -5
  135. data/lib/bundler/plugin/installer/git.rb +0 -4
  136. data/lib/bundler/plugin/installer/path.rb +18 -0
  137. data/lib/bundler/plugin/installer/rubygems.rb +0 -8
  138. data/lib/bundler/plugin/installer.rb +42 -19
  139. data/lib/bundler/plugin/source_list.rb +4 -4
  140. data/lib/bundler/plugin.rb +16 -7
  141. data/lib/bundler/process_lock.rb +1 -1
  142. data/lib/bundler/remote_specification.rb +11 -5
  143. data/lib/bundler/resolver/base.rb +111 -0
  144. data/lib/bundler/resolver/candidate.rb +82 -0
  145. data/lib/bundler/resolver/incompatibility.rb +15 -0
  146. data/lib/bundler/resolver/package.rb +81 -0
  147. data/lib/bundler/resolver/root.rb +25 -0
  148. data/lib/bundler/resolver/spec_group.rb +53 -66
  149. data/lib/bundler/resolver.rb +419 -307
  150. data/lib/bundler/retry.rb +1 -1
  151. data/lib/bundler/ruby_dsl.rb +42 -7
  152. data/lib/bundler/ruby_version.rb +16 -22
  153. data/lib/bundler/rubygems_ext.rb +250 -64
  154. data/lib/bundler/rubygems_gem_installer.rb +90 -64
  155. data/lib/bundler/rubygems_integration.rb +81 -190
  156. data/lib/bundler/runtime.rb +8 -13
  157. data/lib/bundler/safe_marshal.rb +31 -0
  158. data/lib/bundler/self_manager.rb +206 -0
  159. data/lib/bundler/settings.rb +139 -57
  160. data/lib/bundler/setup.rb +13 -1
  161. data/lib/bundler/shared_helpers.rb +67 -36
  162. data/lib/bundler/source/git/git_proxy.rb +285 -82
  163. data/lib/bundler/source/git.rb +81 -41
  164. data/lib/bundler/source/metadata.rb +17 -16
  165. data/lib/bundler/source/path/installer.rb +1 -22
  166. data/lib/bundler/source/path.rb +13 -25
  167. data/lib/bundler/source/rubygems/remote.rb +1 -1
  168. data/lib/bundler/source/rubygems.rb +164 -234
  169. data/lib/bundler/source/rubygems_aggregate.rb +1 -1
  170. data/lib/bundler/source.rb +7 -6
  171. data/lib/bundler/source_list.rb +40 -32
  172. data/lib/bundler/source_map.rb +15 -2
  173. data/lib/bundler/spec_set.rb +156 -46
  174. data/lib/bundler/stub_specification.rb +18 -5
  175. data/lib/bundler/templates/Executable +3 -5
  176. data/lib/bundler/templates/Executable.bundler +7 -12
  177. data/lib/bundler/templates/Executable.standalone +4 -4
  178. data/lib/bundler/templates/Gemfile +0 -2
  179. data/lib/bundler/templates/newgem/CODE_OF_CONDUCT.md.tt +77 -29
  180. data/lib/bundler/templates/newgem/Cargo.toml.tt +7 -0
  181. data/lib/bundler/templates/newgem/Gemfile.tt +8 -2
  182. data/lib/bundler/templates/newgem/README.md.tt +7 -11
  183. data/lib/bundler/templates/newgem/Rakefile.tt +28 -4
  184. data/lib/bundler/templates/newgem/bin/console.tt +0 -4
  185. data/lib/bundler/templates/newgem/circleci/config.yml.tt +12 -0
  186. data/lib/bundler/templates/newgem/ext/newgem/Cargo.toml.tt +15 -0
  187. data/lib/bundler/templates/newgem/ext/newgem/extconf-c.rb.tt +10 -0
  188. data/lib/bundler/templates/newgem/ext/newgem/extconf-rust.rb.tt +6 -0
  189. data/lib/bundler/templates/newgem/ext/newgem/newgem.c.tt +1 -1
  190. data/lib/bundler/templates/newgem/ext/newgem/src/lib.rs.tt +12 -0
  191. data/lib/bundler/templates/newgem/github/workflows/main.yml.tt +13 -3
  192. data/lib/bundler/templates/newgem/gitignore.tt +3 -0
  193. data/lib/bundler/templates/newgem/gitlab-ci.yml.tt +13 -4
  194. data/lib/bundler/templates/newgem/newgem.gemspec.tt +25 -17
  195. data/lib/bundler/templates/newgem/rubocop.yml.tt +0 -5
  196. data/lib/bundler/templates/newgem/sig/newgem.rbs.tt +8 -0
  197. data/lib/bundler/templates/newgem/standard.yml.tt +3 -0
  198. data/lib/bundler/templates/newgem/test/minitest/{newgem_test.rb.tt → test_newgem.rb.tt} +1 -1
  199. data/lib/bundler/ui/rg_proxy.rb +1 -1
  200. data/lib/bundler/ui/shell.rb +38 -15
  201. data/lib/bundler/ui/silent.rb +21 -5
  202. data/lib/bundler/uri_credentials_filter.rb +2 -2
  203. data/lib/bundler/uri_normalizer.rb +23 -0
  204. data/lib/bundler/vendor/.document +1 -0
  205. data/lib/bundler/vendor/connection_pool/.document +1 -0
  206. data/lib/bundler/vendor/connection_pool/LICENSE +20 -0
  207. data/lib/bundler/vendor/connection_pool/lib/connection_pool/timed_stack.rb +19 -21
  208. data/lib/bundler/vendor/connection_pool/lib/connection_pool/version.rb +1 -1
  209. data/lib/bundler/vendor/connection_pool/lib/connection_pool/wrapper.rb +56 -0
  210. data/lib/bundler/vendor/connection_pool/lib/connection_pool.rb +92 -78
  211. data/lib/bundler/vendor/fileutils/.document +1 -0
  212. data/lib/bundler/vendor/fileutils/LICENSE.txt +22 -0
  213. data/lib/bundler/vendor/fileutils/lib/fileutils.rb +1340 -410
  214. data/lib/bundler/vendor/net-http-persistent/.document +1 -0
  215. data/lib/bundler/vendor/net-http-persistent/README.rdoc +82 -0
  216. data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent/connection.rb +4 -3
  217. data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent/pool.rb +23 -11
  218. data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent/timed_stack_multi.rb +1 -1
  219. data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent.rb +57 -57
  220. data/lib/bundler/vendor/pub_grub/.document +1 -0
  221. data/lib/bundler/vendor/pub_grub/LICENSE.txt +21 -0
  222. data/lib/bundler/vendor/pub_grub/lib/pub_grub/assignment.rb +20 -0
  223. data/lib/bundler/vendor/pub_grub/lib/pub_grub/basic_package_source.rb +189 -0
  224. data/lib/bundler/vendor/pub_grub/lib/pub_grub/failure_writer.rb +182 -0
  225. data/lib/bundler/vendor/pub_grub/lib/pub_grub/incompatibility.rb +150 -0
  226. data/lib/bundler/vendor/pub_grub/lib/pub_grub/package.rb +43 -0
  227. data/lib/bundler/vendor/pub_grub/lib/pub_grub/partial_solution.rb +121 -0
  228. data/lib/bundler/vendor/pub_grub/lib/pub_grub/rubygems.rb +45 -0
  229. data/lib/bundler/vendor/pub_grub/lib/pub_grub/solve_failure.rb +19 -0
  230. data/lib/bundler/vendor/pub_grub/lib/pub_grub/static_package_source.rb +61 -0
  231. data/lib/bundler/vendor/pub_grub/lib/pub_grub/term.rb +105 -0
  232. data/lib/bundler/vendor/pub_grub/lib/pub_grub/version.rb +3 -0
  233. data/lib/bundler/vendor/pub_grub/lib/pub_grub/version_constraint.rb +129 -0
  234. data/lib/bundler/vendor/pub_grub/lib/pub_grub/version_range.rb +411 -0
  235. data/lib/bundler/vendor/pub_grub/lib/pub_grub/version_solver.rb +248 -0
  236. data/lib/bundler/vendor/pub_grub/lib/pub_grub/version_union.rb +178 -0
  237. data/lib/bundler/vendor/pub_grub/lib/pub_grub.rb +31 -0
  238. data/lib/bundler/vendor/thor/.document +1 -0
  239. data/lib/bundler/vendor/thor/LICENSE.md +20 -0
  240. data/lib/bundler/vendor/thor/lib/thor/actions/create_file.rb +3 -2
  241. data/lib/bundler/vendor/thor/lib/thor/actions/directory.rb +1 -1
  242. data/lib/bundler/vendor/thor/lib/thor/actions/empty_directory.rb +1 -1
  243. data/lib/bundler/vendor/thor/lib/thor/actions/file_manipulation.rb +12 -14
  244. data/lib/bundler/vendor/thor/lib/thor/actions/inject_into_file.rb +16 -6
  245. data/lib/bundler/vendor/thor/lib/thor/actions.rb +21 -17
  246. data/lib/bundler/vendor/thor/lib/thor/base.rb +140 -14
  247. data/lib/bundler/vendor/thor/lib/thor/command.rb +13 -4
  248. data/lib/bundler/vendor/thor/lib/thor/core_ext/hash_with_indifferent_access.rb +10 -0
  249. data/lib/bundler/vendor/thor/lib/thor/error.rb +16 -20
  250. data/lib/bundler/vendor/thor/lib/thor/group.rb +1 -1
  251. data/lib/bundler/vendor/thor/lib/thor/invocation.rb +1 -1
  252. data/lib/bundler/vendor/thor/lib/thor/nested_context.rb +2 -2
  253. data/lib/bundler/vendor/thor/lib/thor/parser/argument.rb +20 -1
  254. data/lib/bundler/vendor/thor/lib/thor/parser/arguments.rb +33 -17
  255. data/lib/bundler/vendor/thor/lib/thor/parser/option.rb +27 -8
  256. data/lib/bundler/vendor/thor/lib/thor/parser/options.rb +63 -7
  257. data/lib/bundler/vendor/thor/lib/thor/rake_compat.rb +2 -2
  258. data/lib/bundler/vendor/thor/lib/thor/runner.rb +40 -30
  259. data/lib/bundler/vendor/thor/lib/thor/shell/basic.rb +48 -154
  260. data/lib/bundler/vendor/thor/lib/thor/shell/color.rb +1 -46
  261. data/lib/bundler/vendor/thor/lib/thor/shell/column_printer.rb +29 -0
  262. data/lib/bundler/vendor/thor/lib/thor/shell/html.rb +0 -45
  263. data/lib/bundler/vendor/thor/lib/thor/shell/table_printer.rb +134 -0
  264. data/lib/bundler/vendor/thor/lib/thor/shell/terminal.rb +42 -0
  265. data/lib/bundler/vendor/thor/lib/thor/shell/wrapped_printer.rb +38 -0
  266. data/lib/bundler/vendor/thor/lib/thor/shell.rb +2 -2
  267. data/lib/bundler/vendor/thor/lib/thor/util.rb +9 -8
  268. data/lib/bundler/vendor/thor/lib/thor/version.rb +1 -1
  269. data/lib/bundler/vendor/thor/lib/thor.rb +155 -8
  270. data/lib/bundler/vendor/tsort/.document +1 -0
  271. data/lib/bundler/vendor/tsort/LICENSE.txt +22 -0
  272. data/lib/bundler/vendor/tsort/lib/tsort.rb +455 -0
  273. data/lib/bundler/vendor/uri/.document +1 -0
  274. data/lib/bundler/vendor/uri/LICENSE.txt +22 -0
  275. data/lib/bundler/vendor/uri/lib/uri/common.rb +316 -207
  276. data/lib/bundler/vendor/uri/lib/uri/file.rb +7 -1
  277. data/lib/bundler/vendor/uri/lib/uri/ftp.rb +2 -2
  278. data/lib/bundler/vendor/uri/lib/uri/generic.rb +33 -13
  279. data/lib/bundler/vendor/uri/lib/uri/http.rb +40 -3
  280. data/lib/bundler/vendor/uri/lib/uri/https.rb +2 -2
  281. data/lib/bundler/vendor/uri/lib/uri/ldap.rb +2 -2
  282. data/lib/bundler/vendor/uri/lib/uri/ldaps.rb +2 -1
  283. data/lib/bundler/vendor/uri/lib/uri/mailto.rb +2 -3
  284. data/lib/bundler/vendor/uri/lib/uri/rfc2396_parser.rb +16 -23
  285. data/lib/bundler/vendor/uri/lib/uri/rfc3986_parser.rb +105 -47
  286. data/lib/bundler/vendor/uri/lib/uri/version.rb +1 -1
  287. data/lib/bundler/vendor/uri/lib/uri/ws.rb +83 -0
  288. data/lib/bundler/vendor/uri/lib/uri/wss.rb +23 -0
  289. data/lib/bundler/vendor/uri/lib/uri.rb +3 -3
  290. data/lib/bundler/vendored_net_http.rb +23 -0
  291. data/lib/bundler/vendored_persistent.rb +0 -36
  292. data/lib/bundler/{vendored_molinillo.rb → vendored_pub_grub.rb} +1 -1
  293. data/lib/bundler/vendored_timeout.rb +12 -0
  294. data/lib/bundler/{vendored_tmpdir.rb → vendored_tsort.rb} +1 -1
  295. data/lib/bundler/vendored_uri.rb +18 -1
  296. data/lib/bundler/version.rb +5 -1
  297. data/lib/bundler/vlad.rb +1 -1
  298. data/lib/bundler/worker.rb +7 -9
  299. data/lib/bundler/yaml_serializer.rb +21 -12
  300. data/lib/bundler.rb +114 -121
  301. metadata +87 -41
  302. data/lib/bundler/dep_proxy.rb +0 -55
  303. data/lib/bundler/gemdeps.rb +0 -29
  304. data/lib/bundler/psyched_yaml.rb +0 -22
  305. data/lib/bundler/templates/gems.rb +0 -8
  306. data/lib/bundler/templates/newgem/ext/newgem/extconf.rb.tt +0 -5
  307. data/lib/bundler/templates/newgem/travis.yml.tt +0 -6
  308. data/lib/bundler/vendor/connection_pool/lib/connection_pool/monotonic_time.rb +0 -66
  309. data/lib/bundler/vendor/molinillo/lib/molinillo/delegates/resolution_state.rb +0 -57
  310. data/lib/bundler/vendor/molinillo/lib/molinillo/delegates/specification_provider.rb +0 -88
  311. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/action.rb +0 -36
  312. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb +0 -66
  313. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_vertex.rb +0 -62
  314. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/delete_edge.rb +0 -63
  315. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb +0 -61
  316. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/log.rb +0 -126
  317. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/set_payload.rb +0 -46
  318. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/tag.rb +0 -36
  319. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/vertex.rb +0 -164
  320. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph.rb +0 -255
  321. data/lib/bundler/vendor/molinillo/lib/molinillo/errors.rb +0 -143
  322. data/lib/bundler/vendor/molinillo/lib/molinillo/gem_metadata.rb +0 -6
  323. data/lib/bundler/vendor/molinillo/lib/molinillo/modules/specification_provider.rb +0 -112
  324. data/lib/bundler/vendor/molinillo/lib/molinillo/modules/ui.rb +0 -67
  325. data/lib/bundler/vendor/molinillo/lib/molinillo/resolution.rb +0 -839
  326. data/lib/bundler/vendor/molinillo/lib/molinillo/resolver.rb +0 -46
  327. data/lib/bundler/vendor/molinillo/lib/molinillo/state.rb +0 -58
  328. data/lib/bundler/vendor/molinillo/lib/molinillo.rb +0 -11
  329. data/lib/bundler/vendor/tmpdir/lib/tmpdir.rb +0 -154
  330. data/lib/bundler/version_ranges.rb +0 -122
@@ -1,36 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Bundler::Molinillo
4
- class DependencyGraph
5
- # An action that modifies a {DependencyGraph} that is reversible.
6
- # @abstract
7
- class Action
8
- # rubocop:disable Lint/UnusedMethodArgument
9
-
10
- # @return [Symbol] The name of the action.
11
- def self.action_name
12
- raise 'Abstract'
13
- end
14
-
15
- # Performs the action on the given graph.
16
- # @param [DependencyGraph] graph the graph to perform the action on.
17
- # @return [Void]
18
- def up(graph)
19
- raise 'Abstract'
20
- end
21
-
22
- # Reverses the action on the given graph.
23
- # @param [DependencyGraph] graph the graph to reverse the action on.
24
- # @return [Void]
25
- def down(graph)
26
- raise 'Abstract'
27
- end
28
-
29
- # @return [Action,Nil] The previous action
30
- attr_accessor :previous
31
-
32
- # @return [Action,Nil] The next action
33
- attr_accessor :next
34
- end
35
- end
36
- end
@@ -1,66 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative 'action'
4
- module Bundler::Molinillo
5
- class DependencyGraph
6
- # @!visibility private
7
- # (see DependencyGraph#add_edge_no_circular)
8
- class AddEdgeNoCircular < Action
9
- # @!group Action
10
-
11
- # (see Action.action_name)
12
- def self.action_name
13
- :add_vertex
14
- end
15
-
16
- # (see Action#up)
17
- def up(graph)
18
- edge = make_edge(graph)
19
- edge.origin.outgoing_edges << edge
20
- edge.destination.incoming_edges << edge
21
- edge
22
- end
23
-
24
- # (see Action#down)
25
- def down(graph)
26
- edge = make_edge(graph)
27
- delete_first(edge.origin.outgoing_edges, edge)
28
- delete_first(edge.destination.incoming_edges, edge)
29
- end
30
-
31
- # @!group AddEdgeNoCircular
32
-
33
- # @return [String] the name of the origin of the edge
34
- attr_reader :origin
35
-
36
- # @return [String] the name of the destination of the edge
37
- attr_reader :destination
38
-
39
- # @return [Object] the requirement that the edge represents
40
- attr_reader :requirement
41
-
42
- # @param [DependencyGraph] graph the graph to find vertices from
43
- # @return [Edge] The edge this action adds
44
- def make_edge(graph)
45
- Edge.new(graph.vertex_named(origin), graph.vertex_named(destination), requirement)
46
- end
47
-
48
- # Initialize an action to add an edge to a dependency graph
49
- # @param [String] origin the name of the origin of the edge
50
- # @param [String] destination the name of the destination of the edge
51
- # @param [Object] requirement the requirement that the edge represents
52
- def initialize(origin, destination, requirement)
53
- @origin = origin
54
- @destination = destination
55
- @requirement = requirement
56
- end
57
-
58
- private
59
-
60
- def delete_first(array, item)
61
- return unless index = array.index(item)
62
- array.delete_at(index)
63
- end
64
- end
65
- end
66
- end
@@ -1,62 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative 'action'
4
- module Bundler::Molinillo
5
- class DependencyGraph
6
- # @!visibility private
7
- # (see DependencyGraph#add_vertex)
8
- class AddVertex < Action # :nodoc:
9
- # @!group Action
10
-
11
- # (see Action.action_name)
12
- def self.action_name
13
- :add_vertex
14
- end
15
-
16
- # (see Action#up)
17
- def up(graph)
18
- if existing = graph.vertices[name]
19
- @existing_payload = existing.payload
20
- @existing_root = existing.root
21
- end
22
- vertex = existing || Vertex.new(name, payload)
23
- graph.vertices[vertex.name] = vertex
24
- vertex.payload ||= payload
25
- vertex.root ||= root
26
- vertex
27
- end
28
-
29
- # (see Action#down)
30
- def down(graph)
31
- if defined?(@existing_payload)
32
- vertex = graph.vertices[name]
33
- vertex.payload = @existing_payload
34
- vertex.root = @existing_root
35
- else
36
- graph.vertices.delete(name)
37
- end
38
- end
39
-
40
- # @!group AddVertex
41
-
42
- # @return [String] the name of the vertex
43
- attr_reader :name
44
-
45
- # @return [Object] the payload for the vertex
46
- attr_reader :payload
47
-
48
- # @return [Boolean] whether the vertex is root or not
49
- attr_reader :root
50
-
51
- # Initialize an action to add a vertex to a dependency graph
52
- # @param [String] name the name of the vertex
53
- # @param [Object] payload the payload for the vertex
54
- # @param [Boolean] root whether the vertex is root or not
55
- def initialize(name, payload, root)
56
- @name = name
57
- @payload = payload
58
- @root = root
59
- end
60
- end
61
- end
62
- end
@@ -1,63 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative 'action'
4
- module Bundler::Molinillo
5
- class DependencyGraph
6
- # @!visibility private
7
- # (see DependencyGraph#delete_edge)
8
- class DeleteEdge < Action
9
- # @!group Action
10
-
11
- # (see Action.action_name)
12
- def self.action_name
13
- :delete_edge
14
- end
15
-
16
- # (see Action#up)
17
- def up(graph)
18
- edge = make_edge(graph)
19
- edge.origin.outgoing_edges.delete(edge)
20
- edge.destination.incoming_edges.delete(edge)
21
- end
22
-
23
- # (see Action#down)
24
- def down(graph)
25
- edge = make_edge(graph)
26
- edge.origin.outgoing_edges << edge
27
- edge.destination.incoming_edges << edge
28
- edge
29
- end
30
-
31
- # @!group DeleteEdge
32
-
33
- # @return [String] the name of the origin of the edge
34
- attr_reader :origin_name
35
-
36
- # @return [String] the name of the destination of the edge
37
- attr_reader :destination_name
38
-
39
- # @return [Object] the requirement that the edge represents
40
- attr_reader :requirement
41
-
42
- # @param [DependencyGraph] graph the graph to find vertices from
43
- # @return [Edge] The edge this action adds
44
- def make_edge(graph)
45
- Edge.new(
46
- graph.vertex_named(origin_name),
47
- graph.vertex_named(destination_name),
48
- requirement
49
- )
50
- end
51
-
52
- # Initialize an action to add an edge to a dependency graph
53
- # @param [String] origin_name the name of the origin of the edge
54
- # @param [String] destination_name the name of the destination of the edge
55
- # @param [Object] requirement the requirement that the edge represents
56
- def initialize(origin_name, destination_name, requirement)
57
- @origin_name = origin_name
58
- @destination_name = destination_name
59
- @requirement = requirement
60
- end
61
- end
62
- end
63
- end
@@ -1,61 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative 'action'
4
- module Bundler::Molinillo
5
- class DependencyGraph
6
- # @!visibility private
7
- # @see DependencyGraph#detach_vertex_named
8
- class DetachVertexNamed < Action
9
- # @!group Action
10
-
11
- # (see Action#name)
12
- def self.action_name
13
- :add_vertex
14
- end
15
-
16
- # (see Action#up)
17
- def up(graph)
18
- return [] unless @vertex = graph.vertices.delete(name)
19
-
20
- removed_vertices = [@vertex]
21
- @vertex.outgoing_edges.each do |e|
22
- v = e.destination
23
- v.incoming_edges.delete(e)
24
- if !v.root? && v.incoming_edges.empty?
25
- removed_vertices.concat graph.detach_vertex_named(v.name)
26
- end
27
- end
28
-
29
- @vertex.incoming_edges.each do |e|
30
- v = e.origin
31
- v.outgoing_edges.delete(e)
32
- end
33
-
34
- removed_vertices
35
- end
36
-
37
- # (see Action#down)
38
- def down(graph)
39
- return unless @vertex
40
- graph.vertices[@vertex.name] = @vertex
41
- @vertex.outgoing_edges.each do |e|
42
- e.destination.incoming_edges << e
43
- end
44
- @vertex.incoming_edges.each do |e|
45
- e.origin.outgoing_edges << e
46
- end
47
- end
48
-
49
- # @!group DetachVertexNamed
50
-
51
- # @return [String] the name of the vertex to detach
52
- attr_reader :name
53
-
54
- # Initialize an action to detach a vertex from a dependency graph
55
- # @param [String] name the name of the vertex to detach
56
- def initialize(name)
57
- @name = name
58
- end
59
- end
60
- end
61
- end
@@ -1,126 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative 'add_edge_no_circular'
4
- require_relative 'add_vertex'
5
- require_relative 'delete_edge'
6
- require_relative 'detach_vertex_named'
7
- require_relative 'set_payload'
8
- require_relative 'tag'
9
-
10
- module Bundler::Molinillo
11
- class DependencyGraph
12
- # A log for dependency graph actions
13
- class Log
14
- # Initializes an empty log
15
- def initialize
16
- @current_action = @first_action = nil
17
- end
18
-
19
- # @!macro [new] action
20
- # {include:DependencyGraph#$0}
21
- # @param [Graph] graph the graph to perform the action on
22
- # @param (see DependencyGraph#$0)
23
- # @return (see DependencyGraph#$0)
24
-
25
- # @macro action
26
- def tag(graph, tag)
27
- push_action(graph, Tag.new(tag))
28
- end
29
-
30
- # @macro action
31
- def add_vertex(graph, name, payload, root)
32
- push_action(graph, AddVertex.new(name, payload, root))
33
- end
34
-
35
- # @macro action
36
- def detach_vertex_named(graph, name)
37
- push_action(graph, DetachVertexNamed.new(name))
38
- end
39
-
40
- # @macro action
41
- def add_edge_no_circular(graph, origin, destination, requirement)
42
- push_action(graph, AddEdgeNoCircular.new(origin, destination, requirement))
43
- end
44
-
45
- # {include:DependencyGraph#delete_edge}
46
- # @param [Graph] graph the graph to perform the action on
47
- # @param [String] origin_name
48
- # @param [String] destination_name
49
- # @param [Object] requirement
50
- # @return (see DependencyGraph#delete_edge)
51
- def delete_edge(graph, origin_name, destination_name, requirement)
52
- push_action(graph, DeleteEdge.new(origin_name, destination_name, requirement))
53
- end
54
-
55
- # @macro action
56
- def set_payload(graph, name, payload)
57
- push_action(graph, SetPayload.new(name, payload))
58
- end
59
-
60
- # Pops the most recent action from the log and undoes the action
61
- # @param [DependencyGraph] graph
62
- # @return [Action] the action that was popped off the log
63
- def pop!(graph)
64
- return unless action = @current_action
65
- unless @current_action = action.previous
66
- @first_action = nil
67
- end
68
- action.down(graph)
69
- action
70
- end
71
-
72
- extend Enumerable
73
-
74
- # @!visibility private
75
- # Enumerates each action in the log
76
- # @yield [Action]
77
- def each
78
- return enum_for unless block_given?
79
- action = @first_action
80
- loop do
81
- break unless action
82
- yield action
83
- action = action.next
84
- end
85
- self
86
- end
87
-
88
- # @!visibility private
89
- # Enumerates each action in the log in reverse order
90
- # @yield [Action]
91
- def reverse_each
92
- return enum_for(:reverse_each) unless block_given?
93
- action = @current_action
94
- loop do
95
- break unless action
96
- yield action
97
- action = action.previous
98
- end
99
- self
100
- end
101
-
102
- # @macro action
103
- def rewind_to(graph, tag)
104
- loop do
105
- action = pop!(graph)
106
- raise "No tag #{tag.inspect} found" unless action
107
- break if action.class.action_name == :tag && action.tag == tag
108
- end
109
- end
110
-
111
- private
112
-
113
- # Adds the given action to the log, running the action
114
- # @param [DependencyGraph] graph
115
- # @param [Action] action
116
- # @return The value returned by `action.up`
117
- def push_action(graph, action)
118
- action.previous = @current_action
119
- @current_action.next = action if @current_action
120
- @current_action = action
121
- @first_action ||= action
122
- action.up(graph)
123
- end
124
- end
125
- end
126
- end
@@ -1,46 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative 'action'
4
- module Bundler::Molinillo
5
- class DependencyGraph
6
- # @!visibility private
7
- # @see DependencyGraph#set_payload
8
- class SetPayload < Action # :nodoc:
9
- # @!group Action
10
-
11
- # (see Action.action_name)
12
- def self.action_name
13
- :set_payload
14
- end
15
-
16
- # (see Action#up)
17
- def up(graph)
18
- vertex = graph.vertex_named(name)
19
- @old_payload = vertex.payload
20
- vertex.payload = payload
21
- end
22
-
23
- # (see Action#down)
24
- def down(graph)
25
- graph.vertex_named(name).payload = @old_payload
26
- end
27
-
28
- # @!group SetPayload
29
-
30
- # @return [String] the name of the vertex
31
- attr_reader :name
32
-
33
- # @return [Object] the payload for the vertex
34
- attr_reader :payload
35
-
36
- # Initialize an action to add set the payload for a vertex in a dependency
37
- # graph
38
- # @param [String] name the name of the vertex
39
- # @param [Object] payload the payload for the vertex
40
- def initialize(name, payload)
41
- @name = name
42
- @payload = payload
43
- end
44
- end
45
- end
46
- end
@@ -1,36 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative 'action'
4
- module Bundler::Molinillo
5
- class DependencyGraph
6
- # @!visibility private
7
- # @see DependencyGraph#tag
8
- class Tag < Action
9
- # @!group Action
10
-
11
- # (see Action.action_name)
12
- def self.action_name
13
- :tag
14
- end
15
-
16
- # (see Action#up)
17
- def up(graph)
18
- end
19
-
20
- # (see Action#down)
21
- def down(graph)
22
- end
23
-
24
- # @!group Tag
25
-
26
- # @return [Object] An opaque tag
27
- attr_reader :tag
28
-
29
- # Initialize an action to tag a state of a dependency graph
30
- # @param [Object] tag an opaque tag
31
- def initialize(tag)
32
- @tag = tag
33
- end
34
- end
35
- end
36
- end
@@ -1,164 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Bundler::Molinillo
4
- class DependencyGraph
5
- # A vertex in a {DependencyGraph} that encapsulates a {#name} and a
6
- # {#payload}
7
- class Vertex
8
- # @return [String] the name of the vertex
9
- attr_accessor :name
10
-
11
- # @return [Object] the payload the vertex holds
12
- attr_accessor :payload
13
-
14
- # @return [Array<Object>] the explicit requirements that required
15
- # this vertex
16
- attr_reader :explicit_requirements
17
-
18
- # @return [Boolean] whether the vertex is considered a root vertex
19
- attr_accessor :root
20
- alias root? root
21
-
22
- # Initializes a vertex with the given name and payload.
23
- # @param [String] name see {#name}
24
- # @param [Object] payload see {#payload}
25
- def initialize(name, payload)
26
- @name = name.frozen? ? name : name.dup.freeze
27
- @payload = payload
28
- @explicit_requirements = []
29
- @outgoing_edges = []
30
- @incoming_edges = []
31
- end
32
-
33
- # @return [Array<Object>] all of the requirements that required
34
- # this vertex
35
- def requirements
36
- (incoming_edges.map(&:requirement) + explicit_requirements).uniq
37
- end
38
-
39
- # @return [Array<Edge>] the edges of {#graph} that have `self` as their
40
- # {Edge#origin}
41
- attr_accessor :outgoing_edges
42
-
43
- # @return [Array<Edge>] the edges of {#graph} that have `self` as their
44
- # {Edge#destination}
45
- attr_accessor :incoming_edges
46
-
47
- # @return [Array<Vertex>] the vertices of {#graph} that have an edge with
48
- # `self` as their {Edge#destination}
49
- def predecessors
50
- incoming_edges.map(&:origin)
51
- end
52
-
53
- # @return [Set<Vertex>] the vertices of {#graph} where `self` is a
54
- # {#descendent?}
55
- def recursive_predecessors
56
- _recursive_predecessors
57
- end
58
-
59
- # @param [Set<Vertex>] vertices the set to add the predecessors to
60
- # @return [Set<Vertex>] the vertices of {#graph} where `self` is a
61
- # {#descendent?}
62
- def _recursive_predecessors(vertices = new_vertex_set)
63
- incoming_edges.each do |edge|
64
- vertex = edge.origin
65
- next unless vertices.add?(vertex)
66
- vertex._recursive_predecessors(vertices)
67
- end
68
-
69
- vertices
70
- end
71
- protected :_recursive_predecessors
72
-
73
- # @return [Array<Vertex>] the vertices of {#graph} that have an edge with
74
- # `self` as their {Edge#origin}
75
- def successors
76
- outgoing_edges.map(&:destination)
77
- end
78
-
79
- # @return [Set<Vertex>] the vertices of {#graph} where `self` is an
80
- # {#ancestor?}
81
- def recursive_successors
82
- _recursive_successors
83
- end
84
-
85
- # @param [Set<Vertex>] vertices the set to add the successors to
86
- # @return [Set<Vertex>] the vertices of {#graph} where `self` is an
87
- # {#ancestor?}
88
- def _recursive_successors(vertices = new_vertex_set)
89
- outgoing_edges.each do |edge|
90
- vertex = edge.destination
91
- next unless vertices.add?(vertex)
92
- vertex._recursive_successors(vertices)
93
- end
94
-
95
- vertices
96
- end
97
- protected :_recursive_successors
98
-
99
- # @return [String] a string suitable for debugging
100
- def inspect
101
- "#{self.class}:#{name}(#{payload.inspect})"
102
- end
103
-
104
- # @return [Boolean] whether the two vertices are equal, determined
105
- # by a recursive traversal of each {Vertex#successors}
106
- def ==(other)
107
- return true if equal?(other)
108
- shallow_eql?(other) &&
109
- successors.to_set == other.successors.to_set
110
- end
111
-
112
- # @param [Vertex] other the other vertex to compare to
113
- # @return [Boolean] whether the two vertices are equal, determined
114
- # solely by {#name} and {#payload} equality
115
- def shallow_eql?(other)
116
- return true if equal?(other)
117
- other &&
118
- name == other.name &&
119
- payload == other.payload
120
- end
121
-
122
- alias eql? ==
123
-
124
- # @return [Fixnum] a hash for the vertex based upon its {#name}
125
- def hash
126
- name.hash
127
- end
128
-
129
- # Is there a path from `self` to `other` following edges in the
130
- # dependency graph?
131
- # @return whether there is a path following edges within this {#graph}
132
- def path_to?(other)
133
- _path_to?(other)
134
- end
135
-
136
- alias descendent? path_to?
137
-
138
- # @param [Vertex] other the vertex to check if there's a path to
139
- # @param [Set<Vertex>] visited the vertices of {#graph} that have been visited
140
- # @return [Boolean] whether there is a path to `other` from `self`
141
- def _path_to?(other, visited = new_vertex_set)
142
- return false unless visited.add?(self)
143
- return true if equal?(other)
144
- successors.any? { |v| v._path_to?(other, visited) }
145
- end
146
- protected :_path_to?
147
-
148
- # Is there a path from `other` to `self` following edges in the
149
- # dependency graph?
150
- # @return whether there is a path following edges within this {#graph}
151
- def ancestor?(other)
152
- other.path_to?(self)
153
- end
154
-
155
- alias is_reachable_from? ancestor?
156
-
157
- def new_vertex_set
158
- require 'set'
159
- Set.new
160
- end
161
- private :new_vertex_set
162
- end
163
- end
164
- end