bundler 2.5.22 → 2.6.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +83 -0
- data/bundler.gemspec +2 -2
- data/lib/bundler/build_metadata.rb +2 -2
- data/lib/bundler/cli/add.rb +2 -0
- data/lib/bundler/cli/check.rb +2 -2
- data/lib/bundler/cli/console.rb +0 -4
- data/lib/bundler/cli/doctor.rb +4 -4
- data/lib/bundler/cli/exec.rb +1 -0
- data/lib/bundler/cli/gem.rb +1 -1
- data/lib/bundler/cli/info.rb +2 -2
- data/lib/bundler/cli/inject.rb +1 -1
- data/lib/bundler/cli/install.rb +4 -0
- data/lib/bundler/cli/lock.rb +20 -1
- data/lib/bundler/cli/pristine.rb +1 -1
- data/lib/bundler/cli/show.rb +2 -2
- data/lib/bundler/cli.rb +23 -53
- data/lib/bundler/compact_index_client/cache_file.rb +0 -5
- data/lib/bundler/compact_index_client/updater.rb +0 -11
- data/lib/bundler/definition.rb +143 -76
- data/lib/bundler/dependency.rb +1 -1
- data/lib/bundler/dsl.rb +33 -28
- data/lib/bundler/endpoint_specification.rb +10 -1
- data/lib/bundler/errors.rb +10 -0
- data/lib/bundler/feature_flag.rb +1 -0
- data/lib/bundler/fetcher/compact_index.rb +1 -1
- data/lib/bundler/fetcher.rb +10 -3
- data/lib/bundler/gem_helpers.rb +21 -5
- data/lib/bundler/injector.rb +2 -2
- data/lib/bundler/inline.rb +12 -8
- data/lib/bundler/installer/standalone.rb +2 -2
- data/lib/bundler/installer.rb +4 -38
- data/lib/bundler/lazy_specification.rb +74 -26
- data/lib/bundler/lockfile_generator.rb +1 -1
- data/lib/bundler/lockfile_parser.rb +9 -1
- data/lib/bundler/man/bundle-add.1 +17 -11
- data/lib/bundler/man/bundle-add.1.ronn +16 -10
- data/lib/bundler/man/bundle-binstubs.1 +7 -4
- data/lib/bundler/man/bundle-binstubs.1.ronn +6 -3
- data/lib/bundler/man/bundle-cache.1 +30 -2
- data/lib/bundler/man/bundle-cache.1.ronn +31 -2
- data/lib/bundler/man/bundle-check.1 +3 -3
- data/lib/bundler/man/bundle-check.1.ronn +4 -2
- data/lib/bundler/man/bundle-clean.1 +1 -1
- data/lib/bundler/man/bundle-config.1 +3 -5
- data/lib/bundler/man/bundle-config.1.ronn +2 -7
- data/lib/bundler/man/bundle-console.1 +2 -4
- data/lib/bundler/man/bundle-console.1.ronn +2 -7
- data/lib/bundler/man/bundle-doctor.1 +2 -2
- data/lib/bundler/man/bundle-doctor.1.ronn +1 -1
- data/lib/bundler/man/bundle-env.1 +9 -0
- data/lib/bundler/man/bundle-env.1.ronn +10 -0
- data/lib/bundler/man/bundle-exec.1 +5 -2
- data/lib/bundler/man/bundle-exec.1.ronn +4 -1
- data/lib/bundler/man/bundle-fund.1 +22 -0
- data/lib/bundler/man/bundle-fund.1.ronn +25 -0
- data/lib/bundler/man/bundle-gem.1 +17 -5
- data/lib/bundler/man/bundle-gem.1.ronn +27 -6
- data/lib/bundler/man/bundle-help.1 +1 -1
- data/lib/bundler/man/bundle-info.1 +5 -2
- data/lib/bundler/man/bundle-info.1.ronn +6 -2
- data/lib/bundler/man/bundle-init.1 +3 -3
- data/lib/bundler/man/bundle-init.1.ronn +3 -2
- data/lib/bundler/man/bundle-inject.1 +10 -2
- data/lib/bundler/man/bundle-inject.1.ronn +9 -1
- data/lib/bundler/man/bundle-install.1 +15 -12
- data/lib/bundler/man/bundle-install.1.ronn +22 -18
- data/lib/bundler/man/bundle-issue.1 +45 -0
- data/lib/bundler/man/bundle-issue.1.ronn +37 -0
- data/lib/bundler/man/bundle-licenses.1 +9 -0
- data/lib/bundler/man/bundle-licenses.1.ronn +10 -0
- data/lib/bundler/man/bundle-list.1 +1 -1
- data/lib/bundler/man/bundle-list.1.ronn +4 -1
- data/lib/bundler/man/bundle-lock.1 +21 -6
- data/lib/bundler/man/bundle-lock.1.ronn +25 -4
- data/lib/bundler/man/bundle-open.1 +2 -2
- data/lib/bundler/man/bundle-open.1.ronn +2 -1
- data/lib/bundler/man/bundle-outdated.1 +8 -5
- data/lib/bundler/man/bundle-outdated.1.ronn +8 -4
- data/lib/bundler/man/bundle-platform.1 +1 -1
- data/lib/bundler/man/bundle-plugin.1 +1 -1
- data/lib/bundler/man/bundle-pristine.1 +1 -1
- data/lib/bundler/man/bundle-pristine.1.ronn +1 -1
- data/lib/bundler/man/bundle-remove.1 +1 -1
- data/lib/bundler/man/bundle-remove.1.ronn +1 -1
- data/lib/bundler/man/bundle-show.1 +5 -2
- data/lib/bundler/man/bundle-show.1.ronn +4 -0
- data/lib/bundler/man/bundle-update.1 +13 -7
- data/lib/bundler/man/bundle-update.1.ronn +14 -6
- data/lib/bundler/man/bundle-version.1 +1 -1
- data/lib/bundler/man/bundle-viz.1 +4 -4
- data/lib/bundler/man/bundle-viz.1.ronn +7 -3
- data/lib/bundler/man/bundle.1 +1 -1
- data/lib/bundler/man/gemfile.5 +1 -1
- data/lib/bundler/man/index.txt +4 -0
- data/lib/bundler/materialization.rb +59 -0
- data/lib/bundler/plugin/events.rb +24 -0
- data/lib/bundler/plugin/installer.rb +1 -1
- data/lib/bundler/plugin.rb +20 -1
- data/lib/bundler/process_lock.rb +10 -14
- data/lib/bundler/remote_specification.rb +6 -1
- data/lib/bundler/resolver/base.rb +6 -6
- data/lib/bundler/resolver/candidate.rb +2 -2
- data/lib/bundler/resolver/spec_group.rb +4 -3
- data/lib/bundler/resolver.rb +5 -5
- data/lib/bundler/rubygems_ext.rb +30 -27
- data/lib/bundler/rubygems_gem_installer.rb +3 -2
- data/lib/bundler/rubygems_integration.rb +23 -40
- data/lib/bundler/runtime.rb +27 -7
- data/lib/bundler/self_manager.rb +2 -3
- data/lib/bundler/settings.rb +6 -1
- data/lib/bundler/shared_helpers.rb +29 -17
- data/lib/bundler/source/git/git_proxy.rb +0 -6
- data/lib/bundler/source/git.rb +56 -31
- data/lib/bundler/source/metadata.rb +2 -3
- data/lib/bundler/source/path.rb +2 -2
- data/lib/bundler/source_list.rb +1 -1
- data/lib/bundler/spec_set.rb +81 -56
- data/lib/bundler/stub_specification.rb +8 -0
- data/lib/bundler/templates/newgem/Gemfile.tt +0 -3
- data/lib/bundler/templates/newgem/README.md.tt +1 -1
- data/lib/bundler/templates/newgem/github/workflows/main.yml.tt +15 -15
- data/lib/bundler/templates/newgem/newgem.gemspec.tt +4 -4
- data/lib/bundler/uri_credentials_filter.rb +1 -1
- data/lib/bundler/vendor/fileutils/COPYING +56 -0
- data/lib/bundler/vendor/fileutils/lib/fileutils.rb +15 -13
- data/lib/bundler/vendor/securerandom/COPYING +56 -0
- data/lib/bundler/vendor/securerandom/lib/securerandom.rb +5 -5
- data/lib/bundler/vendor/thor/lib/thor/actions/file_manipulation.rb +3 -5
- data/lib/bundler/vendor/thor/lib/thor/group.rb +11 -0
- data/lib/bundler/vendor/thor/lib/thor/parser/argument.rb +1 -4
- data/lib/bundler/vendor/thor/lib/thor/parser/option.rb +2 -2
- data/lib/bundler/vendor/thor/lib/thor/parser/options.rb +2 -1
- data/lib/bundler/vendor/thor/lib/thor/shell/basic.rb +9 -9
- data/lib/bundler/vendor/thor/lib/thor/shell/html.rb +1 -1
- data/lib/bundler/vendor/thor/lib/thor/shell/table_printer.rb +5 -21
- data/lib/bundler/vendor/thor/lib/thor/util.rb +1 -1
- data/lib/bundler/vendor/thor/lib/thor/version.rb +1 -1
- data/lib/bundler/vendor/thor/lib/thor.rb +11 -0
- data/lib/bundler/vendor/uri/COPYING +56 -0
- data/lib/bundler/vendor/uri/lib/uri/common.rb +37 -16
- data/lib/bundler/vendor/uri/lib/uri/file.rb +3 -3
- data/lib/bundler/vendor/uri/lib/uri/ftp.rb +1 -1
- data/lib/bundler/vendor/uri/lib/uri/generic.rb +16 -26
- data/lib/bundler/vendor/uri/lib/uri/http.rb +2 -2
- data/lib/bundler/vendor/uri/lib/uri/rfc2396_parser.rb +10 -3
- data/lib/bundler/vendor/uri/lib/uri/rfc3986_parser.rb +26 -3
- data/lib/bundler/vendor/uri/lib/uri/version.rb +1 -1
- data/lib/bundler/vendor/uri/lib/uri.rb +9 -9
- data/lib/bundler/vendored_securerandom.rb +0 -2
- data/lib/bundler/version.rb +1 -1
- data/lib/bundler.rb +38 -14
- metadata +18 -12
- data/lib/bundler/vendor/fileutils/LICENSE.txt +0 -22
- data/lib/bundler/vendor/securerandom/LICENSE.txt +0 -22
- data/lib/bundler/vendor/securerandom/lib/random/formatter.rb +0 -373
- 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" "
|
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" "
|
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=
|
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=<
|
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=<
|
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\-\-
|
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
|
-
[--
|
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=<
|
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=<
|
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
|
-
* `--
|
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" "
|
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" "
|
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
|
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
|
-
|
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
|
-
|
34
|
+
|
35
|
+
* `--without=<list>`, `-W=<list>`:
|
32
36
|
Exclude gems that are part of the specified named group.
|
data/lib/bundler/man/bundle.1
CHANGED
data/lib/bundler/man/gemfile.5
CHANGED
@@ -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" "
|
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"
|
data/lib/bundler/man/index.txt
CHANGED
@@ -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.
|
37
|
+
definition.remotely!
|
38
38
|
specs = definition.specs
|
39
39
|
|
40
40
|
install_from_specs specs
|
data/lib/bundler/plugin.rb
CHANGED
@@ -342,7 +342,26 @@ module Bundler
|
|
342
342
|
# done to avoid conflicts
|
343
343
|
path = index.plugin_path(name)
|
344
344
|
|
345
|
-
|
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
|
|
data/lib/bundler/process_lock.rb
CHANGED
@@ -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
|
-
|
7
|
+
base_lock_file_path = lock_file_path.delete_suffix(".lock")
|
8
8
|
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
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.
|
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
|
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.
|
42
|
+
@dependencies ||= @specs.flat_map do |spec|
|
42
43
|
__dependencies(spec) + metadata_dependencies(spec)
|
43
|
-
end.
|
44
|
+
end.uniq.sort
|
44
45
|
end
|
45
46
|
|
46
47
|
def ==(other)
|
data/lib/bundler/resolver.rb
CHANGED
@@ -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
|
-
|
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).
|
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.
|
446
|
+
end.to_h
|
447
447
|
end
|
448
448
|
|
449
449
|
def select_sorted_versions(package, range)
|
data/lib/bundler/rubygems_ext.rb
CHANGED
@@ -79,14 +79,18 @@ module Gem
|
|
79
79
|
include ::Bundler::MatchMetadata
|
80
80
|
include ::Bundler::MatchPlatform
|
81
81
|
|
82
|
-
attr_accessor :remote, :
|
82
|
+
attr_accessor :remote, :relative_loaded_from
|
83
83
|
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
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
|
-
|
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
|