bundler 2.1.4 → 2.3.12

Sign up to get free protection for your applications and to get access to all the features.
Files changed (277) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +2164 -1430
  3. data/README.md +7 -9
  4. data/bundler.gemspec +5 -6
  5. data/exe/bundle +10 -8
  6. data/exe/bundler +1 -1
  7. data/lib/bundler/.document +1 -0
  8. data/lib/bundler/build_metadata.rb +3 -11
  9. data/lib/bundler/cli/add.rb +1 -1
  10. data/lib/bundler/cli/binstubs.rb +6 -2
  11. data/lib/bundler/cli/cache.rb +3 -8
  12. data/lib/bundler/cli/check.rb +4 -2
  13. data/lib/bundler/cli/clean.rb +1 -1
  14. data/lib/bundler/cli/common.rb +30 -3
  15. data/lib/bundler/cli/config.rb +10 -1
  16. data/lib/bundler/cli/console.rb +1 -1
  17. data/lib/bundler/cli/doctor.rb +25 -6
  18. data/lib/bundler/cli/exec.rb +5 -10
  19. data/lib/bundler/cli/fund.rb +36 -0
  20. data/lib/bundler/cli/gem.rb +219 -28
  21. data/lib/bundler/cli/info.rb +38 -6
  22. data/lib/bundler/cli/init.rb +3 -3
  23. data/lib/bundler/cli/inject.rb +1 -1
  24. data/lib/bundler/cli/install.rb +20 -52
  25. data/lib/bundler/cli/issue.rb +5 -4
  26. data/lib/bundler/cli/list.rb +19 -11
  27. data/lib/bundler/cli/lock.rb +5 -1
  28. data/lib/bundler/cli/open.rb +1 -2
  29. data/lib/bundler/cli/outdated.rb +95 -75
  30. data/lib/bundler/cli/platform.rb +1 -1
  31. data/lib/bundler/cli/plugin.rb +10 -0
  32. data/lib/bundler/cli/pristine.rb +5 -0
  33. data/lib/bundler/cli/remove.rb +1 -2
  34. data/lib/bundler/cli/show.rb +2 -2
  35. data/lib/bundler/cli/update.rb +20 -9
  36. data/lib/bundler/cli.rb +101 -81
  37. data/lib/bundler/compact_index_client/cache.rb +6 -23
  38. data/lib/bundler/compact_index_client/gem_parser.rb +28 -0
  39. data/lib/bundler/compact_index_client/updater.rb +13 -22
  40. data/lib/bundler/compact_index_client.rb +3 -9
  41. data/lib/bundler/current_ruby.rb +6 -4
  42. data/lib/bundler/definition.rb +201 -385
  43. data/lib/bundler/dep_proxy.rb +16 -9
  44. data/lib/bundler/dependency.rb +23 -14
  45. data/lib/bundler/digest.rb +71 -0
  46. data/lib/bundler/dsl.rb +71 -74
  47. data/lib/bundler/endpoint_specification.rb +22 -12
  48. data/lib/bundler/env.rb +2 -2
  49. data/lib/bundler/environment_preserver.rb +29 -2
  50. data/lib/bundler/errors.rb +20 -3
  51. data/lib/bundler/feature_flag.rb +0 -8
  52. data/lib/bundler/fetcher/base.rb +1 -1
  53. data/lib/bundler/fetcher/compact_index.rb +11 -16
  54. data/lib/bundler/fetcher/downloader.rb +10 -7
  55. data/lib/bundler/fetcher/index.rb +2 -30
  56. data/lib/bundler/fetcher.rb +18 -23
  57. data/lib/bundler/friendly_errors.rb +25 -43
  58. data/lib/bundler/gem_helper.rb +53 -31
  59. data/lib/bundler/gem_helpers.rb +36 -25
  60. data/lib/bundler/gem_version_promoter.rb +4 -4
  61. data/lib/bundler/graph.rb +1 -1
  62. data/lib/bundler/index.rb +9 -9
  63. data/lib/bundler/injector.rb +33 -6
  64. data/lib/bundler/inline.rb +3 -2
  65. data/lib/bundler/installer/gem_installer.rb +7 -25
  66. data/lib/bundler/installer/parallel_installer.rb +46 -25
  67. data/lib/bundler/installer/standalone.rb +30 -10
  68. data/lib/bundler/installer.rb +36 -59
  69. data/lib/bundler/lazy_specification.rb +62 -26
  70. data/lib/bundler/lockfile_generator.rb +2 -2
  71. data/lib/bundler/lockfile_parser.rb +17 -46
  72. data/lib/bundler/man/.document +1 -0
  73. data/{man → lib/bundler/man}/bundle-add.1 +10 -2
  74. data/{man/bundle-add.ronn → lib/bundler/man/bundle-add.1.ronn} +7 -1
  75. data/{man → lib/bundler/man}/bundle-binstubs.1 +5 -3
  76. data/{man/bundle-binstubs.ronn → lib/bundler/man/bundle-binstubs.1.ronn} +2 -4
  77. data/{man → lib/bundler/man}/bundle-cache.1 +1 -1
  78. data/{man → lib/bundler/man}/bundle-check.1 +1 -1
  79. data/{man → lib/bundler/man}/bundle-clean.1 +1 -1
  80. data/{man → lib/bundler/man}/bundle-config.1 +44 -45
  81. data/{man/bundle-config.ronn → lib/bundler/man/bundle-config.1.ronn} +59 -60
  82. data/{man → lib/bundler/man}/bundle-doctor.1 +1 -1
  83. data/{man → lib/bundler/man}/bundle-exec.1 +1 -1
  84. data/{man → lib/bundler/man}/bundle-gem.1 +38 -3
  85. data/{man/bundle-gem.ronn → lib/bundler/man/bundle-gem.1.ronn} +46 -7
  86. data/{man → lib/bundler/man}/bundle-info.1 +1 -1
  87. data/{man → lib/bundler/man}/bundle-init.1 +1 -1
  88. data/{man → lib/bundler/man}/bundle-inject.1 +1 -1
  89. data/{man → lib/bundler/man}/bundle-install.1 +31 -4
  90. data/{man/bundle-install.ronn → lib/bundler/man/bundle-install.1.ronn} +27 -5
  91. data/{man → lib/bundler/man}/bundle-list.1 +7 -7
  92. data/{man/bundle-list.ronn → lib/bundler/man/bundle-list.1.ronn} +6 -6
  93. data/{man → lib/bundler/man}/bundle-lock.1 +1 -1
  94. data/{man → lib/bundler/man}/bundle-open.1 +1 -1
  95. data/{man → lib/bundler/man}/bundle-outdated.1 +3 -10
  96. data/{man/bundle-outdated.ronn → lib/bundler/man/bundle-outdated.1.ronn} +1 -10
  97. data/{man → lib/bundler/man}/bundle-platform.1 +1 -1
  98. data/{man → lib/bundler/man}/bundle-pristine.1 +1 -1
  99. data/{man → lib/bundler/man}/bundle-remove.1 +1 -1
  100. data/{man → lib/bundler/man}/bundle-show.1 +1 -1
  101. data/{man → lib/bundler/man}/bundle-update.1 +5 -5
  102. data/{man/bundle-update.ronn → lib/bundler/man/bundle-update.1.ronn} +5 -4
  103. data/{man → lib/bundler/man}/bundle-viz.1 +1 -1
  104. data/{man → lib/bundler/man}/bundle.1 +1 -1
  105. data/{man → lib/bundler/man}/gemfile.5 +31 -5
  106. data/{man → lib/bundler/man}/gemfile.5.ronn +13 -5
  107. data/lib/bundler/mirror.rb +2 -2
  108. data/lib/bundler/plugin/api/source.rb +23 -7
  109. data/lib/bundler/plugin/dsl.rb +1 -1
  110. data/lib/bundler/plugin/index.rb +13 -1
  111. data/lib/bundler/plugin/installer/rubygems.rb +1 -1
  112. data/lib/bundler/plugin/installer.rb +11 -11
  113. data/lib/bundler/plugin/source_list.rb +5 -1
  114. data/lib/bundler/plugin.rb +56 -11
  115. data/lib/bundler/process_lock.rb +1 -1
  116. data/lib/bundler/remote_specification.rb +12 -2
  117. data/lib/bundler/resolver/spec_group.rb +58 -55
  118. data/lib/bundler/resolver.rb +176 -177
  119. data/lib/bundler/retry.rb +2 -2
  120. data/lib/bundler/ruby_version.rb +2 -15
  121. data/lib/bundler/rubygems_ext.rb +137 -28
  122. data/lib/bundler/rubygems_gem_installer.rb +69 -8
  123. data/lib/bundler/rubygems_integration.rb +69 -133
  124. data/lib/bundler/runtime.rb +22 -25
  125. data/lib/bundler/self_manager.rb +168 -0
  126. data/lib/bundler/settings.rb +144 -65
  127. data/lib/bundler/setup.rb +2 -2
  128. data/lib/bundler/shared_helpers.rb +12 -27
  129. data/lib/bundler/similarity_detector.rb +1 -1
  130. data/lib/bundler/source/git/git_proxy.rb +88 -84
  131. data/lib/bundler/source/git.rb +43 -23
  132. data/lib/bundler/source/metadata.rb +3 -7
  133. data/lib/bundler/source/path/installer.rb +10 -10
  134. data/lib/bundler/source/path.rb +10 -4
  135. data/lib/bundler/source/rubygems/remote.rb +1 -1
  136. data/lib/bundler/source/rubygems.rb +126 -116
  137. data/lib/bundler/source/rubygems_aggregate.rb +68 -0
  138. data/lib/bundler/source.rb +22 -1
  139. data/lib/bundler/source_list.rb +101 -63
  140. data/lib/bundler/source_map.rb +71 -0
  141. data/lib/bundler/spec_set.rb +26 -41
  142. data/lib/bundler/stub_specification.rb +25 -7
  143. data/lib/bundler/templates/Executable +2 -4
  144. data/lib/bundler/templates/Executable.bundler +8 -8
  145. data/lib/bundler/templates/Executable.standalone +2 -4
  146. data/lib/bundler/templates/Gemfile +0 -2
  147. data/lib/bundler/templates/gems.rb +0 -3
  148. data/lib/bundler/templates/newgem/CHANGELOG.md.tt +5 -0
  149. data/lib/bundler/templates/newgem/CODE_OF_CONDUCT.md.tt +57 -47
  150. data/lib/bundler/templates/newgem/Gemfile.tt +12 -1
  151. data/lib/bundler/templates/newgem/README.md.tt +9 -14
  152. data/lib/bundler/templates/newgem/Rakefile.tt +32 -5
  153. data/lib/bundler/templates/newgem/bin/console.tt +1 -0
  154. data/lib/bundler/templates/newgem/circleci/config.yml.tt +13 -0
  155. data/lib/bundler/templates/newgem/ext/newgem/extconf.rb.tt +2 -0
  156. data/lib/bundler/templates/newgem/github/workflows/main.yml.tt +27 -0
  157. data/lib/bundler/templates/newgem/gitlab-ci.yml.tt +9 -0
  158. data/lib/bundler/templates/newgem/lib/newgem/version.rb.tt +2 -0
  159. data/lib/bundler/templates/newgem/lib/newgem.rb.tt +4 -2
  160. data/lib/bundler/templates/newgem/newgem.gemspec.tt +27 -17
  161. data/lib/bundler/templates/newgem/rubocop.yml.tt +13 -0
  162. data/lib/bundler/templates/newgem/sig/newgem.rbs.tt +8 -0
  163. data/lib/bundler/templates/newgem/spec/newgem_spec.rb.tt +2 -0
  164. data/lib/bundler/templates/newgem/spec/spec_helper.rb.tt +2 -1
  165. data/lib/bundler/templates/newgem/standard.yml.tt +3 -0
  166. data/lib/bundler/templates/newgem/test/{test_helper.rb.tt → minitest/test_helper.rb.tt} +2 -0
  167. data/lib/bundler/templates/newgem/test/{newgem_test.rb.tt → minitest/test_newgem.rb.tt} +3 -1
  168. data/lib/bundler/templates/newgem/test/test-unit/newgem_test.rb.tt +15 -0
  169. data/lib/bundler/templates/newgem/test/test-unit/test_helper.rb.tt +6 -0
  170. data/lib/bundler/ui/shell.rb +6 -6
  171. data/lib/bundler/uri_credentials_filter.rb +3 -1
  172. data/lib/bundler/vendor/.document +1 -0
  173. data/lib/bundler/vendor/connection_pool/LICENSE +20 -0
  174. data/lib/bundler/vendor/connection_pool/lib/connection_pool/timed_stack.rb +19 -21
  175. data/lib/bundler/vendor/connection_pool/lib/connection_pool/version.rb +1 -1
  176. data/lib/bundler/vendor/connection_pool/lib/connection_pool/wrapper.rb +57 -0
  177. data/lib/bundler/vendor/connection_pool/lib/connection_pool.rb +39 -74
  178. data/lib/bundler/vendor/fileutils/LICENSE.txt +22 -0
  179. data/lib/bundler/vendor/molinillo/LICENSE +9 -0
  180. data/lib/bundler/vendor/molinillo/lib/molinillo/delegates/specification_provider.rb +7 -0
  181. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/tag.rb +2 -2
  182. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/vertex.rb +11 -5
  183. data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph.rb +37 -5
  184. data/lib/bundler/vendor/molinillo/lib/molinillo/errors.rb +34 -28
  185. data/lib/bundler/vendor/molinillo/lib/molinillo/gem_metadata.rb +1 -1
  186. data/lib/bundler/vendor/molinillo/lib/molinillo/modules/specification_provider.rb +12 -1
  187. data/lib/bundler/vendor/molinillo/lib/molinillo/resolution.rb +49 -47
  188. data/lib/bundler/vendor/molinillo/lib/molinillo.rb +0 -1
  189. data/lib/bundler/vendor/net-http-persistent/README.rdoc +82 -0
  190. data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent.rb +82 -189
  191. data/lib/bundler/vendor/thor/LICENSE.md +20 -0
  192. data/lib/bundler/vendor/thor/lib/thor/actions/create_link.rb +2 -1
  193. data/lib/bundler/vendor/thor/lib/thor/actions/file_manipulation.rb +9 -7
  194. data/lib/bundler/vendor/thor/lib/thor/actions/inject_into_file.rb +1 -2
  195. data/lib/bundler/vendor/thor/lib/thor/actions.rb +7 -3
  196. data/lib/bundler/vendor/thor/lib/thor/base.rb +9 -0
  197. data/lib/bundler/vendor/thor/lib/thor/core_ext/hash_with_indifferent_access.rb +6 -0
  198. data/lib/bundler/vendor/thor/lib/thor/error.rb +10 -5
  199. data/lib/bundler/vendor/thor/lib/thor/parser/arguments.rb +5 -1
  200. data/lib/bundler/vendor/thor/lib/thor/parser/options.rb +28 -9
  201. data/lib/bundler/vendor/thor/lib/thor/shell/basic.rb +27 -6
  202. data/lib/bundler/vendor/thor/lib/thor/shell/color.rb +5 -1
  203. data/lib/bundler/vendor/thor/lib/thor/shell.rb +1 -1
  204. data/lib/bundler/vendor/thor/lib/thor/util.rb +1 -1
  205. data/lib/bundler/vendor/thor/lib/thor/version.rb +1 -1
  206. data/lib/bundler/vendor/thor/lib/thor.rb +5 -13
  207. data/lib/bundler/vendor/tmpdir/lib/tmpdir.rb +154 -0
  208. data/lib/bundler/vendor/tsort/LICENSE.txt +22 -0
  209. data/lib/bundler/vendor/tsort/lib/tsort.rb +452 -0
  210. data/lib/bundler/vendor/uri/LICENSE.txt +22 -0
  211. data/lib/bundler/vendor/uri/lib/uri/common.rb +17 -80
  212. data/lib/bundler/vendor/uri/lib/uri/ftp.rb +0 -1
  213. data/lib/bundler/vendor/uri/lib/uri/generic.rb +5 -6
  214. data/lib/bundler/vendor/uri/lib/uri/http.rb +0 -1
  215. data/lib/bundler/vendor/uri/lib/uri/https.rb +0 -1
  216. data/lib/bundler/vendor/uri/lib/uri/ldap.rb +1 -1
  217. data/lib/bundler/vendor/uri/lib/uri/mailto.rb +0 -1
  218. data/lib/bundler/vendor/uri/lib/uri/rfc2396_parser.rb +1 -14
  219. data/lib/bundler/vendor/uri/lib/uri/rfc3986_parser.rb +1 -12
  220. data/lib/bundler/vendor/uri/lib/uri/version.rb +1 -1
  221. data/lib/bundler/vendor/uri/lib/uri/ws.rb +84 -0
  222. data/lib/bundler/vendor/uri/lib/uri/wss.rb +22 -0
  223. data/lib/bundler/vendor/uri/lib/uri.rb +0 -1
  224. data/lib/bundler/vendored_persistent.rb +0 -7
  225. data/lib/bundler/vendored_tmpdir.rb +4 -0
  226. data/lib/bundler/vendored_tsort.rb +4 -0
  227. data/lib/bundler/version.rb +1 -1
  228. data/lib/bundler/worker.rb +20 -5
  229. data/lib/bundler/yaml_serializer.rb +1 -1
  230. data/lib/bundler.rb +64 -43
  231. metadata +94 -91
  232. data/lib/bundler/gemdeps.rb +0 -29
  233. data/lib/bundler/psyched_yaml.rb +0 -37
  234. data/lib/bundler/vendor/connection_pool/lib/connection_pool/monotonic_time.rb +0 -66
  235. data/lib/bundler/vendor/molinillo/lib/molinillo/compatibility.rb +0 -26
  236. data/man/bundle-add.1.txt +0 -58
  237. data/man/bundle-binstubs.1.txt +0 -48
  238. data/man/bundle-cache.1.txt +0 -78
  239. data/man/bundle-check.1.txt +0 -33
  240. data/man/bundle-clean.1.txt +0 -26
  241. data/man/bundle-config.1.txt +0 -528
  242. data/man/bundle-doctor.1.txt +0 -44
  243. data/man/bundle-exec.1.txt +0 -178
  244. data/man/bundle-gem.1.txt +0 -91
  245. data/man/bundle-info.1.txt +0 -21
  246. data/man/bundle-init.1.txt +0 -34
  247. data/man/bundle-inject.1.txt +0 -32
  248. data/man/bundle-install.1.txt +0 -401
  249. data/man/bundle-list.1.txt +0 -43
  250. data/man/bundle-lock.1.txt +0 -93
  251. data/man/bundle-open.1.txt +0 -29
  252. data/man/bundle-outdated.1.txt +0 -131
  253. data/man/bundle-platform.1.txt +0 -57
  254. data/man/bundle-pristine.1.txt +0 -44
  255. data/man/bundle-remove.1.txt +0 -34
  256. data/man/bundle-show.1.txt +0 -27
  257. data/man/bundle-update.1.txt +0 -390
  258. data/man/bundle-viz.1.txt +0 -39
  259. data/man/bundle.1.txt +0 -116
  260. data/man/gemfile.5.txt +0 -649
  261. /data/{man/bundle-cache.ronn → lib/bundler/man/bundle-cache.1.ronn} +0 -0
  262. /data/{man/bundle-check.ronn → lib/bundler/man/bundle-check.1.ronn} +0 -0
  263. /data/{man/bundle-clean.ronn → lib/bundler/man/bundle-clean.1.ronn} +0 -0
  264. /data/{man/bundle-doctor.ronn → lib/bundler/man/bundle-doctor.1.ronn} +0 -0
  265. /data/{man/bundle-exec.ronn → lib/bundler/man/bundle-exec.1.ronn} +0 -0
  266. /data/{man/bundle-info.ronn → lib/bundler/man/bundle-info.1.ronn} +0 -0
  267. /data/{man/bundle-init.ronn → lib/bundler/man/bundle-init.1.ronn} +0 -0
  268. /data/{man/bundle-inject.ronn → lib/bundler/man/bundle-inject.1.ronn} +0 -0
  269. /data/{man/bundle-lock.ronn → lib/bundler/man/bundle-lock.1.ronn} +0 -0
  270. /data/{man/bundle-open.ronn → lib/bundler/man/bundle-open.1.ronn} +0 -0
  271. /data/{man/bundle-platform.ronn → lib/bundler/man/bundle-platform.1.ronn} +0 -0
  272. /data/{man/bundle-pristine.ronn → lib/bundler/man/bundle-pristine.1.ronn} +0 -0
  273. /data/{man/bundle-remove.ronn → lib/bundler/man/bundle-remove.1.ronn} +0 -0
  274. /data/{man/bundle-show.ronn → lib/bundler/man/bundle-show.1.ronn} +0 -0
  275. /data/{man/bundle-viz.ronn → lib/bundler/man/bundle-viz.1.ronn} +0 -0
  276. /data/{man/bundle.ronn → lib/bundler/man/bundle.1.ronn} +0 -0
  277. /data/{man → lib/bundler/man}/index.txt +0 -0
@@ -1,57 +0,0 @@
1
- BUNDLE-PLATFORM(1) BUNDLE-PLATFORM(1)
2
-
3
-
4
-
5
- NAME
6
- bundle-platform - Displays platform compatibility information
7
-
8
- SYNOPSIS
9
- bundle platform [--ruby]
10
-
11
- DESCRIPTION
12
- platform will display information from your Gemfile, Gemfile.lock, and
13
- Ruby VM about your platform.
14
-
15
- For instance, using this Gemfile(5):
16
-
17
-
18
-
19
- source "https://rubygems.org"
20
-
21
- ruby "1.9.3"
22
-
23
- gem "rack"
24
-
25
-
26
-
27
- If you run bundle platform on Ruby 1.9.3, it will display the following
28
- output:
29
-
30
-
31
-
32
- Your platform is: x86_64-linux
33
-
34
- Your app has gems that work on these platforms:
35
- * ruby
36
-
37
- Your Gemfile specifies a Ruby version requirement:
38
- * ruby 1.9.3
39
-
40
- Your current platform satisfies the Ruby version requirement.
41
-
42
-
43
-
44
- platform will list all the platforms in your Gemfile.lock as well as
45
- the ruby directive if applicable from your Gemfile(5). It will also let
46
- you know if the ruby directive requirement has been met. If ruby direc-
47
- tive doesn't match the running Ruby VM, it will tell you what part does
48
- not.
49
-
50
- OPTIONS
51
- --ruby It will display the ruby directive information, so you don't
52
- have to parse it from the Gemfile(5).
53
-
54
-
55
-
56
-
57
- January 2020 BUNDLE-PLATFORM(1)
@@ -1,44 +0,0 @@
1
- BUNDLE-PRISTINE(1) BUNDLE-PRISTINE(1)
2
-
3
-
4
-
5
- NAME
6
- bundle-pristine - Restores installed gems to their pristine condition
7
-
8
- SYNOPSIS
9
- bundle pristine
10
-
11
- DESCRIPTION
12
- pristine restores the installed gems in the bundle to their pristine
13
- condition using the local gem cache from RubyGems. For git gems, a
14
- forced checkout will be performed.
15
-
16
- For further explanation, bundle pristine ignores unpacked files on
17
- disk. In other words, this command utilizes the local .gem cache or the
18
- gem's git repository as if one were installing from scratch.
19
-
20
- Note: the Bundler gem cannot be restored to its original state with
21
- pristine. One also cannot use bundle pristine on gems with a 'path'
22
- option in the Gemfile, because bundler has no original copy it can
23
- restore from.
24
-
25
- When is it practical to use bundle pristine?
26
-
27
- It comes in handy when a developer is debugging a gem. bundle pristine
28
- is a great way to get rid of experimental changes to a gem that one may
29
- not want.
30
-
31
- Why use bundle pristine over gem pristine --all?
32
-
33
- Both commands are very similar. For context: bundle pristine, without
34
- arguments, cleans all gems from the lockfile. Meanwhile, gem pristine
35
- --all cleans all installed gems for that Ruby version.
36
-
37
- If a developer forgets which gems in their project they might have been
38
- debugging, the Rubygems gem pristine [GEMNAME] command may be inconve-
39
- nient. One can avoid waiting for gem pristine --all, and instead run
40
- bundle pristine.
41
-
42
-
43
-
44
- January 2020 BUNDLE-PRISTINE(1)
@@ -1,34 +0,0 @@
1
- BUNDLE-REMOVE(1) BUNDLE-REMOVE(1)
2
-
3
-
4
-
5
- NAME
6
- bundle-remove - Removes gems from the Gemfile
7
-
8
- SYNOPSIS
9
- bundle remove [GEM [GEM ...]] [--install]
10
-
11
- DESCRIPTION
12
- Removes the given gems from the Gemfile while ensuring that the result-
13
- ing Gemfile is still valid. If a gem cannot be removed, a warning is
14
- printed. If a gem is already absent from the Gemfile, and error is
15
- raised.
16
-
17
- OPTIONS
18
- --install
19
- Runs bundle install after the given gems have been removed from
20
- the Gemfile, which ensures that both the lockfile and the
21
- installed gems on disk are also updated to remove the given
22
- gem(s).
23
-
24
- Example:
25
-
26
- bundle remove rails
27
-
28
- bundle remove rails rack
29
-
30
- bundle remove rails rack --install
31
-
32
-
33
-
34
- January 2020 BUNDLE-REMOVE(1)
@@ -1,27 +0,0 @@
1
- BUNDLE-SHOW(1) BUNDLE-SHOW(1)
2
-
3
-
4
-
5
- NAME
6
- bundle-show - Shows all the gems in your bundle, or the path to a gem
7
-
8
- SYNOPSIS
9
- bundle show [GEM] [--paths]
10
-
11
- DESCRIPTION
12
- Without the [GEM] option, show will print a list of the names and ver-
13
- sions of all gems that are required by your [Gemfile(5)][Gemfile(5)],
14
- sorted by name.
15
-
16
- Calling show with [GEM] will list the exact location of that gem on
17
- your machine.
18
-
19
- OPTIONS
20
- --paths
21
- List the paths of all gems that are required by your [Gem-
22
- file(5)][Gemfile(5)], sorted by gem name.
23
-
24
-
25
-
26
-
27
- January 2020 BUNDLE-SHOW(1)
@@ -1,390 +0,0 @@
1
- BUNDLE-UPDATE(1) BUNDLE-UPDATE(1)
2
-
3
-
4
-
5
- NAME
6
- bundle-update - Update your gems to the latest available versions
7
-
8
- SYNOPSIS
9
- bundle update *gems [--all] [--group=NAME] [--source=NAME] [--local]
10
- [--ruby] [--bundler[=VERSION]] [--full-index] [--jobs=JOBS] [--quiet]
11
- [--patch|--minor|--major] [--redownload] [--strict] [--conservative]
12
-
13
- DESCRIPTION
14
- Update the gems specified (all gems, if --all flag is used), ignoring
15
- the previously installed gems specified in the Gemfile.lock. In gen-
16
- eral, you should use bundle install(1) bundle-install.1.html to install
17
- the same exact gems and versions across machines.
18
-
19
- You would use bundle update to explicitly update the version of a gem.
20
-
21
- OPTIONS
22
- --all Update all gems specified in Gemfile.
23
-
24
- --group=<name>, -g=[<name>]
25
- Only update the gems in the specified group. For instance, you
26
- can update all gems in the development group with bundle update
27
- --group development. You can also call bundle update rails
28
- --group test to update the rails gem and all gems in the test
29
- group, for example.
30
-
31
- --source=<name>
32
- The name of a :git or :path source used in the Gemfile(5). For
33
- instance, with a :git source of
34
- http://github.com/rails/rails.git, you would call bundle update
35
- --source rails
36
-
37
- --local
38
- Do not attempt to fetch gems remotely and use the gem cache
39
- instead.
40
-
41
- --ruby Update the locked version of Ruby to the current version of
42
- Ruby.
43
-
44
- --bundler
45
- Update the locked version of bundler to the invoked bundler ver-
46
- sion.
47
-
48
- --full-index
49
- Fall back to using the single-file index of all gems.
50
-
51
- --jobs=[<number>], -j[<number>]
52
- Specify the number of jobs to run in parallel. The default is 1.
53
-
54
- --retry=[<number>]
55
- Retry failed network or git requests for number times.
56
-
57
- --quiet
58
- Only output warnings and errors.
59
-
60
- --redownload
61
- Force downloading every gem.
62
-
63
- --patch
64
- Prefer updating only to next patch version.
65
-
66
- --minor
67
- Prefer updating only to next minor version.
68
-
69
- --major
70
- Prefer updating to next major version (default).
71
-
72
- --strict
73
- Do not allow any gem to be updated past latest --patch | --minor
74
- | --major.
75
-
76
- --conservative
77
- Use bundle install conservative update behavior and do not allow
78
- shared dependencies to be updated.
79
-
80
- UPDATING ALL GEMS
81
- If you run bundle update --all, bundler will ignore any previously
82
- installed gems and resolve all dependencies again based on the latest
83
- versions of all gems available in the sources.
84
-
85
- Consider the following Gemfile(5):
86
-
87
-
88
-
89
- source "https://rubygems.org"
90
-
91
- gem "rails", "3.0.0.rc"
92
- gem "nokogiri"
93
-
94
-
95
-
96
- When you run bundle install(1) bundle-install.1.html the first time,
97
- bundler will resolve all of the dependencies, all the way down, and
98
- install what you need:
99
-
100
-
101
-
102
- Fetching gem metadata from https://rubygems.org/.........
103
- Resolving dependencies...
104
- Installing builder 2.1.2
105
- Installing abstract 1.0.0
106
- Installing rack 1.2.8
107
- Using bundler 1.7.6
108
- Installing rake 10.4.0
109
- Installing polyglot 0.3.5
110
- Installing mime-types 1.25.1
111
- Installing i18n 0.4.2
112
- Installing mini_portile 0.6.1
113
- Installing tzinfo 0.3.42
114
- Installing rack-mount 0.6.14
115
- Installing rack-test 0.5.7
116
- Installing treetop 1.4.15
117
- Installing thor 0.14.6
118
- Installing activesupport 3.0.0.rc
119
- Installing erubis 2.6.6
120
- Installing activemodel 3.0.0.rc
121
- Installing arel 0.4.0
122
- Installing mail 2.2.20
123
- Installing activeresource 3.0.0.rc
124
- Installing actionpack 3.0.0.rc
125
- Installing activerecord 3.0.0.rc
126
- Installing actionmailer 3.0.0.rc
127
- Installing railties 3.0.0.rc
128
- Installing rails 3.0.0.rc
129
- Installing nokogiri 1.6.5
130
-
131
- Bundle complete! 2 Gemfile dependencies, 26 gems total.
132
- Use `bundle show [gemname]` to see where a bundled gem is installed.
133
-
134
-
135
-
136
- As you can see, even though you have two gems in the Gemfile(5), your
137
- application needs 26 different gems in order to run. Bundler remembers
138
- the exact versions it installed in Gemfile.lock. The next time you run
139
- bundle install(1) bundle-install.1.html, bundler skips the dependency
140
- resolution and installs the same gems as it installed last time.
141
-
142
- After checking in the Gemfile.lock into version control and cloning it
143
- on another machine, running bundle install(1) bundle-install.1.html
144
- will still install the gems that you installed last time. You don't
145
- need to worry that a new release of erubis or mail changes the gems you
146
- use.
147
-
148
- However, from time to time, you might want to update the gems you are
149
- using to the newest versions that still match the gems in your Gem-
150
- file(5).
151
-
152
- To do this, run bundle update --all, which will ignore the Gem-
153
- file.lock, and resolve all the dependencies again. Keep in mind that
154
- this process can result in a significantly different set of the 25
155
- gems, based on the requirements of new gems that the gem authors
156
- released since the last time you ran bundle update --all.
157
-
158
- UPDATING A LIST OF GEMS
159
- Sometimes, you want to update a single gem in the Gemfile(5), and leave
160
- the rest of the gems that you specified locked to the versions in the
161
- Gemfile.lock.
162
-
163
- For instance, in the scenario above, imagine that nokogiri releases
164
- version 1.4.4, and you want to update it without updating Rails and all
165
- of its dependencies. To do this, run bundle update nokogiri.
166
-
167
- Bundler will update nokogiri and any of its dependencies, but leave
168
- alone Rails and its dependencies.
169
-
170
- OVERLAPPING DEPENDENCIES
171
- Sometimes, multiple gems declared in your Gemfile(5) are satisfied by
172
- the same second-level dependency. For instance, consider the case of
173
- thin and rack-perftools-profiler.
174
-
175
-
176
-
177
- source "https://rubygems.org"
178
-
179
- gem "thin"
180
- gem "rack-perftools-profiler"
181
-
182
-
183
-
184
- The thin gem depends on rack >= 1.0, while rack-perftools-profiler
185
- depends on rack ~> 1.0. If you run bundle install, you get:
186
-
187
-
188
-
189
- Fetching source index for https://rubygems.org/
190
- Installing daemons (1.1.0)
191
- Installing eventmachine (0.12.10) with native extensions
192
- Installing open4 (1.0.1)
193
- Installing perftools.rb (0.4.7) with native extensions
194
- Installing rack (1.2.1)
195
- Installing rack-perftools_profiler (0.0.2)
196
- Installing thin (1.2.7) with native extensions
197
- Using bundler (1.0.0.rc.3)
198
-
199
-
200
-
201
- In this case, the two gems have their own set of dependencies, but they
202
- share rack in common. If you run bundle update thin, bundler will
203
- update daemons, eventmachine and rack, which are dependencies of thin,
204
- but not open4 or perftools.rb, which are dependencies of
205
- rack-perftools_profiler. Note that bundle update thin will update rack
206
- even though it's also a dependency of rack-perftools_profiler.
207
-
208
- In short, by default, when you update a gem using bundle update,
209
- bundler will update all dependencies of that gem, including those that
210
- are also dependencies of another gem.
211
-
212
- To prevent updating shared dependencies, prior to version 1.14 the only
213
- option was the CONSERVATIVE UPDATING behavior in bundle install(1) bun-
214
- dle-install.1.html:
215
-
216
- In this scenario, updating the thin version manually in the Gemfile(5),
217
- and then running bundle install(1) bundle-install.1.html will only
218
- update daemons and eventmachine, but not rack. For more information,
219
- see the CONSERVATIVE UPDATING section of bundle install(1) bun-
220
- dle-install.1.html.
221
-
222
- Starting with 1.14, specifying the --conservative option will also pre-
223
- vent shared dependencies from being updated.
224
-
225
- PATCH LEVEL OPTIONS
226
- Version 1.14 introduced 4 patch-level options that will influence how
227
- gem versions are resolved. One of the following options can be used:
228
- --patch, --minor or --major. --strict can be added to further influence
229
- resolution.
230
-
231
- --patch
232
- Prefer updating only to next patch version.
233
-
234
- --minor
235
- Prefer updating only to next minor version.
236
-
237
- --major
238
- Prefer updating to next major version (default).
239
-
240
- --strict
241
- Do not allow any gem to be updated past latest --patch | --minor
242
- | --major.
243
-
244
- When Bundler is resolving what versions to use to satisfy declared
245
- requirements in the Gemfile or in parent gems, it looks up all avail-
246
- able versions, filters out any versions that don't satisfy the require-
247
- ment, and then, by default, sorts them from newest to oldest, consider-
248
- ing them in that order.
249
-
250
- Providing one of the patch level options (e.g. --patch) changes the
251
- sort order of the satisfying versions, causing Bundler to consider the
252
- latest --patch or --minor version available before other versions. Note
253
- that versions outside the stated patch level could still be resolved to
254
- if necessary to find a suitable dependency graph.
255
-
256
- For example, if gem 'foo' is locked at 1.0.2, with no gem requirement
257
- defined in the Gemfile, and versions 1.0.3, 1.0.4, 1.1.0, 1.1.1, 2.0.0
258
- all exist, the default order of preference by default (--major) will be
259
- "2.0.0, 1.1.1, 1.1.0, 1.0.4, 1.0.3, 1.0.2".
260
-
261
- If the --patch option is used, the order of preference will change to
262
- "1.0.4, 1.0.3, 1.0.2, 1.1.1, 1.1.0, 2.0.0".
263
-
264
- If the --minor option is used, the order of preference will change to
265
- "1.1.1, 1.1.0, 1.0.4, 1.0.3, 1.0.2, 2.0.0".
266
-
267
- Combining the --strict option with any of the patch level options will
268
- remove any versions beyond the scope of the patch level option, to
269
- ensure that no gem is updated that far.
270
-
271
- To continue the previous example, if both --patch and --strict options
272
- are used, the available versions for resolution would be "1.0.4, 1.0.3,
273
- 1.0.2". If --minor and --strict are used, it would be "1.1.1, 1.1.0,
274
- 1.0.4, 1.0.3, 1.0.2".
275
-
276
- Gem requirements as defined in the Gemfile will still be the first
277
- determining factor for what versions are available. If the gem require-
278
- ment for foo in the Gemfile is '~> 1.0', that will accomplish the same
279
- thing as providing the --minor and --strict options.
280
-
281
- PATCH LEVEL EXAMPLES
282
- Given the following gem specifications:
283
-
284
-
285
-
286
- foo 1.4.3, requires: ~> bar 2.0
287
- foo 1.4.4, requires: ~> bar 2.0
288
- foo 1.4.5, requires: ~> bar 2.1
289
- foo 1.5.0, requires: ~> bar 2.1
290
- foo 1.5.1, requires: ~> bar 3.0
291
- bar with versions 2.0.3, 2.0.4, 2.1.0, 2.1.1, 3.0.0
292
-
293
-
294
-
295
- Gemfile:
296
-
297
-
298
-
299
- gem 'foo'
300
-
301
-
302
-
303
- Gemfile.lock:
304
-
305
-
306
-
307
- foo (1.4.3)
308
- bar (~> 2.0)
309
- bar (2.0.3)
310
-
311
-
312
-
313
- Cases:
314
-
315
-
316
-
317
- # Command Line Result
318
- ------------------------------------------------------------
319
- 1 bundle update --patch 'foo 1.4.5', 'bar 2.1.1'
320
- 2 bundle update --patch foo 'foo 1.4.5', 'bar 2.1.1'
321
- 3 bundle update --minor 'foo 1.5.1', 'bar 3.0.0'
322
- 4 bundle update --minor --strict 'foo 1.5.0', 'bar 2.1.1'
323
- 5 bundle update --patch --strict 'foo 1.4.4', 'bar 2.0.4'
324
-
325
-
326
-
327
- In case 1, bar is upgraded to 2.1.1, a minor version increase, because
328
- the dependency from foo 1.4.5 required it.
329
-
330
- In case 2, only foo is requested to be unlocked, but bar is also
331
- allowed to move because it's not a declared dependency in the Gemfile.
332
-
333
- In case 3, bar goes up a whole major release, because a minor increase
334
- is preferred now for foo, and when it goes to 1.5.1, it requires 3.0.0
335
- of bar.
336
-
337
- In case 4, foo is preferred up to a minor version, but 1.5.1 won't work
338
- because the --strict flag removes bar 3.0.0 from consideration since
339
- it's a major increment.
340
-
341
- In case 5, both foo and bar have any minor or major increments removed
342
- from consideration because of the --strict flag, so the most they can
343
- move is up to 1.4.4 and 2.0.4.
344
-
345
- RECOMMENDED WORKFLOW
346
- In general, when working with an application managed with bundler, you
347
- should use the following workflow:
348
-
349
- o After you create your Gemfile(5) for the first time, run
350
-
351
- $ bundle install
352
-
353
- o Check the resulting Gemfile.lock into version control
354
-
355
- $ git add Gemfile.lock
356
-
357
- o When checking out this repository on another development machine,
358
- run
359
-
360
- $ bundle install
361
-
362
- o When checking out this repository on a deployment machine, run
363
-
364
- $ bundle install --deployment
365
-
366
- o After changing the Gemfile(5) to reflect a new or update depen-
367
- dency, run
368
-
369
- $ bundle install
370
-
371
- o Make sure to check the updated Gemfile.lock into version control
372
-
373
- $ git add Gemfile.lock
374
-
375
- o If bundle install(1) bundle-install.1.html reports a conflict, man-
376
- ually update the specific gems that you changed in the Gemfile(5)
377
-
378
- $ bundle update rails thin
379
-
380
- o If you want to update all the gems to the latest possible versions
381
- that still match the gems listed in the Gemfile(5), run
382
-
383
- $ bundle update --all
384
-
385
-
386
-
387
-
388
-
389
-
390
- January 2020 BUNDLE-UPDATE(1)
data/man/bundle-viz.1.txt DELETED
@@ -1,39 +0,0 @@
1
- BUNDLE-VIZ(1) BUNDLE-VIZ(1)
2
-
3
-
4
-
5
- NAME
6
- bundle-viz - Generates a visual dependency graph for your Gemfile
7
-
8
- SYNOPSIS
9
- bundle viz [--file=FILE] [--format=FORMAT] [--requirements] [--version]
10
- [--without=GROUP GROUP]
11
-
12
- DESCRIPTION
13
- viz generates a PNG file of the current Gemfile(5) as a dependency
14
- graph. viz requires the ruby-graphviz gem (and its dependencies).
15
-
16
- The associated gems must also be installed via bundle install(1) bun-
17
- dle-install.1.html.
18
-
19
- OPTIONS
20
- --file, -f
21
- The name to use for the generated file. See --format option
22
-
23
- --format, -F
24
- This is output format option. Supported format is png, jpg, svg,
25
- dot ...
26
-
27
- --requirements, -R
28
- Set to show the version of each required dependency.
29
-
30
- --version, -v
31
- Set to show each gem version.
32
-
33
- --without, -W
34
- Exclude gems that are part of the specified named group.
35
-
36
-
37
-
38
-
39
- January 2020 BUNDLE-VIZ(1)