bundler 2.5.22 → 2.6.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (157) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +83 -0
  3. data/bundler.gemspec +2 -2
  4. data/lib/bundler/build_metadata.rb +2 -2
  5. data/lib/bundler/cli/add.rb +2 -0
  6. data/lib/bundler/cli/check.rb +2 -2
  7. data/lib/bundler/cli/console.rb +0 -4
  8. data/lib/bundler/cli/doctor.rb +4 -4
  9. data/lib/bundler/cli/exec.rb +1 -0
  10. data/lib/bundler/cli/gem.rb +1 -1
  11. data/lib/bundler/cli/info.rb +2 -2
  12. data/lib/bundler/cli/inject.rb +1 -1
  13. data/lib/bundler/cli/install.rb +4 -0
  14. data/lib/bundler/cli/lock.rb +20 -1
  15. data/lib/bundler/cli/pristine.rb +1 -1
  16. data/lib/bundler/cli/show.rb +2 -2
  17. data/lib/bundler/cli.rb +23 -53
  18. data/lib/bundler/compact_index_client/cache_file.rb +0 -5
  19. data/lib/bundler/compact_index_client/updater.rb +0 -11
  20. data/lib/bundler/definition.rb +143 -76
  21. data/lib/bundler/dependency.rb +1 -1
  22. data/lib/bundler/dsl.rb +33 -28
  23. data/lib/bundler/endpoint_specification.rb +10 -1
  24. data/lib/bundler/errors.rb +10 -0
  25. data/lib/bundler/feature_flag.rb +1 -0
  26. data/lib/bundler/fetcher/compact_index.rb +1 -1
  27. data/lib/bundler/fetcher.rb +10 -3
  28. data/lib/bundler/gem_helpers.rb +21 -5
  29. data/lib/bundler/injector.rb +2 -2
  30. data/lib/bundler/inline.rb +12 -8
  31. data/lib/bundler/installer/standalone.rb +2 -2
  32. data/lib/bundler/installer.rb +4 -38
  33. data/lib/bundler/lazy_specification.rb +74 -26
  34. data/lib/bundler/lockfile_generator.rb +1 -1
  35. data/lib/bundler/lockfile_parser.rb +9 -1
  36. data/lib/bundler/man/bundle-add.1 +17 -11
  37. data/lib/bundler/man/bundle-add.1.ronn +16 -10
  38. data/lib/bundler/man/bundle-binstubs.1 +7 -4
  39. data/lib/bundler/man/bundle-binstubs.1.ronn +6 -3
  40. data/lib/bundler/man/bundle-cache.1 +30 -2
  41. data/lib/bundler/man/bundle-cache.1.ronn +31 -2
  42. data/lib/bundler/man/bundle-check.1 +3 -3
  43. data/lib/bundler/man/bundle-check.1.ronn +4 -2
  44. data/lib/bundler/man/bundle-clean.1 +1 -1
  45. data/lib/bundler/man/bundle-config.1 +3 -5
  46. data/lib/bundler/man/bundle-config.1.ronn +2 -7
  47. data/lib/bundler/man/bundle-console.1 +2 -4
  48. data/lib/bundler/man/bundle-console.1.ronn +2 -7
  49. data/lib/bundler/man/bundle-doctor.1 +2 -2
  50. data/lib/bundler/man/bundle-doctor.1.ronn +1 -1
  51. data/lib/bundler/man/bundle-env.1 +9 -0
  52. data/lib/bundler/man/bundle-env.1.ronn +10 -0
  53. data/lib/bundler/man/bundle-exec.1 +5 -2
  54. data/lib/bundler/man/bundle-exec.1.ronn +4 -1
  55. data/lib/bundler/man/bundle-fund.1 +22 -0
  56. data/lib/bundler/man/bundle-fund.1.ronn +25 -0
  57. data/lib/bundler/man/bundle-gem.1 +17 -5
  58. data/lib/bundler/man/bundle-gem.1.ronn +27 -6
  59. data/lib/bundler/man/bundle-help.1 +1 -1
  60. data/lib/bundler/man/bundle-info.1 +5 -2
  61. data/lib/bundler/man/bundle-info.1.ronn +6 -2
  62. data/lib/bundler/man/bundle-init.1 +3 -3
  63. data/lib/bundler/man/bundle-init.1.ronn +3 -2
  64. data/lib/bundler/man/bundle-inject.1 +10 -2
  65. data/lib/bundler/man/bundle-inject.1.ronn +9 -1
  66. data/lib/bundler/man/bundle-install.1 +15 -12
  67. data/lib/bundler/man/bundle-install.1.ronn +22 -18
  68. data/lib/bundler/man/bundle-issue.1 +45 -0
  69. data/lib/bundler/man/bundle-issue.1.ronn +37 -0
  70. data/lib/bundler/man/bundle-licenses.1 +9 -0
  71. data/lib/bundler/man/bundle-licenses.1.ronn +10 -0
  72. data/lib/bundler/man/bundle-list.1 +1 -1
  73. data/lib/bundler/man/bundle-list.1.ronn +4 -1
  74. data/lib/bundler/man/bundle-lock.1 +21 -6
  75. data/lib/bundler/man/bundle-lock.1.ronn +25 -4
  76. data/lib/bundler/man/bundle-open.1 +2 -2
  77. data/lib/bundler/man/bundle-open.1.ronn +2 -1
  78. data/lib/bundler/man/bundle-outdated.1 +8 -5
  79. data/lib/bundler/man/bundle-outdated.1.ronn +8 -4
  80. data/lib/bundler/man/bundle-platform.1 +1 -1
  81. data/lib/bundler/man/bundle-plugin.1 +1 -1
  82. data/lib/bundler/man/bundle-pristine.1 +1 -1
  83. data/lib/bundler/man/bundle-pristine.1.ronn +1 -1
  84. data/lib/bundler/man/bundle-remove.1 +1 -1
  85. data/lib/bundler/man/bundle-remove.1.ronn +1 -1
  86. data/lib/bundler/man/bundle-show.1 +5 -2
  87. data/lib/bundler/man/bundle-show.1.ronn +4 -0
  88. data/lib/bundler/man/bundle-update.1 +13 -7
  89. data/lib/bundler/man/bundle-update.1.ronn +14 -6
  90. data/lib/bundler/man/bundle-version.1 +1 -1
  91. data/lib/bundler/man/bundle-viz.1 +4 -4
  92. data/lib/bundler/man/bundle-viz.1.ronn +7 -3
  93. data/lib/bundler/man/bundle.1 +1 -1
  94. data/lib/bundler/man/gemfile.5 +1 -1
  95. data/lib/bundler/man/index.txt +4 -0
  96. data/lib/bundler/materialization.rb +59 -0
  97. data/lib/bundler/plugin/events.rb +24 -0
  98. data/lib/bundler/plugin/installer.rb +1 -1
  99. data/lib/bundler/plugin.rb +20 -1
  100. data/lib/bundler/process_lock.rb +10 -14
  101. data/lib/bundler/remote_specification.rb +6 -1
  102. data/lib/bundler/resolver/base.rb +6 -6
  103. data/lib/bundler/resolver/candidate.rb +2 -2
  104. data/lib/bundler/resolver/spec_group.rb +4 -3
  105. data/lib/bundler/resolver.rb +5 -5
  106. data/lib/bundler/rubygems_ext.rb +30 -27
  107. data/lib/bundler/rubygems_gem_installer.rb +3 -2
  108. data/lib/bundler/rubygems_integration.rb +23 -40
  109. data/lib/bundler/runtime.rb +27 -7
  110. data/lib/bundler/self_manager.rb +2 -3
  111. data/lib/bundler/settings.rb +6 -1
  112. data/lib/bundler/shared_helpers.rb +29 -17
  113. data/lib/bundler/source/git/git_proxy.rb +0 -6
  114. data/lib/bundler/source/git.rb +56 -31
  115. data/lib/bundler/source/metadata.rb +2 -3
  116. data/lib/bundler/source/path.rb +2 -2
  117. data/lib/bundler/source_list.rb +1 -1
  118. data/lib/bundler/spec_set.rb +81 -56
  119. data/lib/bundler/stub_specification.rb +8 -0
  120. data/lib/bundler/templates/newgem/Gemfile.tt +0 -3
  121. data/lib/bundler/templates/newgem/README.md.tt +1 -1
  122. data/lib/bundler/templates/newgem/github/workflows/main.yml.tt +15 -15
  123. data/lib/bundler/templates/newgem/newgem.gemspec.tt +4 -4
  124. data/lib/bundler/uri_credentials_filter.rb +1 -1
  125. data/lib/bundler/vendor/fileutils/COPYING +56 -0
  126. data/lib/bundler/vendor/fileutils/lib/fileutils.rb +15 -13
  127. data/lib/bundler/vendor/securerandom/COPYING +56 -0
  128. data/lib/bundler/vendor/securerandom/lib/securerandom.rb +5 -5
  129. data/lib/bundler/vendor/thor/lib/thor/actions/file_manipulation.rb +3 -5
  130. data/lib/bundler/vendor/thor/lib/thor/group.rb +11 -0
  131. data/lib/bundler/vendor/thor/lib/thor/parser/argument.rb +1 -4
  132. data/lib/bundler/vendor/thor/lib/thor/parser/option.rb +2 -2
  133. data/lib/bundler/vendor/thor/lib/thor/parser/options.rb +2 -1
  134. data/lib/bundler/vendor/thor/lib/thor/shell/basic.rb +9 -9
  135. data/lib/bundler/vendor/thor/lib/thor/shell/html.rb +1 -1
  136. data/lib/bundler/vendor/thor/lib/thor/shell/table_printer.rb +5 -21
  137. data/lib/bundler/vendor/thor/lib/thor/util.rb +1 -1
  138. data/lib/bundler/vendor/thor/lib/thor/version.rb +1 -1
  139. data/lib/bundler/vendor/thor/lib/thor.rb +11 -0
  140. data/lib/bundler/vendor/uri/COPYING +56 -0
  141. data/lib/bundler/vendor/uri/lib/uri/common.rb +37 -16
  142. data/lib/bundler/vendor/uri/lib/uri/file.rb +3 -3
  143. data/lib/bundler/vendor/uri/lib/uri/ftp.rb +1 -1
  144. data/lib/bundler/vendor/uri/lib/uri/generic.rb +16 -26
  145. data/lib/bundler/vendor/uri/lib/uri/http.rb +2 -2
  146. data/lib/bundler/vendor/uri/lib/uri/rfc2396_parser.rb +10 -3
  147. data/lib/bundler/vendor/uri/lib/uri/rfc3986_parser.rb +26 -3
  148. data/lib/bundler/vendor/uri/lib/uri/version.rb +1 -1
  149. data/lib/bundler/vendor/uri/lib/uri.rb +9 -9
  150. data/lib/bundler/vendored_securerandom.rb +0 -2
  151. data/lib/bundler/version.rb +1 -1
  152. data/lib/bundler.rb +38 -14
  153. metadata +18 -12
  154. data/lib/bundler/vendor/fileutils/LICENSE.txt +0 -22
  155. data/lib/bundler/vendor/securerandom/LICENSE.txt +0 -22
  156. data/lib/bundler/vendor/securerandom/lib/random/formatter.rb +0 -373
  157. data/lib/bundler/vendor/uri/LICENSE.txt +0 -22
@@ -1,10 +1,10 @@
1
1
  .\" generated with nRonn/v0.11.1
2
2
  .\" https://github.com/n-ronn/nronn/tree/0.11.1
3
- .TH "BUNDLE\-SHOW" "1" "September 2024" ""
3
+ .TH "BUNDLE\-SHOW" "1" "December 2024" ""
4
4
  .SH "NAME"
5
5
  \fBbundle\-show\fR \- Shows all the gems in your bundle, or the path to a gem
6
6
  .SH "SYNOPSIS"
7
- \fBbundle show\fR [GEM] [\-\-paths]
7
+ \fBbundle show\fR [GEM] [\-\-paths] [\-\-outdated]
8
8
  .SH "DESCRIPTION"
9
9
  Without the [GEM] option, \fBshow\fR will print a list of the names and versions of all gems that are required by your [\fBGemfile(5)\fR][Gemfile(5)], sorted by name\.
10
10
  .P
@@ -13,4 +13,7 @@ Calling show with [GEM] will list the exact location of that gem on your machine
13
13
  .TP
14
14
  \fB\-\-paths\fR
15
15
  List the paths of all gems that are required by your [\fBGemfile(5)\fR][Gemfile(5)], sorted by gem name\.
16
+ .TP
17
+ \fB\-\-outdated\fR
18
+ Show verbose output including whether gems are outdated\.
16
19
 
@@ -5,6 +5,7 @@ bundle-show(1) -- Shows all the gems in your bundle, or the path to a gem
5
5
 
6
6
  `bundle show` [GEM]
7
7
  [--paths]
8
+ [--outdated]
8
9
 
9
10
  ## DESCRIPTION
10
11
 
@@ -19,3 +20,6 @@ machine.
19
20
  * `--paths`:
20
21
  List the paths of all gems that are required by your [`Gemfile(5)`][Gemfile(5)],
21
22
  sorted by gem name.
23
+
24
+ * `--outdated`:
25
+ Show verbose output including whether gems are outdated.
@@ -1,10 +1,10 @@
1
1
  .\" generated with nRonn/v0.11.1
2
2
  .\" https://github.com/n-ronn/nronn/tree/0.11.1
3
- .TH "BUNDLE\-UPDATE" "1" "September 2024" ""
3
+ .TH "BUNDLE\-UPDATE" "1" "December 2024" ""
4
4
  .SH "NAME"
5
5
  \fBbundle\-update\fR \- Update your gems to the latest available versions
6
6
  .SH "SYNOPSIS"
7
- \fBbundle update\fR \fI*gems\fR [\-\-all] [\-\-group=NAME] [\-\-source=NAME] [\-\-local] [\-\-ruby] [\-\-bundler[=VERSION]] [\-\-full\-index] [\-\-jobs=JOBS] [\-\-quiet] [\-\-patch|\-\-minor|\-\-major] [\-\-redownload] [\-\-strict] [\-\-conservative]
7
+ \fBbundle update\fR \fI*gems\fR [\-\-all] [\-\-group=NAME] [\-\-source=NAME] [\-\-local] [\-\-ruby] [\-\-bundler[=VERSION]] [\-\-full\-index] [\-\-gemfile=GEMFILE] [\-\-jobs=NUMBER] [\-\-quiet] [\-\-patch|\-\-minor|\-\-major] [\-\-pre] [\-\-redownload] [\-\-strict] [\-\-conservative]
8
8
  .SH "DESCRIPTION"
9
9
  Update the gems specified (all gems, if \fB\-\-all\fR flag is used), ignoring the previously installed gems specified in the \fBGemfile\.lock\fR\. In general, you should use bundle install(1) \fIbundle\-install\.1\.html\fR to install the same exact gems and versions across machines\.
10
10
  .P
@@ -14,10 +14,10 @@ You would use \fBbundle update\fR to explicitly update the version of a gem\.
14
14
  \fB\-\-all\fR
15
15
  Update all gems specified in Gemfile\.
16
16
  .TP
17
- \fB\-\-group=<name>\fR, \fB\-g=[<name>]\fR
17
+ \fB\-\-group=<list>\fR, \fB\-g=<list>\fR
18
18
  Only update the gems in the specified group\. For instance, you can update all gems in the development group with \fBbundle update \-\-group development\fR\. You can also call \fBbundle update rails \-\-group test\fR to update the rails gem and all gems in the test group, for example\.
19
19
  .TP
20
- \fB\-\-source=<name>\fR
20
+ \fB\-\-source=<list>\fR
21
21
  The name of a \fB:git\fR or \fB:path\fR source used in the Gemfile(5)\. For instance, with a \fB:git\fR source of \fBhttp://github\.com/rails/rails\.git\fR, you would call \fBbundle update \-\-source rails\fR
22
22
  .TP
23
23
  \fB\-\-local\fR
@@ -26,13 +26,16 @@ Do not attempt to fetch gems remotely and use the gem cache instead\.
26
26
  \fB\-\-ruby\fR
27
27
  Update the locked version of Ruby to the current version of Ruby\.
28
28
  .TP
29
- \fB\-\-bundler\fR
29
+ \fB\-\-bundler[=BUNDLER]\fR
30
30
  Update the locked version of bundler to the invoked bundler version\.
31
31
  .TP
32
32
  \fB\-\-full\-index\fR
33
33
  Fall back to using the single\-file index of all gems\.
34
34
  .TP
35
- \fB\-\-jobs=[<number>]\fR, \fB\-j[<number>]\fR
35
+ \fB\-\-gemfile=GEMFILE\fR
36
+ Use the specified gemfile instead of [\fBGemfile(5)\fR][Gemfile(5)]\.
37
+ .TP
38
+ \fB\-\-jobs=<number>\fR, \fB\-j=<number>\fR
36
39
  Specify the number of jobs to run in parallel\. The default is the number of available processors\.
37
40
  .TP
38
41
  \fB\-\-retry=[<number>]\fR
@@ -41,7 +44,7 @@ Retry failed network or git requests for \fInumber\fR times\.
41
44
  \fB\-\-quiet\fR
42
45
  Only output warnings and errors\.
43
46
  .TP
44
- \fB\-\-redownload\fR
47
+ \fB\-\-redownload\fR, \fB\-\-force\fR
45
48
  Force downloading every gem\.
46
49
  .TP
47
50
  \fB\-\-patch\fR
@@ -53,6 +56,9 @@ Prefer updating only to next minor version\.
53
56
  \fB\-\-major\fR
54
57
  Prefer updating to next major version (default)\.
55
58
  .TP
59
+ \fB\-\-pre\fR
60
+ Always choose the highest allowed version, regardless of prerelease status\.
61
+ .TP
56
62
  \fB\-\-strict\fR
57
63
  Do not allow any gem to be updated past latest \fB\-\-patch\fR | \fB\-\-minor\fR | \fB\-\-major\fR\.
58
64
  .TP
@@ -10,9 +10,11 @@ bundle-update(1) -- Update your gems to the latest available versions
10
10
  [--ruby]
11
11
  [--bundler[=VERSION]]
12
12
  [--full-index]
13
- [--jobs=JOBS]
13
+ [--gemfile=GEMFILE]
14
+ [--jobs=NUMBER]
14
15
  [--quiet]
15
16
  [--patch|--minor|--major]
17
+ [--pre]
16
18
  [--redownload]
17
19
  [--strict]
18
20
  [--conservative]
@@ -32,13 +34,13 @@ gem.
32
34
  * `--all`:
33
35
  Update all gems specified in Gemfile.
34
36
 
35
- * `--group=<name>`, `-g=[<name>]`:
37
+ * `--group=<list>`, `-g=<list>`:
36
38
  Only update the gems in the specified group. For instance, you can update all gems
37
39
  in the development group with `bundle update --group development`. You can also
38
40
  call `bundle update rails --group test` to update the rails gem and all gems in
39
41
  the test group, for example.
40
42
 
41
- * `--source=<name>`:
43
+ * `--source=<list>`:
42
44
  The name of a `:git` or `:path` source used in the Gemfile(5). For
43
45
  instance, with a `:git` source of `http://github.com/rails/rails.git`,
44
46
  you would call `bundle update --source rails`
@@ -49,13 +51,16 @@ gem.
49
51
  * `--ruby`:
50
52
  Update the locked version of Ruby to the current version of Ruby.
51
53
 
52
- * `--bundler`:
54
+ * `--bundler[=BUNDLER]`:
53
55
  Update the locked version of bundler to the invoked bundler version.
54
56
 
55
57
  * `--full-index`:
56
58
  Fall back to using the single-file index of all gems.
57
59
 
58
- * `--jobs=[<number>]`, `-j[<number>]`:
60
+ * `--gemfile=GEMFILE`:
61
+ Use the specified gemfile instead of [`Gemfile(5)`][Gemfile(5)].
62
+
63
+ * `--jobs=<number>`, `-j=<number>`:
59
64
  Specify the number of jobs to run in parallel. The default is the number of
60
65
  available processors.
61
66
 
@@ -65,7 +70,7 @@ gem.
65
70
  * `--quiet`:
66
71
  Only output warnings and errors.
67
72
 
68
- * `--redownload`:
73
+ * `--redownload`, `--force`:
69
74
  Force downloading every gem.
70
75
 
71
76
  * `--patch`:
@@ -77,6 +82,9 @@ gem.
77
82
  * `--major`:
78
83
  Prefer updating to next major version (default).
79
84
 
85
+ * `--pre`:
86
+ Always choose the highest allowed version, regardless of prerelease status.
87
+
80
88
  * `--strict`:
81
89
  Do not allow any gem to be updated past latest `--patch` | `--minor` | `--major`.
82
90
 
@@ -1,6 +1,6 @@
1
1
  .\" generated with nRonn/v0.11.1
2
2
  .\" https://github.com/n-ronn/nronn/tree/0.11.1
3
- .TH "BUNDLE\-VERSION" "1" "September 2024" ""
3
+ .TH "BUNDLE\-VERSION" "1" "December 2024" ""
4
4
  .SH "NAME"
5
5
  \fBbundle\-version\fR \- Prints Bundler version information
6
6
  .SH "SYNOPSIS"
@@ -1,6 +1,6 @@
1
1
  .\" generated with nRonn/v0.11.1
2
2
  .\" https://github.com/n-ronn/nronn/tree/0.11.1
3
- .TH "BUNDLE\-VIZ" "1" "September 2024" ""
3
+ .TH "BUNDLE\-VIZ" "1" "December 2024" ""
4
4
  .SH "NAME"
5
5
  \fBbundle\-viz\fR \- Generates a visual dependency graph for your Gemfile
6
6
  .SH "SYNOPSIS"
@@ -13,10 +13,10 @@ The associated gems must also be installed via \fBbundle install(1)\fR \fIbundle
13
13
  \fBviz\fR command was deprecated in Bundler 2\.2\. Use bundler\-graph plugin \fIhttps://github\.com/rubygems/bundler\-graph\fR instead\.
14
14
  .SH "OPTIONS"
15
15
  .TP
16
- \fB\-\-file\fR, \fB\-f\fR
16
+ \fB\-\-file=FILE\fR, \fB\-f=FILE\fR
17
17
  The name to use for the generated file\. See \fB\-\-format\fR option
18
18
  .TP
19
- \fB\-\-format\fR, \fB\-F\fR
19
+ \fB\-\-format=FORMAT\fR, \fB\-F=FORMAT\fR
20
20
  This is output format option\. Supported format is png, jpg, svg, dot \|\.\|\.\|\.
21
21
  .TP
22
22
  \fB\-\-requirements\fR, \fB\-R\fR
@@ -25,6 +25,6 @@ Set to show the version of each required dependency\.
25
25
  \fB\-\-version\fR, \fB\-v\fR
26
26
  Set to show each gem version\.
27
27
  .TP
28
- \fB\-\-without\fR, \fB\-W\fR
28
+ \fB\-\-without=<list>\fR, \fB\-W=<list>\fR
29
29
  Exclude gems that are part of the specified named group\.
30
30
 
@@ -20,13 +20,17 @@ The associated gems must also be installed via [`bundle install(1)`](bundle-inst
20
20
 
21
21
  ## OPTIONS
22
22
 
23
- * `--file`, `-f`:
23
+ * `--file=FILE`, `-f=FILE`:
24
24
  The name to use for the generated file. See `--format` option
25
- * `--format`, `-F`:
25
+
26
+ * `--format=FORMAT`, `-F=FORMAT`:
26
27
  This is output format option. Supported format is png, jpg, svg, dot ...
28
+
27
29
  * `--requirements`, `-R`:
28
30
  Set to show the version of each required dependency.
31
+
29
32
  * `--version`, `-v`:
30
33
  Set to show each gem version.
31
- * `--without`, `-W`:
34
+
35
+ * `--without=<list>`, `-W=<list>`:
32
36
  Exclude gems that are part of the specified named group.
@@ -1,6 +1,6 @@
1
1
  .\" generated with nRonn/v0.11.1
2
2
  .\" https://github.com/n-ronn/nronn/tree/0.11.1
3
- .TH "BUNDLE" "1" "September 2024" ""
3
+ .TH "BUNDLE" "1" "December 2024" ""
4
4
  .SH "NAME"
5
5
  \fBbundle\fR \- Ruby Dependency Management
6
6
  .SH "SYNOPSIS"
@@ -1,6 +1,6 @@
1
1
  .\" generated with nRonn/v0.11.1
2
2
  .\" https://github.com/n-ronn/nronn/tree/0.11.1
3
- .TH "GEMFILE" "5" "September 2024" ""
3
+ .TH "GEMFILE" "5" "December 2024" ""
4
4
  .SH "NAME"
5
5
  \fBGemfile\fR \- A format for describing gem dependencies for Ruby programs
6
6
  .SH "SYNOPSIS"
@@ -8,13 +8,17 @@ bundle-clean(1) bundle-clean.1
8
8
  bundle-config(1) bundle-config.1
9
9
  bundle-console(1) bundle-console.1
10
10
  bundle-doctor(1) bundle-doctor.1
11
+ bundle-env(1) bundle-env.1
11
12
  bundle-exec(1) bundle-exec.1
13
+ bundle-fund(1) bundle-fund.1
12
14
  bundle-gem(1) bundle-gem.1
13
15
  bundle-help(1) bundle-help.1
14
16
  bundle-info(1) bundle-info.1
15
17
  bundle-init(1) bundle-init.1
16
18
  bundle-inject(1) bundle-inject.1
17
19
  bundle-install(1) bundle-install.1
20
+ bundle-issue(1) bundle-issue.1
21
+ bundle-licenses(1) bundle-licenses.1
18
22
  bundle-list(1) bundle-list.1
19
23
  bundle-lock(1) bundle-lock.1
20
24
  bundle-open(1) bundle-open.1
@@ -0,0 +1,59 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Bundler
4
+ #
5
+ # This class materializes a set of resolved specifications (`LazySpecification`)
6
+ # for a given gem into the most appropriate real specifications
7
+ # (`StubSepecification`, `EndpointSpecification`, etc), given a dependency and a
8
+ # target platform.
9
+ #
10
+ class Materialization
11
+ def initialize(dep, platform, candidates:)
12
+ @dep = dep
13
+ @platform = platform
14
+ @candidates = candidates
15
+ end
16
+
17
+ def complete?
18
+ specs.any?
19
+ end
20
+
21
+ def specs
22
+ @specs ||= if @candidates.nil?
23
+ []
24
+ elsif platform
25
+ GemHelpers.select_best_platform_match(@candidates, platform, force_ruby: dep.force_ruby_platform)
26
+ else
27
+ GemHelpers.select_best_local_platform_match(@candidates, force_ruby: dep.force_ruby_platform || dep.default_force_ruby_platform)
28
+ end
29
+ end
30
+
31
+ def dependencies
32
+ specs.first.runtime_dependencies.map {|d| [d, platform] }
33
+ end
34
+
35
+ def materialized_spec
36
+ specs.reject(&:missing?).first&.materialization
37
+ end
38
+
39
+ def completely_missing_specs
40
+ return [] unless specs.all?(&:missing?)
41
+
42
+ specs
43
+ end
44
+
45
+ def partially_missing_specs
46
+ specs.select(&:missing?)
47
+ end
48
+
49
+ def incomplete_specs
50
+ return [] if complete?
51
+
52
+ @candidates || LazySpecification.new(dep.name, nil, nil)
53
+ end
54
+
55
+ private
56
+
57
+ attr_reader :dep, :platform
58
+ end
59
+ end
@@ -56,6 +56,30 @@ module Bundler
56
56
  # Includes an Array of Bundler::Dependency objects
57
57
  # GEM_AFTER_INSTALL_ALL = "after-install-all"
58
58
  define :GEM_AFTER_INSTALL_ALL, "after-install-all"
59
+
60
+ # @!parse
61
+ # A hook called before each individual gem is required
62
+ # Includes a Bundler::Dependency.
63
+ # GEM_BEFORE_REQUIRE = "before-require"
64
+ define :GEM_BEFORE_REQUIRE, "before-require"
65
+
66
+ # @!parse
67
+ # A hook called after each individual gem is required
68
+ # Includes a Bundler::Dependency.
69
+ # GEM_AFTER_REQUIRE = "after-require"
70
+ define :GEM_AFTER_REQUIRE, "after-require"
71
+
72
+ # @!parse
73
+ # A hook called before any gems require
74
+ # Includes an Array of Bundler::Dependency objects.
75
+ # GEM_BEFORE_REQUIRE_ALL = "before-require-all"
76
+ define :GEM_BEFORE_REQUIRE_ALL, "before-require-all"
77
+
78
+ # @!parse
79
+ # A hook called after all gems required
80
+ # Includes an Array of Bundler::Dependency objects.
81
+ # GEM_AFTER_REQUIRE_ALL = "after-require-all"
82
+ define :GEM_AFTER_REQUIRE_ALL, "after-require-all"
59
83
  end
60
84
  end
61
85
  end
@@ -34,7 +34,7 @@ module Bundler
34
34
  # @return [Hash] map of names to their specs they are installed with
35
35
  def install_definition(definition)
36
36
  def definition.lock(*); end
37
- definition.resolve_remotely!
37
+ definition.remotely!
38
38
  specs = definition.specs
39
39
 
40
40
  install_from_specs specs
@@ -342,7 +342,26 @@ module Bundler
342
342
  # done to avoid conflicts
343
343
  path = index.plugin_path(name)
344
344
 
345
- Gem.add_to_load_path(*index.load_paths(name))
345
+ paths = index.load_paths(name)
346
+ invalid_paths = paths.reject {|p| File.directory?(p) }
347
+
348
+ if invalid_paths.any?
349
+ Bundler.ui.warn <<~MESSAGE
350
+ The following plugin paths don't exist: #{invalid_paths.join(", ")}.
351
+
352
+ This can happen if the plugin was installed with a different version of Ruby that has since been uninstalled.
353
+
354
+ If you would like to reinstall the plugin, run:
355
+
356
+ bundler plugin uninstall #{name} && bundler plugin install #{name}
357
+
358
+ Continuing without installing plugin #{name}.
359
+ MESSAGE
360
+
361
+ return
362
+ end
363
+
364
+ Gem.add_to_load_path(*paths)
346
365
 
347
366
  load path.join(PLUGIN_FILE_NAME)
348
367
 
@@ -2,23 +2,19 @@
2
2
 
3
3
  module Bundler
4
4
  class ProcessLock
5
- def self.lock(bundle_path = Bundler.bundle_path)
5
+ def self.lock(bundle_path = Bundler.bundle_path, &block)
6
6
  lock_file_path = File.join(bundle_path, "bundler.lock")
7
- has_lock = false
7
+ base_lock_file_path = lock_file_path.delete_suffix(".lock")
8
8
 
9
- File.open(lock_file_path, "w") do |f|
10
- f.flock(File::LOCK_EX)
11
- has_lock = true
12
- yield
13
- f.flock(File::LOCK_UN)
9
+ require "fileutils" if Bundler.rubygems.provides?("< 3.6.0")
10
+
11
+ begin
12
+ SharedHelpers.filesystem_access(lock_file_path, :write) do
13
+ Gem.open_file_with_lock(base_lock_file_path, &block)
14
+ end
15
+ rescue PermissionError
16
+ block.call
14
17
  end
15
- rescue Errno::EACCES, Errno::ENOLCK, Errno::ENOTSUP, Errno::EPERM, Errno::EROFS
16
- # In the case the user does not have access to
17
- # create the lock file or is using NFS where
18
- # locks are not available we skip locking.
19
- yield
20
- ensure
21
- FileUtils.rm_f(lock_file_path) if has_lock
22
18
  end
23
19
  end
24
20
  end
@@ -12,7 +12,7 @@ module Bundler
12
12
 
13
13
  attr_reader :name, :version, :platform
14
14
  attr_writer :dependencies
15
- attr_accessor :source, :remote
15
+ attr_accessor :source, :remote, :locked_platform
16
16
 
17
17
  def initialize(name, version, platform, spec_fetcher)
18
18
  @name = name
@@ -21,6 +21,11 @@ module Bundler
21
21
  @platform = Gem::Platform.new(platform)
22
22
  @spec_fetcher = spec_fetcher
23
23
  @dependencies = nil
24
+ @locked_platform = nil
25
+ end
26
+
27
+ def insecurely_materialized?
28
+ @locked_platform.to_s != @platform.to_s
24
29
  end
25
30
 
26
31
  # Needed before installs, since the arch matters then and quick
@@ -16,7 +16,7 @@ module Bundler
16
16
  hash[name] = Package.new(name, platforms, **options)
17
17
  end
18
18
 
19
- @requirements = dependencies.map do |dep|
19
+ @requirements = dependencies.filter_map do |dep|
20
20
  dep_platforms = dep.gem_platforms(platforms)
21
21
 
22
22
  # Dependencies scoped to external platforms are ignored
@@ -27,11 +27,7 @@ module Bundler
27
27
  @packages[name] = Package.new(name, dep_platforms, **options.merge(dependency: dep))
28
28
 
29
29
  dep
30
- end.compact
31
- end
32
-
33
- def specs_compatible_with(result)
34
- @base.specs_compatible_with(result)
30
+ end
35
31
  end
36
32
 
37
33
  def [](name)
@@ -107,6 +103,10 @@ module Bundler
107
103
  def build_base_requirements
108
104
  base_requirements = {}
109
105
  @base.each do |ls|
106
+ if ls.source_changed? && ls.source.specs.search(ls.name).empty?
107
+ raise GemNotFound, "Could not find gem '#{ls.name}' in #{ls.source}"
108
+ end
109
+
110
110
  req = Gem::Requirement.new(ls.version)
111
111
  base_requirements[ls.name] = req
112
112
  end
@@ -34,10 +34,10 @@ module Bundler
34
34
  @spec_group.dependencies
35
35
  end
36
36
 
37
- def to_specs(package)
37
+ def to_specs(package, most_specific_locked_platform)
38
38
  return [] if package.meta?
39
39
 
40
- @spec_group.to_specs(package.force_ruby_platform?)
40
+ @spec_group.to_specs(package.force_ruby_platform?, most_specific_locked_platform)
41
41
  end
42
42
 
43
43
  def prerelease?
@@ -25,10 +25,11 @@ module Bundler
25
25
  @source ||= exemplary_spec.source
26
26
  end
27
27
 
28
- def to_specs(force_ruby_platform)
28
+ def to_specs(force_ruby_platform, most_specific_locked_platform)
29
29
  @specs.map do |s|
30
30
  lazy_spec = LazySpecification.from_spec(s)
31
31
  lazy_spec.force_ruby_platform = force_ruby_platform
32
+ lazy_spec.most_specific_locked_platform = most_specific_locked_platform
32
33
  lazy_spec
33
34
  end
34
35
  end
@@ -38,9 +39,9 @@ module Bundler
38
39
  end
39
40
 
40
41
  def dependencies
41
- @dependencies ||= @specs.map do |spec|
42
+ @dependencies ||= @specs.flat_map do |spec|
42
43
  __dependencies(spec) + metadata_dependencies(spec)
43
- end.flatten.uniq.sort
44
+ end.uniq.sort
44
45
  end
45
46
 
46
47
  def ==(other)
@@ -15,10 +15,11 @@ module Bundler
15
15
 
16
16
  include GemHelpers
17
17
 
18
- def initialize(base, gem_version_promoter)
18
+ def initialize(base, gem_version_promoter, most_specific_locked_platform = nil)
19
19
  @source_requirements = base.source_requirements
20
20
  @base = base
21
21
  @gem_version_promoter = gem_version_promoter
22
+ @most_specific_locked_platform = most_specific_locked_platform
22
23
  end
23
24
 
24
25
  def start
@@ -79,8 +80,7 @@ module Bundler
79
80
  def solve_versions(root:, logger:)
80
81
  solver = PubGrub::VersionSolver.new(source: self, root: root, logger: logger)
81
82
  result = solver.solve
82
- resolved_specs = result.map {|package, version| version.to_specs(package) }.flatten
83
- resolved_specs |= @base.specs_compatible_with(SpecSet.new(resolved_specs))
83
+ result.flat_map {|package, version| version.to_specs(package, @most_specific_locked_platform) }
84
84
  rescue PubGrub::SolveFailure => e
85
85
  incompatibility = e.incompatibility
86
86
 
@@ -417,7 +417,7 @@ module Bundler
417
417
  end
418
418
 
419
419
  def prepare_dependencies(requirements, packages)
420
- to_dependency_hash(requirements, packages).map do |dep_package, dep_constraint|
420
+ to_dependency_hash(requirements, packages).filter_map do |dep_package, dep_constraint|
421
421
  name = dep_package.name
422
422
 
423
423
  next [dep_package, dep_constraint] if name == "bundler"
@@ -443,7 +443,7 @@ module Bundler
443
443
  next unless dep_package.current_platform?
444
444
 
445
445
  raise_not_found!(dep_package)
446
- end.compact.to_h
446
+ end.to_h
447
447
  end
448
448
 
449
449
  def select_sorted_versions(package, range)
@@ -79,14 +79,18 @@ module Gem
79
79
  include ::Bundler::MatchMetadata
80
80
  include ::Bundler::MatchPlatform
81
81
 
82
- attr_accessor :remote, :location, :relative_loaded_from
82
+ attr_accessor :remote, :relative_loaded_from
83
83
 
84
- remove_method :source
85
- attr_writer :source
86
- def source
87
- (defined?(@source) && @source) || Gem::Source::Installed.new
84
+ module AllowSettingSource
85
+ attr_writer :source
86
+
87
+ def source
88
+ (defined?(@source) && @source) || super
89
+ end
88
90
  end
89
91
 
92
+ prepend AllowSettingSource
93
+
90
94
  alias_method :rg_full_gem_path, :full_gem_path
91
95
  alias_method :rg_loaded_from, :loaded_from
92
96
 
@@ -122,7 +126,9 @@ module Gem
122
126
  end
123
127
  end
124
128
 
125
- remove_method :gem_dir
129
+ # Can be removed once RubyGems 3.5.21 support is dropped
130
+ remove_method :gem_dir if method_defined?(:gem_dir, false)
131
+
126
132
  def gem_dir
127
133
  full_gem_path
128
134
  end
@@ -144,6 +150,10 @@ module Gem
144
150
  end
145
151
  end
146
152
 
153
+ def insecurely_materialized?
154
+ false
155
+ end
156
+
147
157
  def groups
148
158
  @groups ||= []
149
159
  end
@@ -278,23 +288,6 @@ module Gem
278
288
  end
279
289
  end
280
290
 
281
- # Requirements using lambda operator differentiate trailing zeros since rubygems 3.2.6
282
- if Gem::Requirement.new("~> 2.0").hash == Gem::Requirement.new("~> 2.0.0").hash
283
- class Requirement
284
- module CorrectHashForLambdaOperator
285
- def hash
286
- if requirements.any? {|r| r.first == "~>" }
287
- requirements.map {|r| r.first == "~>" ? [r[0], r[1].to_s] : r }.sort.hash
288
- else
289
- super
290
- end
291
- end
292
- end
293
-
294
- prepend CorrectHashForLambdaOperator
295
- end
296
- end
297
-
298
291
  require "rubygems/platform"
299
292
 
300
293
  class Platform
@@ -344,10 +337,6 @@ module Gem
344
337
  without_gnu_nor_abi_modifiers
345
338
  end
346
339
  end
347
-
348
- if RUBY_ENGINE == "truffleruby" && !defined?(REUSE_AS_BINARY_ON_TRUFFLERUBY)
349
- REUSE_AS_BINARY_ON_TRUFFLERUBY = %w[libv8 libv8-node sorbet-static].freeze
350
- end
351
340
  end
352
341
 
353
342
  Platform.singleton_class.module_eval do
@@ -452,4 +441,18 @@ module Gem
452
441
  end
453
442
  end
454
443
  end
444
+
445
+ if Gem.rubygems_version < Gem::Version.new("3.6.0")
446
+ class Package; end
447
+ require "rubygems/package/tar_reader"
448
+ require "rubygems/package/tar_reader/entry"
449
+
450
+ module FixFullNameEncoding
451
+ def full_name
452
+ super.force_encoding(Encoding::UTF_8)
453
+ end
454
+ end
455
+
456
+ Package::TarReader::Entry.prepend(FixFullNameEncoding)
457
+ end
455
458
  end