rubygems-update 3.3.26 → 3.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +35 -0
- data/CONTRIBUTING.md +24 -1
- data/Manifest.txt +30 -27
- data/POLICIES.md +10 -8
- data/README.md +2 -2
- data/bin/gem +1 -4
- data/bin/update_rubygems +1 -1
- data/bundler/CHANGELOG.md +59 -0
- data/bundler/README.md +2 -2
- data/bundler/bundler.gemspec +2 -2
- data/bundler/exe/bundle +1 -4
- data/bundler/lib/bundler/build_metadata.rb +2 -2
- data/bundler/lib/bundler/cli/add.rb +1 -1
- data/bundler/lib/bundler/cli/check.rb +1 -1
- data/bundler/lib/bundler/cli/common.rb +1 -0
- data/bundler/lib/bundler/cli/console.rb +2 -2
- data/bundler/lib/bundler/cli/doctor.rb +4 -6
- data/bundler/lib/bundler/cli/gem.rb +62 -40
- data/bundler/lib/bundler/cli/install.rb +2 -3
- data/bundler/lib/bundler/cli/lock.rb +8 -5
- data/bundler/lib/bundler/cli/outdated.rb +1 -3
- data/bundler/lib/bundler/cli/viz.rb +1 -1
- data/bundler/lib/bundler/cli.rb +43 -2
- data/bundler/lib/bundler/compact_index_client/cache.rb +1 -1
- data/bundler/lib/bundler/compact_index_client/updater.rb +40 -39
- data/bundler/lib/bundler/constants.rb +1 -1
- data/bundler/lib/bundler/definition.rb +61 -31
- data/bundler/lib/bundler/dependency.rb +12 -11
- data/bundler/lib/bundler/digest.rb +1 -1
- data/bundler/lib/bundler/dsl.rb +1 -1
- data/bundler/lib/bundler/env.rb +1 -1
- data/bundler/lib/bundler/environment_preserver.rb +1 -0
- data/bundler/lib/bundler/errors.rb +1 -11
- data/bundler/lib/bundler/fetcher/compact_index.rb +9 -11
- data/bundler/lib/bundler/fetcher/dependency.rb +1 -1
- data/bundler/lib/bundler/fetcher/downloader.rb +2 -5
- data/bundler/lib/bundler/fetcher.rb +2 -6
- data/bundler/lib/bundler/force_platform.rb +18 -0
- data/bundler/lib/bundler/friendly_errors.rb +0 -3
- data/bundler/lib/bundler/gem_version_promoter.rb +52 -86
- data/bundler/lib/bundler/graph.rb +3 -3
- data/bundler/lib/bundler/index.rb +5 -13
- data/bundler/lib/bundler/injector.rb +1 -1
- data/bundler/lib/bundler/inline.rb +2 -2
- data/bundler/lib/bundler/installer/parallel_installer.rb +0 -31
- data/bundler/lib/bundler/installer.rb +6 -16
- data/bundler/lib/bundler/lazy_specification.rb +5 -1
- data/bundler/lib/bundler/lockfile_parser.rb +5 -5
- data/bundler/lib/bundler/man/bundle-add.1 +1 -1
- data/bundler/lib/bundler/man/bundle-binstubs.1 +1 -1
- data/bundler/lib/bundler/man/bundle-cache.1 +1 -1
- data/bundler/lib/bundler/man/bundle-check.1 +1 -1
- data/bundler/lib/bundler/man/bundle-clean.1 +1 -1
- data/bundler/lib/bundler/man/bundle-config.1 +1 -1
- data/bundler/lib/bundler/man/bundle-console.1 +1 -1
- data/bundler/lib/bundler/man/bundle-doctor.1 +1 -1
- data/bundler/lib/bundler/man/bundle-exec.1 +1 -1
- data/bundler/lib/bundler/man/bundle-gem.1 +27 -37
- data/bundler/lib/bundler/man/bundle-gem.1.ronn +5 -5
- data/bundler/lib/bundler/man/bundle-help.1 +1 -1
- data/bundler/lib/bundler/man/bundle-info.1 +1 -1
- data/bundler/lib/bundler/man/bundle-init.1 +1 -1
- data/bundler/lib/bundler/man/bundle-inject.1 +1 -1
- data/bundler/lib/bundler/man/bundle-install.1 +1 -30
- data/bundler/lib/bundler/man/bundle-install.1.ronn +0 -29
- data/bundler/lib/bundler/man/bundle-list.1 +1 -1
- data/bundler/lib/bundler/man/bundle-lock.1 +1 -1
- data/bundler/lib/bundler/man/bundle-open.1 +1 -1
- data/bundler/lib/bundler/man/bundle-outdated.1 +1 -1
- data/bundler/lib/bundler/man/bundle-platform.1 +2 -2
- data/bundler/lib/bundler/man/bundle-platform.1.ronn +1 -1
- data/bundler/lib/bundler/man/bundle-plugin.1 +1 -1
- data/bundler/lib/bundler/man/bundle-pristine.1 +1 -1
- data/bundler/lib/bundler/man/bundle-remove.1 +1 -1
- data/bundler/lib/bundler/man/bundle-show.1 +1 -1
- data/bundler/lib/bundler/man/bundle-update.1 +1 -1
- data/bundler/lib/bundler/man/bundle-version.1 +1 -1
- data/bundler/lib/bundler/man/bundle-viz.1 +1 -1
- data/bundler/lib/bundler/man/bundle.1 +1 -1
- data/bundler/lib/bundler/man/gemfile.5 +1 -1
- data/bundler/lib/bundler/mirror.rb +5 -7
- data/bundler/lib/bundler/plugin/index.rb +4 -4
- data/bundler/lib/bundler/plugin/installer/rubygems.rb +0 -4
- data/bundler/lib/bundler/resolver/base.rb +7 -11
- data/bundler/lib/bundler/resolver/candidate.rb +92 -0
- data/bundler/lib/bundler/resolver/incompatibility.rb +15 -0
- data/bundler/lib/bundler/resolver/package.rb +63 -0
- data/bundler/lib/bundler/resolver/root.rb +25 -0
- data/bundler/lib/bundler/resolver/spec_group.rb +26 -36
- data/bundler/lib/bundler/resolver.rb +294 -277
- data/bundler/lib/bundler/rubygems_ext.rb +11 -6
- data/bundler/lib/bundler/rubygems_gem_installer.rb +4 -2
- data/bundler/lib/bundler/rubygems_integration.rb +1 -9
- data/bundler/lib/bundler/runtime.rb +1 -5
- data/bundler/lib/bundler/settings.rb +0 -6
- data/bundler/lib/bundler/shared_helpers.rb +1 -0
- data/bundler/lib/bundler/source/git/git_proxy.rb +193 -67
- data/bundler/lib/bundler/source/git.rb +15 -17
- data/bundler/lib/bundler/source/metadata.rb +0 -1
- data/bundler/lib/bundler/source/path/installer.rb +1 -22
- data/bundler/lib/bundler/source/path.rb +5 -5
- data/bundler/lib/bundler/source/rubygems.rb +13 -67
- data/bundler/lib/bundler/source_list.rb +8 -2
- data/bundler/lib/bundler/spec_set.rb +7 -9
- data/bundler/lib/bundler/templates/Executable +1 -1
- data/bundler/lib/bundler/templates/Executable.bundler +4 -9
- data/bundler/lib/bundler/templates/Executable.standalone +2 -0
- data/bundler/lib/bundler/templates/newgem/Cargo.toml.tt +7 -0
- data/bundler/lib/bundler/templates/newgem/Gemfile.tt +3 -0
- data/bundler/lib/bundler/templates/newgem/README.md.tt +6 -4
- data/bundler/lib/bundler/templates/newgem/Rakefile.tt +2 -1
- data/bundler/lib/bundler/templates/newgem/circleci/config.yml.tt +12 -0
- data/bundler/lib/bundler/templates/newgem/ext/newgem/Cargo.toml.tt +15 -0
- data/bundler/lib/bundler/templates/newgem/ext/newgem/{extconf.rb.tt → extconf-c.rb.tt} +0 -0
- data/bundler/lib/bundler/templates/newgem/ext/newgem/extconf-rust.rb.tt +6 -0
- data/bundler/lib/bundler/templates/newgem/ext/newgem/src/lib.rs.tt +12 -0
- data/bundler/lib/bundler/templates/newgem/github/workflows/main.yml.tt +10 -0
- data/bundler/lib/bundler/templates/newgem/gitignore.tt +3 -0
- data/bundler/lib/bundler/templates/newgem/gitlab-ci.yml.tt +8 -0
- data/bundler/lib/bundler/templates/newgem/newgem.gemspec.tt +8 -2
- data/bundler/lib/bundler/ui/shell.rb +35 -12
- data/bundler/lib/bundler/ui/silent.rb +21 -5
- data/bundler/lib/bundler/vendor/connection_pool/lib/connection_pool/timed_stack.rb +3 -3
- data/bundler/lib/bundler/vendor/connection_pool/lib/connection_pool/wrapper.rb +0 -1
- data/bundler/lib/bundler/vendor/connection_pool/lib/connection_pool.rb +3 -1
- data/bundler/lib/bundler/vendor/fileutils/lib/fileutils.rb +1350 -408
- data/bundler/lib/bundler/vendor/net-http-persistent/README.rdoc +1 -1
- data/bundler/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent.rb +1 -1
- data/bundler/lib/bundler/vendor/pub_grub/LICENSE.txt +21 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/assignment.rb +20 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/basic_package_source.rb +189 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/failure_writer.rb +182 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/incompatibility.rb +151 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/package.rb +43 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/partial_solution.rb +121 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/rubygems.rb +45 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/solve_failure.rb +19 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/static_package_source.rb +53 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/term.rb +105 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/version.rb +3 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/version_constraint.rb +124 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/version_range.rb +409 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/version_solver.rb +240 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub/version_union.rb +178 -0
- data/bundler/lib/bundler/vendor/pub_grub/lib/pub_grub.rb +31 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/shell/basic.rb +1 -1
- data/bundler/lib/bundler/vendor/uri/lib/uri/common.rb +64 -16
- data/bundler/lib/bundler/vendor/uri/lib/uri/file.rb +7 -1
- data/bundler/lib/bundler/vendor/uri/lib/uri/ftp.rb +2 -1
- data/bundler/lib/bundler/vendor/uri/lib/uri/generic.rb +27 -7
- data/bundler/lib/bundler/vendor/uri/lib/uri/http.rb +40 -2
- data/bundler/lib/bundler/vendor/uri/lib/uri/https.rb +2 -1
- data/bundler/lib/bundler/vendor/uri/lib/uri/ldap.rb +1 -1
- data/bundler/lib/bundler/vendor/uri/lib/uri/ldaps.rb +2 -1
- data/bundler/lib/bundler/vendor/uri/lib/uri/mailto.rb +2 -2
- data/bundler/lib/bundler/vendor/uri/lib/uri/rfc2396_parser.rb +13 -7
- data/bundler/lib/bundler/vendor/uri/lib/uri/rfc3986_parser.rb +10 -5
- data/bundler/lib/bundler/vendor/uri/lib/uri/version.rb +1 -1
- data/bundler/lib/bundler/vendor/uri/lib/uri/ws.rb +1 -2
- data/bundler/lib/bundler/vendor/uri/lib/uri/wss.rb +2 -1
- data/bundler/lib/bundler/vendor/uri/lib/uri.rb +3 -2
- data/bundler/lib/bundler/vendored_persistent.rb +1 -33
- data/bundler/lib/bundler/{vendored_tmpdir.rb → vendored_pub_grub.rb} +1 -1
- data/bundler/lib/bundler/version.rb +5 -1
- data/bundler/lib/bundler/worker.rb +5 -7
- data/bundler/lib/bundler.rb +20 -64
- data/lib/rubygems/command_manager.rb +2 -2
- data/lib/rubygems/commands/fetch_command.rb +1 -1
- data/lib/rubygems/commands/install_command.rb +7 -3
- data/lib/rubygems/commands/rdoc_command.rb +3 -2
- data/lib/rubygems/commands/setup_command.rb +2 -2
- data/lib/rubygems/commands/unpack_command.rb +1 -1
- data/lib/rubygems/commands/update_command.rb +1 -7
- data/lib/rubygems/config_file.rb +33 -0
- data/lib/rubygems/core_ext/kernel_warn.rb +1 -2
- data/lib/rubygems/defaults.rb +15 -1
- data/lib/rubygems/dependency.rb +4 -1
- data/lib/rubygems/dependency_installer.rb +24 -24
- data/lib/rubygems/exceptions.rb +1 -3
- data/lib/rubygems/ext/builder.rb +3 -3
- data/lib/rubygems/ext/cargo_builder/link_flag_converter.rb +9 -5
- data/lib/rubygems/ext/cargo_builder.rb +15 -20
- data/lib/rubygems/ext/ext_conf_builder.rb +2 -0
- data/lib/rubygems/indexer.rb +1 -1
- data/lib/rubygems/installer.rb +5 -5
- data/lib/rubygems/optparse/lib/optparse.rb +20 -15
- data/lib/rubygems/package/tar_header.rb +11 -11
- data/lib/rubygems/platform.rb +0 -2
- data/lib/rubygems/request_set/gem_dependency_api.rb +104 -104
- data/lib/rubygems/requirement.rb +7 -7
- data/lib/rubygems/resolver/installer_set.rb +1 -1
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph.rb +1 -1
- data/lib/rubygems/resolver/molinillo/lib/molinillo/errors.rb +32 -26
- data/lib/rubygems/resolver/molinillo/lib/molinillo/gem_metadata.rb +1 -1
- data/lib/rubygems/security/policies.rb +40 -40
- data/lib/rubygems/security/trust_dir.rb +1 -1
- data/lib/rubygems/security.rb +3 -16
- data/lib/rubygems/source.rb +2 -2
- data/lib/rubygems/specification.rb +37 -49
- data/lib/rubygems/specification_policy.rb +14 -0
- data/lib/rubygems/stub_specification.rb +2 -2
- data/lib/rubygems/text.rb +1 -1
- data/lib/rubygems/tsort/lib/tsort.rb +308 -310
- data/lib/rubygems/update_suggestion.rb +69 -0
- data/lib/rubygems/util.rb +1 -5
- data/lib/rubygems/validator.rb +1 -1
- data/lib/rubygems.rb +8 -3
- data/rubygems-update.gemspec +2 -2
- data/test/rubygems/helper.rb +7 -3
- data/test/rubygems/test_bundled_ca.rb +1 -1
- data/test/rubygems/test_exit.rb +6 -0
- data/test/rubygems/test_gem.rb +4 -9
- data/test/rubygems/test_gem_bundler_version_finder.rb +2 -1
- data/test/rubygems/test_gem_command_manager.rb +1 -1
- data/test/rubygems/test_gem_commands_install_command.rb +19 -0
- data/test/rubygems/test_gem_commands_setup_command.rb +1 -8
- data/test/rubygems/test_gem_commands_update_command.rb +6 -6
- data/test/rubygems/test_gem_config_file.rb +1 -1
- data/test/rubygems/test_gem_dependency.rb +2 -0
- data/test/rubygems/test_gem_ext_builder.rb +3 -3
- data/test/rubygems/test_gem_ext_cargo_builder/custom_name/Cargo.lock +22 -32
- data/test/rubygems/test_gem_ext_cargo_builder/custom_name/Cargo.toml +1 -1
- data/test/rubygems/test_gem_ext_cargo_builder/rust_ruby_example/Cargo.lock +22 -32
- data/test/rubygems/test_gem_ext_cargo_builder/rust_ruby_example/Cargo.toml +1 -1
- data/test/rubygems/test_gem_ext_cargo_builder/rust_ruby_example/src/lib.rs +12 -0
- data/test/rubygems/test_gem_ext_cargo_builder.rb +22 -27
- data/test/rubygems/test_gem_ext_cargo_builder_link_flag_converter.rb +16 -16
- data/test/rubygems/test_gem_ext_cargo_builder_unit.rb +0 -10
- data/test/rubygems/test_gem_indexer.rb +39 -20
- data/test/rubygems/test_gem_installer.rb +68 -2
- data/test/rubygems/test_gem_package_tar_header.rb +13 -13
- data/test/rubygems/test_gem_platform.rb +59 -60
- data/test/rubygems/test_gem_remote_fetcher.rb +4 -4
- data/test/rubygems/test_gem_request_set.rb +2 -2
- data/test/rubygems/test_gem_requirement.rb +1 -1
- data/test/rubygems/test_gem_resolver_api_set.rb +12 -12
- data/test/rubygems/test_gem_resolver_api_specification.rb +19 -19
- data/test/rubygems/test_gem_resolver_git_specification.rb +1 -1
- data/test/rubygems/test_gem_security_policy.rb +10 -10
- data/test/rubygems/test_gem_security_trust_dir.rb +2 -2
- data/test/rubygems/test_gem_specification.rb +50 -37
- data/test/rubygems/test_gem_uninstaller.rb +1 -1
- data/test/rubygems/test_gem_update_suggestion.rb +208 -0
- data/test/rubygems/test_kernel.rb +10 -8
- data/test/rubygems/test_require.rb +70 -55
- metadata +34 -31
- data/bundler/lib/bundler/templates/newgem/travis.yml.tt +0 -6
- data/bundler/lib/bundler/vendor/molinillo/LICENSE +0 -9
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/delegates/resolution_state.rb +0 -57
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/delegates/specification_provider.rb +0 -88
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/action.rb +0 -36
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb +0 -66
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_vertex.rb +0 -62
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/delete_edge.rb +0 -63
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb +0 -61
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/log.rb +0 -126
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/set_payload.rb +0 -46
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/tag.rb +0 -36
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/vertex.rb +0 -164
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph.rb +0 -255
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/errors.rb +0 -149
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/gem_metadata.rb +0 -6
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/modules/specification_provider.rb +0 -112
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/modules/ui.rb +0 -67
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/resolution.rb +0 -839
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/resolver.rb +0 -46
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/state.rb +0 -58
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo.rb +0 -11
- data/bundler/lib/bundler/vendor/tmpdir/lib/tmpdir.rb +0 -154
- data/bundler/lib/bundler/vendored_molinillo.rb +0 -4
- data/bundler/lib/bundler/version_ranges.rb +0 -122
@@ -15,7 +15,7 @@ module Bundler
|
|
15
15
|
"test-unit" => "3.0",
|
16
16
|
}.freeze
|
17
17
|
|
18
|
-
attr_reader :options, :gem_name, :thor, :name, :target
|
18
|
+
attr_reader :options, :gem_name, :thor, :name, :target, :extension
|
19
19
|
|
20
20
|
def initialize(options, gem_name, thor)
|
21
21
|
@options = options
|
@@ -28,7 +28,11 @@ module Bundler
|
|
28
28
|
@name = @gem_name
|
29
29
|
@target = SharedHelpers.pwd.join(gem_name)
|
30
30
|
|
31
|
-
|
31
|
+
@extension = options[:ext]
|
32
|
+
|
33
|
+
validate_ext_name if @extension
|
34
|
+
validate_rust_builder_rubygems_version if @extension == "rust"
|
35
|
+
travis_removal_info
|
32
36
|
end
|
33
37
|
|
34
38
|
def run
|
@@ -55,21 +59,22 @@ module Bundler
|
|
55
59
|
end
|
56
60
|
|
57
61
|
config = {
|
58
|
-
:name
|
62
|
+
:name => name,
|
59
63
|
:underscored_name => underscored_name,
|
60
|
-
:namespaced_path
|
61
|
-
:makefile_path
|
62
|
-
:constant_name
|
63
|
-
:constant_array
|
64
|
-
:author
|
65
|
-
:email
|
66
|
-
:test
|
67
|
-
:ext
|
68
|
-
:exe
|
69
|
-
:bundler_version
|
70
|
-
:git
|
71
|
-
:github_username
|
64
|
+
:namespaced_path => namespaced_path,
|
65
|
+
:makefile_path => "#{underscored_name}/#{underscored_name}",
|
66
|
+
:constant_name => constant_name,
|
67
|
+
:constant_array => constant_array,
|
68
|
+
:author => git_author_name.empty? ? "TODO: Write your name" : git_author_name,
|
69
|
+
:email => git_user_email.empty? ? "TODO: Write your email address" : git_user_email,
|
70
|
+
:test => options[:test],
|
71
|
+
:ext => extension,
|
72
|
+
:exe => options[:exe],
|
73
|
+
:bundler_version => bundler_dependency_version,
|
74
|
+
:git => use_git,
|
75
|
+
:github_username => github_username.empty? ? "[USERNAME]" : github_username,
|
72
76
|
:required_ruby_version => required_ruby_version,
|
77
|
+
:rust_builder_required_rubygems_version => rust_builder_required_rubygems_version,
|
73
78
|
:minitest_constant_name => minitest_constant_name,
|
74
79
|
}
|
75
80
|
ensure_safe_gem_name(name, constant_array)
|
@@ -132,8 +137,6 @@ module Bundler
|
|
132
137
|
case config[:ci]
|
133
138
|
when "github"
|
134
139
|
templates.merge!("github/workflows/main.yml.tt" => ".github/workflows/main.yml")
|
135
|
-
when "travis"
|
136
|
-
templates.merge!("travis.yml.tt" => ".travis.yml")
|
137
140
|
when "gitlab"
|
138
141
|
templates.merge!("gitlab-ci.yml.tt" => ".gitlab-ci.yml")
|
139
142
|
when "circle"
|
@@ -188,14 +191,23 @@ module Bundler
|
|
188
191
|
|
189
192
|
templates.merge!("exe/newgem.tt" => "exe/#{name}") if config[:exe]
|
190
193
|
|
191
|
-
if
|
194
|
+
if extension == "c"
|
192
195
|
templates.merge!(
|
193
|
-
"ext/newgem/extconf.rb.tt" => "ext/#{name}/extconf.rb",
|
196
|
+
"ext/newgem/extconf-c.rb.tt" => "ext/#{name}/extconf.rb",
|
194
197
|
"ext/newgem/newgem.h.tt" => "ext/#{name}/#{underscored_name}.h",
|
195
198
|
"ext/newgem/newgem.c.tt" => "ext/#{name}/#{underscored_name}.c"
|
196
199
|
)
|
197
200
|
end
|
198
201
|
|
202
|
+
if extension == "rust"
|
203
|
+
templates.merge!(
|
204
|
+
"Cargo.toml.tt" => "Cargo.toml",
|
205
|
+
"ext/newgem/Cargo.toml.tt" => "ext/#{name}/Cargo.toml",
|
206
|
+
"ext/newgem/extconf-rust.rb.tt" => "ext/#{name}/extconf.rb",
|
207
|
+
"ext/newgem/src/lib.rs.tt" => "ext/#{name}/src/lib.rs",
|
208
|
+
)
|
209
|
+
end
|
210
|
+
|
199
211
|
if target.exist? && !target.directory?
|
200
212
|
Bundler.ui.error "Couldn't create a new gem named `#{gem_name}` because there's an existing file named `#{gem_name}`."
|
201
213
|
exit Bundler::BundlerError.all_errors[Bundler::GenericSystemCallError]
|
@@ -270,7 +282,7 @@ module Bundler
|
|
270
282
|
Bundler.ui.info hint_text("test")
|
271
283
|
|
272
284
|
result = Bundler.ui.ask "Enter a test framework. rspec/minitest/test-unit/(none):"
|
273
|
-
if
|
285
|
+
if /rspec|minitest|test-unit/.match?(result)
|
274
286
|
test_framework = result
|
275
287
|
else
|
276
288
|
test_framework = false
|
@@ -306,12 +318,11 @@ module Bundler
|
|
306
318
|
"* CircleCI: https://circleci.com/\n" \
|
307
319
|
"* GitHub Actions: https://github.com/features/actions\n" \
|
308
320
|
"* GitLab CI: https://docs.gitlab.com/ee/ci/\n" \
|
309
|
-
"* Travis CI: https://travis-ci.org/\n" \
|
310
321
|
"\n"
|
311
322
|
Bundler.ui.info hint_text("ci")
|
312
323
|
|
313
|
-
result = Bundler.ui.ask "Enter a CI service. github/
|
314
|
-
if
|
324
|
+
result = Bundler.ui.ask "Enter a CI service. github/gitlab/circle/(none):"
|
325
|
+
if /github|gitlab|circle/.match?(result)
|
315
326
|
ci_template = result
|
316
327
|
else
|
317
328
|
ci_template = false
|
@@ -342,7 +353,7 @@ module Bundler
|
|
342
353
|
Bundler.ui.info hint_text("linter")
|
343
354
|
|
344
355
|
result = Bundler.ui.ask "Enter a linter. rubocop/standard/(none):"
|
345
|
-
if
|
356
|
+
if /rubocop|standard/.match?(result)
|
346
357
|
linter_template = result
|
347
358
|
else
|
348
359
|
linter_template = false
|
@@ -389,7 +400,7 @@ module Bundler
|
|
389
400
|
end
|
390
401
|
|
391
402
|
def ensure_safe_gem_name(name, constant_array)
|
392
|
-
if
|
403
|
+
if /^\d/.match?(name)
|
393
404
|
Bundler.ui.error "Invalid gem name #{name} Please give a name which does not start with numbers."
|
394
405
|
exit 1
|
395
406
|
end
|
@@ -415,28 +426,39 @@ module Bundler
|
|
415
426
|
thor.run(%(#{editor} "#{file}"))
|
416
427
|
end
|
417
428
|
|
429
|
+
def rust_builder_required_rubygems_version
|
430
|
+
"3.3.11"
|
431
|
+
end
|
432
|
+
|
418
433
|
def required_ruby_version
|
419
|
-
|
420
|
-
elsif Gem.ruby_version < Gem::Version.new("2.5.a") then "2.4.0"
|
421
|
-
elsif Gem.ruby_version < Gem::Version.new("2.6.a") then "2.5.0"
|
422
|
-
else
|
423
|
-
"2.6.0"
|
424
|
-
end
|
434
|
+
"2.6.0"
|
425
435
|
end
|
426
436
|
|
427
437
|
def rubocop_version
|
428
|
-
|
429
|
-
elsif Gem.ruby_version < Gem::Version.new("2.5.a") then "1.12"
|
430
|
-
else
|
431
|
-
"1.21"
|
432
|
-
end
|
438
|
+
"1.21"
|
433
439
|
end
|
434
440
|
|
435
441
|
def standard_version
|
436
|
-
|
437
|
-
|
438
|
-
|
439
|
-
|
442
|
+
"1.3"
|
443
|
+
end
|
444
|
+
|
445
|
+
# TODO: remove at next minor release
|
446
|
+
def travis_removal_info
|
447
|
+
if options[:ci] == "travis"
|
448
|
+
Bundler.ui.error "Support for Travis CI was removed from gem skeleton generator."
|
449
|
+
exit 1
|
450
|
+
end
|
451
|
+
|
452
|
+
if Bundler.settings["gem.ci"] == "travis"
|
453
|
+
Bundler.ui.error "Support for Travis CI was removed from gem skeleton generator, but it is present in bundle config. Please configure another provider using `bundle config set gem.ci SERVICE` (where SERVICE is one of github/gitlab/circle) or unset configuration using `bundle config unset gem.ci`."
|
454
|
+
exit 1
|
455
|
+
end
|
456
|
+
end
|
457
|
+
|
458
|
+
def validate_rust_builder_rubygems_version
|
459
|
+
if Gem::Version.new(rust_builder_required_rubygems_version) > Gem.rubygems_version
|
460
|
+
Bundler.ui.error "Your RubyGems version (#{Gem.rubygems_version}) is too old to build Rust extension. Please update your RubyGems using `gem update --system` or any other way and try again."
|
461
|
+
exit 1
|
440
462
|
end
|
441
463
|
end
|
442
464
|
end
|
@@ -94,9 +94,8 @@ module Bundler
|
|
94
94
|
|
95
95
|
def warn_if_root
|
96
96
|
return if Bundler.settings[:silence_root_warning] || Gem.win_platform? || !Process.uid.zero?
|
97
|
-
Bundler.ui.warn "Don't run Bundler as root.
|
98
|
-
|
99
|
-
"application for all non-root users on this machine.", :wrap => true
|
97
|
+
Bundler.ui.warn "Don't run Bundler as root. Installing your bundle as root " \
|
98
|
+
"will break this application for all non-root users on this machine.", :wrap => true
|
100
99
|
end
|
101
100
|
|
102
101
|
def dependencies_count_for(definition)
|
@@ -15,19 +15,22 @@ module Bundler
|
|
15
15
|
end
|
16
16
|
|
17
17
|
print = options[:print]
|
18
|
-
|
19
|
-
Bundler.ui =
|
18
|
+
previous_ui_level = Bundler.ui.level
|
19
|
+
Bundler.ui.level = "silent" if print
|
20
20
|
|
21
21
|
Bundler::Fetcher.disable_endpoint = options["full-index"]
|
22
22
|
|
23
23
|
update = options[:update]
|
24
24
|
conservative = options[:conservative]
|
25
|
+
bundler = options[:bundler]
|
25
26
|
|
26
27
|
if update.is_a?(Array) # unlocking specific gems
|
27
28
|
Bundler::CLI::Common.ensure_all_gems_in_lockfile!(update)
|
28
29
|
update = { :gems => update, :conservative => conservative }
|
29
|
-
elsif update
|
30
|
-
update = { :conservative => conservative }
|
30
|
+
elsif update && conservative
|
31
|
+
update = { :conservative => conservative }
|
32
|
+
elsif update && bundler
|
33
|
+
update = { :bundler => bundler }
|
31
34
|
end
|
32
35
|
definition = Bundler.definition(update)
|
33
36
|
|
@@ -61,7 +64,7 @@ module Bundler
|
|
61
64
|
definition.lock(file)
|
62
65
|
end
|
63
66
|
|
64
|
-
Bundler.ui =
|
67
|
+
Bundler.ui.level = previous_ui_level
|
65
68
|
end
|
66
69
|
end
|
67
70
|
end
|
@@ -23,7 +23,7 @@ module Bundler
|
|
23
23
|
Bundler.ui.warn "Make sure you have the graphviz ruby gem. You can install it with:"
|
24
24
|
Bundler.ui.warn "`gem install ruby-graphviz`"
|
25
25
|
rescue StandardError => e
|
26
|
-
raise unless e.message
|
26
|
+
raise unless e.message.to_s.include?("GraphViz not installed or dot not in PATH")
|
27
27
|
Bundler.ui.error e.message
|
28
28
|
Bundler.ui.warn "Please install GraphViz. On a Mac with Homebrew, you can run `brew install graphviz`."
|
29
29
|
end
|
data/bundler/lib/bundler/cli.rb
CHANGED
@@ -10,6 +10,7 @@ module Bundler
|
|
10
10
|
|
11
11
|
AUTO_INSTALL_CMDS = %w[show binstubs outdated exec open console licenses clean].freeze
|
12
12
|
PARSEABLE_COMMANDS = %w[check config help exec platform show version].freeze
|
13
|
+
EXTENSIONS = ["c", "rust"].freeze
|
13
14
|
|
14
15
|
COMMAND_ALIASES = {
|
15
16
|
"check" => "c",
|
@@ -22,6 +23,8 @@ module Bundler
|
|
22
23
|
}.freeze
|
23
24
|
|
24
25
|
def self.start(*)
|
26
|
+
check_deprecated_ext_option(ARGV) if ARGV.include?("--ext")
|
27
|
+
|
25
28
|
super
|
26
29
|
ensure
|
27
30
|
Bundler::SharedHelpers.print_major_deprecations!
|
@@ -292,6 +295,8 @@ module Bundler
|
|
292
295
|
"Prefer updating only to next minor version"
|
293
296
|
method_option "major", :type => :boolean, :banner =>
|
294
297
|
"Prefer updating to next major version (default)"
|
298
|
+
method_option "pre", :type => :boolean, :banner =>
|
299
|
+
"Always choose the highest allowed version when updating gems, regardless of prerelease status"
|
295
300
|
method_option "strict", :type => :boolean, :banner =>
|
296
301
|
"Do not allow any gem to be updated past latest --patch | --minor | --major"
|
297
302
|
method_option "conservative", :type => :boolean, :banner =>
|
@@ -574,7 +579,7 @@ module Bundler
|
|
574
579
|
method_option :edit, :type => :string, :aliases => "-e", :required => false, :banner => "EDITOR",
|
575
580
|
:lazy_default => [ENV["BUNDLER_EDITOR"], ENV["VISUAL"], ENV["EDITOR"]].find {|e| !e.nil? && !e.empty? },
|
576
581
|
:desc => "Open generated gemspec in the specified editor (defaults to $EDITOR or $BUNDLER_EDITOR)"
|
577
|
-
method_option :ext, :type => :
|
582
|
+
method_option :ext, :type => :string, :desc => "Generate the boilerplate for C extension code.", :enum => EXTENSIONS
|
578
583
|
method_option :git, :type => :boolean, :default => true, :desc => "Initialize a git repo inside your library."
|
579
584
|
method_option :mit, :type => :boolean, :desc => "Generate an MIT license file. Set a default with `bundle config set --global gem.mit true`."
|
580
585
|
method_option :rubocop, :type => :boolean, :desc => "Add rubocop to the generated Rakefile and gemspec. Set a default with `bundle config set --global gem.rubocop true`."
|
@@ -582,7 +587,7 @@ module Bundler
|
|
582
587
|
method_option :test, :type => :string, :lazy_default => Bundler.settings["gem.test"] || "", :aliases => "-t", :banner => "Use the specified test framework for your library",
|
583
588
|
:desc => "Generate a test directory for your library, either rspec, minitest or test-unit. Set a default with `bundle config set --global gem.test (rspec|minitest|test-unit)`."
|
584
589
|
method_option :ci, :type => :string, :lazy_default => Bundler.settings["gem.ci"] || "",
|
585
|
-
:desc => "Generate CI configuration, either GitHub Actions,
|
590
|
+
:desc => "Generate CI configuration, either GitHub Actions, GitLab CI or CircleCI. Set a default with `bundle config set --global gem.ci (github|gitlab|circle)`"
|
586
591
|
method_option :linter, :type => :string, :lazy_default => Bundler.settings["gem.linter"] || "",
|
587
592
|
:desc => "Add a linter and code formatter, either RuboCop or Standard. Set a default with `bundle config set --global gem.linter (rubocop|standard)`"
|
588
593
|
method_option :github_username, :type => :string, :default => Bundler.settings["gem.github_username"], :banner => "Set your username on GitHub", :desc => "Fill in GitHub username on README so that you don't have to do it manually. Set a default with `bundle config set --global gem.github_username <your_username>`."
|
@@ -668,10 +673,14 @@ module Bundler
|
|
668
673
|
"If updating, prefer updating only to next minor version"
|
669
674
|
method_option "major", :type => :boolean, :banner =>
|
670
675
|
"If updating, prefer updating to next major version (default)"
|
676
|
+
method_option "pre", :type => :boolean, :banner =>
|
677
|
+
"If updating, always choose the highest allowed version, regardless of prerelease status"
|
671
678
|
method_option "strict", :type => :boolean, :banner =>
|
672
679
|
"If updating, do not allow any gem to be updated past latest --patch | --minor | --major"
|
673
680
|
method_option "conservative", :type => :boolean, :banner =>
|
674
681
|
"If updating, use bundle install conservative update behavior and do not allow shared dependencies to be updated"
|
682
|
+
method_option "bundler", :type => :string, :lazy_default => "> 0.a", :banner =>
|
683
|
+
"Update the locked version of bundler"
|
675
684
|
def lock
|
676
685
|
require_relative "cli/lock"
|
677
686
|
Lock.new(options).run
|
@@ -749,6 +758,38 @@ module Bundler
|
|
749
758
|
end
|
750
759
|
end
|
751
760
|
|
761
|
+
def self.check_deprecated_ext_option(arguments)
|
762
|
+
# when deprecated version of `--ext` is called
|
763
|
+
# print out deprecation warning and pretend `--ext=c` was provided
|
764
|
+
if deprecated_ext_value?(arguments)
|
765
|
+
SharedHelpers.major_deprecation 2, "Extensions can now be generated using C or Rust, so `--ext` with no arguments has been deprecated. Please select a language, e.g. `--ext=rust` to generate a Rust extension. This gem will now be generated as if `--ext=c` was used."
|
766
|
+
arguments[arguments.index("--ext")] = "--ext=c"
|
767
|
+
end
|
768
|
+
end
|
769
|
+
|
770
|
+
def self.deprecated_ext_value?(arguments)
|
771
|
+
index = arguments.index("--ext")
|
772
|
+
next_argument = arguments[index+1]
|
773
|
+
|
774
|
+
# it is ok when --ext is followed with valid extension value
|
775
|
+
# for example `bundle gem hello --ext c`
|
776
|
+
return false if EXTENSIONS.include?(next_argument)
|
777
|
+
|
778
|
+
# deprecated call when --ext is called with no value in last position
|
779
|
+
# for example `bundle gem hello_gem --ext`
|
780
|
+
return true if next_argument.nil?
|
781
|
+
|
782
|
+
# deprecated call when --ext is followed by other parameter
|
783
|
+
# for example `bundle gem --ext --no-ci hello_gem`
|
784
|
+
return true if next_argument.start_with?("-")
|
785
|
+
|
786
|
+
# deprecated call when --ext is followed by gem name
|
787
|
+
# for example `bundle gem --ext hello_gem`
|
788
|
+
return true if next_argument
|
789
|
+
|
790
|
+
false
|
791
|
+
end
|
792
|
+
|
752
793
|
private
|
753
794
|
|
754
795
|
# Automatically invoke `bundle install` and resume if
|
@@ -20,63 +20,64 @@ module Bundler
|
|
20
20
|
|
21
21
|
def initialize(fetcher)
|
22
22
|
@fetcher = fetcher
|
23
|
-
require_relative "../vendored_tmpdir"
|
24
23
|
end
|
25
24
|
|
26
25
|
def update(local_path, remote_path, retrying = nil)
|
27
26
|
headers = {}
|
28
27
|
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
# first try to fetch any new bytes on the existing file
|
33
|
-
if retrying.nil? && local_path.file?
|
34
|
-
copy_file local_path, local_temp_path
|
35
|
-
|
36
|
-
headers["If-None-Match"] = etag_for(local_temp_path)
|
37
|
-
headers["Range"] =
|
38
|
-
if local_temp_path.size.nonzero?
|
39
|
-
# Subtract a byte to ensure the range won't be empty.
|
40
|
-
# Avoids 416 (Range Not Satisfiable) responses.
|
41
|
-
"bytes=#{local_temp_path.size - 1}-"
|
42
|
-
else
|
43
|
-
"bytes=#{local_temp_path.size}-"
|
44
|
-
end
|
45
|
-
end
|
28
|
+
local_temp_path = local_path.sub(/$/, ".#{$$}")
|
29
|
+
local_temp_path = local_temp_path.sub(/$/, ".retrying") if retrying
|
30
|
+
local_temp_path = local_temp_path.sub(/$/, ".tmp")
|
46
31
|
|
47
|
-
|
48
|
-
|
32
|
+
# first try to fetch any new bytes on the existing file
|
33
|
+
if retrying.nil? && local_path.file?
|
34
|
+
copy_file local_path, local_temp_path
|
49
35
|
|
50
|
-
|
36
|
+
headers["If-None-Match"] = etag_for(local_temp_path)
|
37
|
+
headers["Range"] =
|
38
|
+
if local_temp_path.size.nonzero?
|
39
|
+
# Subtract a byte to ensure the range won't be empty.
|
40
|
+
# Avoids 416 (Range Not Satisfiable) responses.
|
41
|
+
"bytes=#{local_temp_path.size - 1}-"
|
42
|
+
else
|
43
|
+
"bytes=#{local_temp_path.size}-"
|
44
|
+
end
|
45
|
+
end
|
51
46
|
|
52
|
-
|
53
|
-
|
54
|
-
if response.is_a?(Net::HTTPPartialContent) && local_temp_path.size.nonzero?
|
55
|
-
local_temp_path.open("a") {|f| f << slice_body(content, 1..-1) }
|
47
|
+
response = @fetcher.call(remote_path, headers)
|
48
|
+
return nil if response.is_a?(Net::HTTPNotModified)
|
56
49
|
|
57
|
-
|
58
|
-
else
|
59
|
-
local_temp_path.open("wb") {|f| f << content }
|
50
|
+
content = response.body
|
60
51
|
|
61
|
-
|
62
|
-
|
63
|
-
|
52
|
+
etag = (response["ETag"] || "").gsub(%r{\AW/}, "")
|
53
|
+
correct_response = SharedHelpers.filesystem_access(local_temp_path) do
|
54
|
+
if response.is_a?(Net::HTTPPartialContent) && local_temp_path.size.nonzero?
|
55
|
+
local_temp_path.open("a") {|f| f << slice_body(content, 1..-1) }
|
64
56
|
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
57
|
+
etag_for(local_temp_path) == etag
|
58
|
+
else
|
59
|
+
local_temp_path.open("wb") {|f| f << content }
|
60
|
+
|
61
|
+
etag.length.zero? || etag_for(local_temp_path) == etag
|
70
62
|
end
|
63
|
+
end
|
71
64
|
|
72
|
-
|
73
|
-
|
65
|
+
if correct_response
|
66
|
+
SharedHelpers.filesystem_access(local_path) do
|
67
|
+
FileUtils.mv(local_temp_path, local_path)
|
74
68
|
end
|
69
|
+
return nil
|
70
|
+
end
|
75
71
|
|
76
|
-
|
72
|
+
if retrying
|
73
|
+
raise MisMatchedChecksumError.new(remote_path, etag, etag_for(local_temp_path))
|
77
74
|
end
|
75
|
+
|
76
|
+
update(local_path, remote_path, :retrying)
|
78
77
|
rescue Zlib::GzipFile::Error
|
79
78
|
raise Bundler::HTTPError
|
79
|
+
ensure
|
80
|
+
FileUtils.remove_file(local_temp_path) if File.exist?(local_temp_path)
|
80
81
|
end
|
81
82
|
|
82
83
|
def etag_for(path)
|