rubygems-update 3.1.6 → 3.2.0.rc.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CODE_OF_CONDUCT.md +55 -19
- data/CONTRIBUTING.md +1 -2
- data/History.txt +122 -14
- data/Manifest.txt +13 -25
- data/POLICIES.md +2 -9
- data/README.md +1 -1
- data/Rakefile +31 -33
- data/bin/update_rubygems +1 -1
- data/bundler/CHANGELOG.md +806 -741
- data/bundler/README.md +6 -8
- data/bundler/UPGRADING.md +16 -30
- data/bundler/bundler.gemspec +3 -3
- data/bundler/exe/bundle +3 -0
- data/bundler/lib/bundler.rb +15 -4
- data/bundler/lib/bundler/build_metadata.rb +2 -2
- data/bundler/lib/bundler/cli.rb +32 -11
- data/bundler/lib/bundler/cli/console.rb +1 -1
- data/bundler/lib/bundler/cli/gem.rb +83 -10
- data/bundler/lib/bundler/cli/info.rb +13 -3
- data/bundler/lib/bundler/cli/init.rb +1 -1
- data/bundler/lib/bundler/cli/install.rb +5 -14
- data/bundler/lib/bundler/cli/issue.rb +2 -2
- data/bundler/lib/bundler/cli/list.rb +11 -9
- data/bundler/lib/bundler/cli/outdated.rb +88 -65
- data/bundler/lib/bundler/cli/plugin.rb +10 -0
- data/bundler/lib/bundler/cli/pristine.rb +5 -0
- data/bundler/lib/bundler/definition.rb +32 -32
- data/bundler/lib/bundler/dependency.rb +0 -9
- data/bundler/lib/bundler/dsl.rb +1 -5
- data/bundler/lib/bundler/environment_preserver.rb +26 -2
- data/bundler/lib/bundler/errors.rb +1 -0
- data/bundler/lib/bundler/feature_flag.rb +0 -2
- data/bundler/lib/bundler/fetcher.rb +1 -0
- data/bundler/lib/bundler/friendly_errors.rb +4 -10
- data/bundler/lib/bundler/gem_helper.rb +17 -10
- data/bundler/lib/bundler/gem_version_promoter.rb +1 -1
- data/bundler/lib/bundler/injector.rb +14 -3
- data/bundler/lib/bundler/inline.rb +1 -1
- data/bundler/lib/bundler/installer.rb +29 -28
- data/bundler/lib/bundler/installer/gem_installer.rb +2 -2
- data/bundler/lib/bundler/installer/parallel_installer.rb +9 -9
- data/bundler/lib/bundler/lazy_specification.rb +16 -3
- data/bundler/lib/bundler/plugin.rb +26 -0
- data/bundler/lib/bundler/plugin/index.rb +9 -0
- data/bundler/lib/bundler/psyched_yaml.rb +0 -15
- data/bundler/lib/bundler/remote_specification.rb +4 -1
- data/bundler/lib/bundler/resolver.rb +31 -8
- data/bundler/lib/bundler/resolver/spec_group.rb +26 -5
- data/bundler/lib/bundler/rubygems_ext.rb +7 -8
- data/bundler/lib/bundler/rubygems_gem_installer.rb +1 -7
- data/bundler/lib/bundler/rubygems_integration.rb +3 -48
- data/bundler/lib/bundler/runtime.rb +2 -12
- data/bundler/lib/bundler/settings.rb +0 -3
- data/bundler/lib/bundler/shared_helpers.rb +1 -1
- data/bundler/lib/bundler/source/git.rb +4 -4
- data/bundler/lib/bundler/source/git/git_proxy.rb +53 -58
- data/bundler/lib/bundler/source/path.rb +5 -1
- data/bundler/lib/bundler/source/path/installer.rb +7 -9
- data/bundler/lib/bundler/source/rubygems.rb +11 -14
- data/bundler/lib/bundler/stub_specification.rb +16 -4
- data/bundler/lib/bundler/templates/newgem/CODE_OF_CONDUCT.md.tt +57 -47
- data/bundler/lib/bundler/templates/newgem/Gemfile.tt +9 -1
- data/bundler/lib/bundler/templates/newgem/Rakefile.tt +19 -5
- data/bundler/lib/bundler/templates/newgem/bin/console.tt +2 -0
- data/bundler/lib/bundler/templates/newgem/circleci/config.yml.tt +13 -0
- data/bundler/lib/bundler/templates/newgem/ext/newgem/extconf.rb.tt +2 -0
- data/bundler/lib/bundler/templates/newgem/github/workflows/main.yml.tt +18 -0
- data/bundler/lib/bundler/templates/newgem/gitlab-ci.yml.tt +9 -0
- data/bundler/lib/bundler/templates/newgem/lib/newgem.rb.tt +2 -0
- data/bundler/lib/bundler/templates/newgem/lib/newgem/version.rb.tt +2 -0
- data/bundler/lib/bundler/templates/newgem/newgem.gemspec.tt +6 -4
- data/bundler/lib/bundler/templates/newgem/rubocop.yml.tt +10 -0
- data/bundler/lib/bundler/templates/newgem/spec/newgem_spec.rb.tt +2 -0
- data/bundler/lib/bundler/templates/newgem/spec/spec_helper.rb.tt +2 -0
- data/bundler/lib/bundler/templates/newgem/test/{newgem_test.rb.tt → minitest/newgem_test.rb.tt} +2 -0
- data/bundler/lib/bundler/templates/newgem/test/{test_helper.rb.tt → minitest/test_helper.rb.tt} +2 -0
- data/bundler/lib/bundler/templates/newgem/test/test-unit/newgem_test.rb.tt +15 -0
- data/bundler/lib/bundler/templates/newgem/test/test-unit/test_helper.rb.tt +6 -0
- data/bundler/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent.rb +75 -189
- data/bundler/lib/bundler/vendor/thor/lib/thor.rb +0 -7
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions/create_link.rb +2 -1
- data/bundler/lib/bundler/vendor/thor/lib/thor/base.rb +9 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/version.rb +1 -1
- data/bundler/lib/bundler/version.rb +1 -1
- data/bundler/man/bundle-add.1 +1 -1
- data/bundler/man/bundle-add.1.txt +15 -15
- data/bundler/man/bundle-binstubs.1 +1 -1
- data/bundler/man/bundle-binstubs.1.txt +10 -10
- data/bundler/man/bundle-cache.1 +1 -1
- data/bundler/man/bundle-cache.1.txt +15 -15
- data/bundler/man/bundle-check.1 +1 -1
- data/bundler/man/bundle-check.1.txt +8 -8
- data/bundler/man/bundle-clean.1 +1 -1
- data/bundler/man/bundle-clean.1.txt +6 -6
- data/bundler/man/bundle-config.1 +3 -9
- data/bundler/man/bundle-config.1.txt +271 -272
- data/bundler/man/bundle-config.ronn +5 -9
- data/bundler/man/bundle-doctor.1 +1 -1
- data/bundler/man/bundle-doctor.1.txt +9 -9
- data/bundler/man/bundle-exec.1 +1 -1
- data/bundler/man/bundle-exec.1.txt +84 -81
- data/bundler/man/bundle-gem.1 +25 -3
- data/bundler/man/bundle-gem.1.txt +65 -39
- data/bundler/man/bundle-gem.ronn +30 -7
- data/bundler/man/bundle-info.1 +1 -1
- data/bundler/man/bundle-info.1.txt +2 -2
- data/bundler/man/bundle-init.1 +1 -1
- data/bundler/man/bundle-init.1.txt +9 -9
- data/bundler/man/bundle-inject.1 +1 -1
- data/bundler/man/bundle-inject.1.txt +4 -4
- data/bundler/man/bundle-install.1 +1 -1
- data/bundler/man/bundle-install.1.txt +169 -169
- data/bundler/man/bundle-list.1 +7 -7
- data/bundler/man/bundle-list.1.txt +12 -11
- data/bundler/man/bundle-list.ronn +6 -6
- data/bundler/man/bundle-lock.1 +1 -1
- data/bundler/man/bundle-lock.1.txt +28 -28
- data/bundler/man/bundle-open.1 +1 -1
- data/bundler/man/bundle-open.1.txt +3 -3
- data/bundler/man/bundle-outdated.1 +1 -1
- data/bundler/man/bundle-outdated.1.txt +34 -34
- data/bundler/man/bundle-platform.1 +1 -1
- data/bundler/man/bundle-platform.1.txt +16 -16
- data/bundler/man/bundle-pristine.1 +1 -1
- data/bundler/man/bundle-pristine.1.txt +8 -8
- data/bundler/man/bundle-remove.1 +1 -1
- data/bundler/man/bundle-remove.1.txt +9 -9
- data/bundler/man/bundle-show.1 +1 -1
- data/bundler/man/bundle-show.1.txt +8 -8
- data/bundler/man/bundle-update.1 +1 -1
- data/bundler/man/bundle-update.1.txt +149 -148
- data/bundler/man/bundle-viz.1 +1 -1
- data/bundler/man/bundle-viz.1.txt +11 -11
- data/bundler/man/bundle.1 +1 -1
- data/bundler/man/bundle.1.txt +31 -31
- data/bundler/man/gemfile.5 +1 -1
- data/bundler/man/gemfile.5.txt +218 -216
- data/lib/rubygems.rb +68 -148
- data/lib/rubygems/available_set.rb +4 -4
- data/lib/rubygems/basic_specification.rb +11 -5
- data/lib/rubygems/bundler_version_finder.rb +14 -9
- data/lib/rubygems/command.rb +16 -14
- data/lib/rubygems/command_manager.rb +4 -3
- data/lib/rubygems/commands/cert_command.rb +1 -1
- data/lib/rubygems/commands/cleanup_command.rb +3 -3
- data/lib/rubygems/commands/contents_command.rb +4 -4
- data/lib/rubygems/commands/dependency_command.rb +6 -6
- data/lib/rubygems/commands/fetch_command.rb +2 -2
- data/lib/rubygems/commands/help_command.rb +1 -1
- data/lib/rubygems/commands/info_command.rb +9 -4
- data/lib/rubygems/commands/install_command.rb +3 -3
- data/lib/rubygems/commands/list_command.rb +9 -6
- data/lib/rubygems/commands/lock_command.rb +1 -1
- data/lib/rubygems/commands/open_command.rb +0 -2
- data/lib/rubygems/commands/pristine_command.rb +10 -2
- data/lib/rubygems/commands/push_command.rb +4 -42
- data/lib/rubygems/commands/query_command.rb +7 -352
- data/lib/rubygems/commands/search_command.rb +8 -6
- data/lib/rubygems/commands/setup_command.rb +128 -32
- data/lib/rubygems/commands/specification_command.rb +2 -2
- data/lib/rubygems/commands/stale_command.rb +1 -1
- data/lib/rubygems/commands/uninstall_command.rb +1 -1
- data/lib/rubygems/commands/unpack_command.rb +1 -1
- data/lib/rubygems/commands/update_command.rb +40 -10
- data/lib/rubygems/config_file.rb +11 -2
- data/lib/rubygems/core_ext/kernel_require.rb +2 -2
- data/lib/rubygems/defaults.rb +99 -5
- data/lib/rubygems/dependency.rb +2 -5
- data/lib/rubygems/dependency_installer.rb +1 -73
- data/lib/rubygems/dependency_list.rb +7 -7
- data/lib/rubygems/deprecate.rb +46 -1
- data/lib/rubygems/doctor.rb +4 -2
- data/lib/rubygems/errors.rb +3 -2
- data/lib/rubygems/exceptions.rb +2 -13
- data/lib/rubygems/ext.rb +6 -6
- data/lib/rubygems/ext/build_error.rb +2 -0
- data/lib/rubygems/ext/builder.rb +1 -1
- data/lib/rubygems/ext/cmake_builder.rb +1 -1
- data/lib/rubygems/ext/ext_conf_builder.rb +6 -7
- data/lib/rubygems/gem_runner.rb +3 -8
- data/lib/rubygems/gemcutter_utilities.rb +1 -1
- data/lib/rubygems/indexer.rb +1 -19
- data/lib/rubygems/install_update_options.rb +5 -5
- data/lib/rubygems/installer.rb +45 -42
- data/lib/rubygems/installer_test_case.rb +19 -2
- data/lib/rubygems/installer_uninstaller_utils.rb +24 -0
- data/lib/rubygems/local_remote_options.rb +1 -1
- data/lib/rubygems/name_tuple.rb +2 -4
- data/lib/rubygems/package.rb +8 -13
- data/lib/rubygems/package/old.rb +1 -1
- data/lib/rubygems/package/tar_header.rb +3 -3
- data/lib/rubygems/package/tar_reader.rb +0 -1
- data/lib/rubygems/package/tar_reader/entry.rb +0 -1
- data/lib/rubygems/package/tar_test_case.rb +1 -1
- data/lib/rubygems/package/tar_writer.rb +2 -6
- data/lib/rubygems/package_task.rb +1 -5
- data/lib/rubygems/path_support.rb +1 -1
- data/lib/rubygems/platform.rb +3 -3
- data/lib/rubygems/query_utils.rb +362 -0
- data/lib/rubygems/rdoc.rb +0 -12
- data/lib/rubygems/remote_fetcher.rb +5 -19
- data/lib/rubygems/request/connection_pools.rb +1 -1
- data/lib/rubygems/request_set.rb +5 -5
- data/lib/rubygems/request_set/gem_dependency_api.rb +1 -1
- data/lib/rubygems/request_set/lockfile.rb +8 -8
- data/lib/rubygems/request_set/lockfile/tokenizer.rb +1 -1
- data/lib/rubygems/requirement.rb +14 -15
- data/lib/rubygems/resolver.rb +7 -8
- data/lib/rubygems/resolver/api_set.rb +3 -3
- data/lib/rubygems/resolver/composed_set.rb +3 -3
- data/lib/rubygems/resolver/conflict.rb +1 -1
- data/lib/rubygems/resolver/index_set.rb +1 -1
- data/lib/rubygems/resolver/installer_set.rb +3 -3
- data/lib/rubygems/resolver/lock_set.rb +1 -1
- data/lib/rubygems/safe_yaml.rb +4 -4
- data/lib/rubygems/security.rb +25 -25
- data/lib/rubygems/security/policy.rb +3 -3
- data/lib/rubygems/security/signer.rb +4 -4
- data/lib/rubygems/security/trust_dir.rb +1 -1
- data/lib/rubygems/server.rb +8 -8
- data/lib/rubygems/source/git.rb +7 -6
- data/lib/rubygems/source/local.rb +2 -2
- data/lib/rubygems/source_list.rb +4 -5
- data/lib/rubygems/spec_fetcher.rb +18 -15
- data/lib/rubygems/specification.rb +79 -104
- data/lib/rubygems/specification_policy.rb +79 -27
- data/lib/rubygems/ssl_certs/{rubygems.org → index.rubygems.org}/GlobalSignRootCA.pem +0 -0
- data/lib/rubygems/ssl_certs/rubygems.global.ssl.fastly.net/DigiCertHighAssuranceEVRootCA.pem +23 -0
- data/lib/rubygems/ssl_certs/rubygems.org/AddTrustExternalCARoot.pem +25 -0
- data/lib/rubygems/test_case.rb +63 -83
- data/lib/rubygems/test_utilities.rb +6 -6
- data/lib/rubygems/uninstaller.rb +35 -14
- data/lib/rubygems/user_interaction.rb +1 -10
- data/lib/rubygems/util.rb +10 -2
- data/lib/rubygems/util/licenses.rb +4 -4
- data/lib/rubygems/validator.rb +1 -1
- data/lib/rubygems/version.rb +4 -4
- data/rubygems-update.gemspec +2 -2
- data/setup.rb +2 -7
- data/test/rubygems/specifications/bar-0.0.2.gemspec +0 -2
- data/test/rubygems/specifications/rubyforge-0.0.1.gemspec +0 -2
- data/test/rubygems/test_bundled_ca.rb +4 -12
- data/test/rubygems/test_deprecate.rb +43 -4
- data/test/rubygems/test_gem.rb +79 -74
- data/test/rubygems/test_gem_available_set.rb +3 -3
- data/test/rubygems/test_gem_bundler_version_finder.rb +19 -1
- data/test/rubygems/test_gem_command.rb +24 -3
- data/test/rubygems/test_gem_command_manager.rb +37 -4
- data/test/rubygems/test_gem_commands_build_command.rb +7 -2
- data/test/rubygems/test_gem_commands_cert_command.rb +2 -2
- data/test/rubygems/test_gem_commands_cleanup_command.rb +1 -1
- data/test/rubygems/test_gem_commands_contents_command.rb +48 -15
- data/test/rubygems/test_gem_commands_environment_command.rb +21 -21
- data/test/rubygems/test_gem_commands_generate_index_command.rb +1 -5
- data/test/rubygems/test_gem_commands_info_command.rb +6 -6
- data/test/rubygems/test_gem_commands_install_command.rb +31 -31
- data/test/rubygems/test_gem_commands_mirror.rb +1 -1
- data/test/rubygems/test_gem_commands_open_command.rb +4 -4
- data/test/rubygems/test_gem_commands_owner_command.rb +11 -3
- data/test/rubygems/test_gem_commands_pristine_command.rb +41 -8
- data/test/rubygems/test_gem_commands_push_command.rb +7 -2
- data/test/rubygems/test_gem_commands_query_command.rb +9 -5
- data/test/rubygems/test_gem_commands_setup_command.rb +160 -108
- data/test/rubygems/test_gem_commands_signin_command.rb +6 -4
- data/test/rubygems/test_gem_commands_signout_command.rb +0 -5
- data/test/rubygems/test_gem_commands_specification_command.rb +18 -18
- data/test/rubygems/test_gem_commands_uninstall_command.rb +1 -1
- data/test/rubygems/test_gem_commands_update_command.rb +68 -5
- data/test/rubygems/test_gem_commands_which_command.rb +3 -3
- data/test/rubygems/test_gem_commands_yank_command.rb +14 -6
- data/test/rubygems/test_gem_config_file.rb +7 -10
- data/test/rubygems/test_gem_dependency_installer.rb +52 -189
- data/test/rubygems/test_gem_dependency_list.rb +8 -8
- data/test/rubygems/test_gem_dependency_resolution_error.rb +1 -1
- data/test/rubygems/test_gem_doctor.rb +28 -0
- data/test/rubygems/test_gem_ext_builder.rb +14 -25
- data/test/rubygems/test_gem_ext_cmake_builder.rb +13 -12
- data/test/rubygems/test_gem_ext_configure_builder.rb +1 -9
- data/test/rubygems/test_gem_ext_ext_conf_builder.rb +0 -1
- data/test/rubygems/test_gem_ext_rake_builder.rb +9 -9
- data/test/rubygems/test_gem_gem_runner.rb +42 -0
- data/test/rubygems/test_gem_gemcutter_utilities.rb +5 -0
- data/test/rubygems/test_gem_indexer.rb +9 -13
- data/test/rubygems/test_gem_installer.rb +149 -45
- data/test/rubygems/test_gem_package.rb +13 -12
- data/test/rubygems/test_gem_package_tar_header.rb +19 -0
- data/test/rubygems/test_gem_package_tar_writer.rb +3 -3
- data/test/rubygems/test_gem_package_task.rb +46 -11
- data/test/rubygems/test_gem_remote_fetcher.rb +152 -190
- data/test/rubygems/test_gem_request.rb +11 -11
- data/test/rubygems/test_gem_request_set.rb +20 -20
- data/test/rubygems/test_gem_request_set_gem_dependency_api.rb +3 -3
- data/test/rubygems/test_gem_request_set_lockfile_parser.rb +9 -9
- data/test/rubygems/test_gem_request_set_lockfile_tokenizer.rb +118 -118
- data/test/rubygems/test_gem_requirement.rb +2 -2
- data/test/rubygems/test_gem_resolver.rb +6 -6
- data/test/rubygems/test_gem_resolver_api_set.rb +3 -3
- data/test/rubygems/test_gem_resolver_best_set.rb +2 -2
- data/test/rubygems/test_gem_resolver_index_set.rb +2 -2
- data/test/rubygems/test_gem_resolver_installer_set.rb +7 -7
- data/test/rubygems/test_gem_resolver_lock_set.rb +3 -3
- data/test/rubygems/test_gem_security.rb +20 -20
- data/test/rubygems/test_gem_security_policy.rb +5 -8
- data/test/rubygems/test_gem_security_signer.rb +8 -8
- data/test/rubygems/test_gem_security_trust_dir.rb +2 -2
- data/test/rubygems/test_gem_server.rb +10 -10
- data/test/rubygems/test_gem_source.rb +12 -14
- data/test/rubygems/test_gem_source_git.rb +12 -11
- data/test/rubygems/test_gem_source_installed.rb +7 -7
- data/test/rubygems/test_gem_source_local.rb +8 -8
- data/test/rubygems/test_gem_source_lock.rb +10 -10
- data/test/rubygems/test_gem_source_specific_file.rb +7 -7
- data/test/rubygems/test_gem_source_vendor.rb +7 -7
- data/test/rubygems/test_gem_spec_fetcher.rb +11 -2
- data/test/rubygems/test_gem_specification.rb +143 -113
- data/test/rubygems/test_gem_stream_ui.rb +3 -1
- data/test/rubygems/test_gem_text.rb +1 -1
- data/test/rubygems/test_gem_uninstaller.rb +134 -10
- data/test/rubygems/test_gem_util.rb +7 -5
- data/test/rubygems/test_gem_version.rb +1 -1
- data/test/rubygems/test_kernel.rb +10 -12
- data/test/rubygems/test_project_sanity.rb +8 -1
- data/test/rubygems/test_require.rb +141 -43
- metadata +32 -45
- data/.bundle/config +0 -2
- data/.rubocop.yml +0 -91
- data/Gemfile +0 -8
- data/Gemfile.lock +0 -43
- data/bundler/CODE_OF_CONDUCT.md +0 -136
- data/lib/rubygems/source_local.rb +0 -7
- data/lib/rubygems/source_specific_file.rb +0 -6
- data/lib/rubygems/ssl_certs/rubygems.org/GlobalSignRootCA_R3.pem +0 -21
- data/lib/ubygems.rb +0 -14
- data/tmp/.keep +0 -0
- data/util/CL2notes +0 -55
- data/util/bisect +0 -10
- data/util/ci.sh +0 -62
- data/util/cops/deprecations.rb +0 -52
- data/util/create_certs.rb +0 -171
- data/util/create_certs.sh +0 -27
- data/util/create_encrypted_key.rb +0 -16
- data/util/generate_spdx_license_list.rb +0 -63
- data/util/patch_with_prs.rb +0 -77
- data/util/rubocop +0 -8
- data/util/update_bundled_ca_certificates.rb +0 -137
- data/util/update_changelog.rb +0 -64
data/lib/rubygems/exceptions.rb
CHANGED
@@ -5,18 +5,7 @@ require 'rubygems/deprecate'
|
|
5
5
|
##
|
6
6
|
# Base exception class for RubyGems. All exception raised by RubyGems are a
|
7
7
|
# subclass of this one.
|
8
|
-
class Gem::Exception < RuntimeError
|
9
|
-
|
10
|
-
##
|
11
|
-
#--
|
12
|
-
# TODO: remove in RubyGems 4, nobody sets this
|
13
|
-
|
14
|
-
attr_accessor :source_exception # :nodoc:
|
15
|
-
|
16
|
-
extend Gem::Deprecate
|
17
|
-
deprecate :source_exception, :none, 2018, 12
|
18
|
-
|
19
|
-
end
|
8
|
+
class Gem::Exception < RuntimeError; end
|
20
9
|
|
21
10
|
class Gem::CommandLineError < Gem::Exception; end
|
22
11
|
|
@@ -256,7 +245,7 @@ class Gem::UnsatisfiableDependencyError < Gem::DependencyError
|
|
256
245
|
|
257
246
|
def initialize(dep, platform_mismatch=nil)
|
258
247
|
if platform_mismatch and !platform_mismatch.empty?
|
259
|
-
plats = platform_mismatch.map {
|
248
|
+
plats = platform_mismatch.map {|x| x.platform.to_s }.sort.uniq
|
260
249
|
super "Unable to resolve dependency: No match for '#{dep}' on this platform. Found: #{plats.join(', ')}"
|
261
250
|
else
|
262
251
|
if dep.explicit?
|
data/lib/rubygems/ext.rb
CHANGED
@@ -10,9 +10,9 @@
|
|
10
10
|
|
11
11
|
module Gem::Ext; end
|
12
12
|
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
13
|
+
require_relative 'ext/build_error'
|
14
|
+
require_relative 'ext/builder'
|
15
|
+
require_relative 'ext/configure_builder'
|
16
|
+
require_relative 'ext/ext_conf_builder'
|
17
|
+
require_relative 'ext/rake_builder'
|
18
|
+
require_relative 'ext/cmake_builder'
|
data/lib/rubygems/ext/builder.rb
CHANGED
@@ -5,15 +5,14 @@
|
|
5
5
|
# See LICENSE.txt for permissions.
|
6
6
|
#++
|
7
7
|
|
8
|
-
require 'fileutils'
|
9
|
-
require 'tempfile'
|
10
8
|
require 'shellwords'
|
11
9
|
|
12
10
|
class Gem::Ext::ExtConfBuilder < Gem::Ext::Builder
|
13
11
|
|
14
|
-
FileEntry = FileUtils::Entry_ # :nodoc:
|
15
|
-
|
16
12
|
def self.build(extension, dest_path, results, args=[], lib_dir=nil)
|
13
|
+
require 'fileutils'
|
14
|
+
require 'tempfile'
|
15
|
+
|
17
16
|
tmp_dest = Dir.mktmpdir(".gem.", ".")
|
18
17
|
|
19
18
|
# Some versions of `mktmpdir` return absolute paths, which will break make
|
@@ -27,7 +26,7 @@ class Gem::Ext::ExtConfBuilder < Gem::Ext::Builder
|
|
27
26
|
# Details: https://github.com/rubygems/rubygems/issues/977#issuecomment-171544940
|
28
27
|
tmp_dest = get_relative_path(tmp_dest)
|
29
28
|
|
30
|
-
Tempfile.open %w
|
29
|
+
Tempfile.open %w[siteconf .rb], "." do |siteconf|
|
31
30
|
siteconf.puts "require 'rbconfig'"
|
32
31
|
siteconf.puts "dest_path = #{tmp_dest.dump}"
|
33
32
|
%w[sitearchdir sitelibdir].each do |dir|
|
@@ -67,11 +66,11 @@ class Gem::Ext::ExtConfBuilder < Gem::Ext::Builder
|
|
67
66
|
if Gem.install_extension_in_lib and lib_dir
|
68
67
|
FileUtils.mkdir_p lib_dir
|
69
68
|
entries = Dir.entries(tmp_dest) - %w[. ..]
|
70
|
-
entries = entries.map {
|
69
|
+
entries = entries.map {|entry| File.join tmp_dest, entry }
|
71
70
|
FileUtils.cp_r entries, lib_dir, :remove_destination => true
|
72
71
|
end
|
73
72
|
|
74
|
-
|
73
|
+
FileUtils::Entry_.new(tmp_dest).traverse do |ent|
|
75
74
|
destent = ent.class.new(dest_path, ent.rel)
|
76
75
|
destent.exist? or FileUtils.mv(ent.path, destent.path)
|
77
76
|
end
|
data/lib/rubygems/gem_runner.rb
CHANGED
@@ -7,7 +7,6 @@
|
|
7
7
|
|
8
8
|
require 'rubygems'
|
9
9
|
require 'rubygems/command_manager'
|
10
|
-
require 'rubygems/config_file'
|
11
10
|
require 'rubygems/deprecate'
|
12
11
|
|
13
12
|
##
|
@@ -26,13 +25,9 @@ Gem.load_env_plugins rescue nil
|
|
26
25
|
|
27
26
|
class Gem::GemRunner
|
28
27
|
|
29
|
-
def initialize
|
30
|
-
|
31
|
-
|
32
|
-
end
|
33
|
-
|
34
|
-
@command_manager_class = options[:command_manager] || Gem::CommandManager
|
35
|
-
@config_file_class = options[:config_file] || Gem::ConfigFile
|
28
|
+
def initialize
|
29
|
+
@command_manager_class = Gem::CommandManager
|
30
|
+
@config_file_class = Gem::ConfigFile
|
36
31
|
end
|
37
32
|
|
38
33
|
##
|
@@ -19,7 +19,7 @@ module Gem::GemcutterUtilities
|
|
19
19
|
def add_key_option
|
20
20
|
add_option('-k', '--key KEYNAME', Symbol,
|
21
21
|
'Use the given API key',
|
22
|
-
|
22
|
+
"from #{Gem.configuration.credentials_path}") do |value,options|
|
23
23
|
options[:key] = value
|
24
24
|
end
|
25
25
|
end
|
data/lib/rubygems/indexer.rb
CHANGED
@@ -4,19 +4,6 @@ require 'rubygems/package'
|
|
4
4
|
require 'time'
|
5
5
|
require 'tmpdir'
|
6
6
|
|
7
|
-
rescue_exceptions = [LoadError]
|
8
|
-
begin
|
9
|
-
require 'bundler/errors'
|
10
|
-
rescue LoadError # this rubygems + old ruby
|
11
|
-
else # this rubygems + ruby trunk with bundler
|
12
|
-
rescue_exceptions << Bundler::GemfileNotFound
|
13
|
-
end
|
14
|
-
begin
|
15
|
-
gem 'builder'
|
16
|
-
require 'builder/xchar'
|
17
|
-
rescue *rescue_exceptions
|
18
|
-
end
|
19
|
-
|
20
7
|
##
|
21
8
|
# Top level class for building the gem repository index.
|
22
9
|
|
@@ -62,11 +49,6 @@ class Gem::Indexer
|
|
62
49
|
require 'tmpdir'
|
63
50
|
require 'zlib'
|
64
51
|
|
65
|
-
unless defined?(Builder::XChar)
|
66
|
-
raise "Gem::Indexer requires that the XML Builder library be installed:" +
|
67
|
-
"\n\tgem install builder"
|
68
|
-
end
|
69
|
-
|
70
52
|
options = { :build_modern => true }.merge options
|
71
53
|
|
72
54
|
@build_modern = options[:build_modern]
|
@@ -383,7 +365,7 @@ class Gem::Indexer
|
|
383
365
|
end
|
384
366
|
|
385
367
|
specs = map_gems_to_specs updated_gems
|
386
|
-
prerelease, released = specs.partition {
|
368
|
+
prerelease, released = specs.partition {|s| s.version.prerelease? }
|
387
369
|
|
388
370
|
files = build_marshal_gemspecs specs
|
389
371
|
|
@@ -25,12 +25,12 @@ module Gem::InstallUpdateOptions
|
|
25
25
|
end
|
26
26
|
|
27
27
|
add_option(:"Install/Update", '-n', '--bindir DIR',
|
28
|
-
'Directory where executables
|
29
|
-
'
|
28
|
+
'Directory where executables will be',
|
29
|
+
'placed when the gem is installed') do |value, options|
|
30
30
|
options[:bin_dir] = File.expand_path(value)
|
31
31
|
end
|
32
32
|
|
33
|
-
add_option(:"Install/Update",
|
33
|
+
add_option(:"Install/Update", '--document [TYPES]', Array,
|
34
34
|
'Generate documentation for installed gems',
|
35
35
|
'List the documentation types you wish to',
|
36
36
|
'generate. For example: rdoc,ri') do |value, options|
|
@@ -88,7 +88,7 @@ module Gem::InstallUpdateOptions
|
|
88
88
|
options[:ignore_dependencies] = value
|
89
89
|
end
|
90
90
|
|
91
|
-
add_option(:"Install/Update",
|
91
|
+
add_option(:"Install/Update", '--[no-]format-executable',
|
92
92
|
'Make installed executable names match Ruby.',
|
93
93
|
'If Ruby is ruby18, foo_exec will be',
|
94
94
|
'foo_exec18') do |value, options|
|
@@ -154,7 +154,7 @@ module Gem::InstallUpdateOptions
|
|
154
154
|
'Omit the named groups (comma separated)',
|
155
155
|
'when installing from a gem dependencies',
|
156
156
|
'file') do |v,o|
|
157
|
-
options[:without_groups].concat v.map {
|
157
|
+
options[:without_groups].concat v.map {|without| without.intern }
|
158
158
|
end
|
159
159
|
|
160
160
|
add_option(:"Install/Update", '--default',
|
data/lib/rubygems/installer.rb
CHANGED
@@ -6,6 +6,7 @@
|
|
6
6
|
#++
|
7
7
|
|
8
8
|
require 'rubygems/command'
|
9
|
+
require 'rubygems/installer_uninstaller_utils'
|
9
10
|
require 'rubygems/exceptions'
|
10
11
|
require 'rubygems/deprecate'
|
11
12
|
require 'rubygems/package'
|
@@ -43,10 +44,7 @@ class Gem::Installer
|
|
43
44
|
|
44
45
|
include Gem::UserInteraction
|
45
46
|
|
46
|
-
|
47
|
-
# Filename of the gem being installed.
|
48
|
-
|
49
|
-
attr_reader :gem
|
47
|
+
include Gem::InstallerUninstallerUtils
|
50
48
|
|
51
49
|
##
|
52
50
|
# The directory a gem's executables will be installed into
|
@@ -180,15 +178,7 @@ class Gem::Installer
|
|
180
178
|
require 'fileutils'
|
181
179
|
|
182
180
|
@options = options
|
183
|
-
|
184
|
-
security_policy = options[:security_policy]
|
185
|
-
@package = Gem::Package.new package, security_policy
|
186
|
-
if $VERBOSE
|
187
|
-
warn "constructing an Installer object with a string is deprecated. Please use Gem::Installer.at (called from: #{caller.first})"
|
188
|
-
end
|
189
|
-
else
|
190
|
-
@package = package
|
191
|
-
end
|
181
|
+
@package = package
|
192
182
|
|
193
183
|
process_options
|
194
184
|
|
@@ -330,6 +320,7 @@ class Gem::Installer
|
|
330
320
|
end
|
331
321
|
|
332
322
|
generate_bin
|
323
|
+
generate_plugins
|
333
324
|
|
334
325
|
unless @options[:install_as_default]
|
335
326
|
write_spec
|
@@ -419,7 +410,7 @@ class Gem::Installer
|
|
419
410
|
|
420
411
|
def installation_satisfies_dependency?(dependency)
|
421
412
|
return true if @options[:development] and dependency.type == :development
|
422
|
-
return true if installed_specs.detect {
|
413
|
+
return true if installed_specs.detect {|s| dependency.matches_spec? s }
|
423
414
|
return false if @only_install_dir
|
424
415
|
not dependency.matching_specs.empty?
|
425
416
|
end
|
@@ -431,7 +422,7 @@ class Gem::Installer
|
|
431
422
|
@gem_dir = directory
|
432
423
|
extract_files
|
433
424
|
end
|
434
|
-
|
425
|
+
rubygems_deprecate :unpack
|
435
426
|
|
436
427
|
##
|
437
428
|
# The location of the spec file that is installed.
|
@@ -491,13 +482,7 @@ class Gem::Installer
|
|
491
482
|
def generate_bin # :nodoc:
|
492
483
|
return if spec.executables.nil? or spec.executables.empty?
|
493
484
|
|
494
|
-
|
495
|
-
Dir.mkdir @bin_dir, *[options[:dir_mode] && 0755].compact
|
496
|
-
rescue SystemCallError
|
497
|
-
raise unless File.directory? @bin_dir
|
498
|
-
end
|
499
|
-
|
500
|
-
raise Gem::FilePermissionError.new(@bin_dir) unless File.writable? @bin_dir
|
485
|
+
ensure_writable_dir @bin_dir
|
501
486
|
|
502
487
|
spec.executables.each do |filename|
|
503
488
|
filename.tap(&Gem::UNTAINT)
|
@@ -520,7 +505,19 @@ class Gem::Installer
|
|
520
505
|
else
|
521
506
|
generate_bin_symlink filename, @bin_dir
|
522
507
|
end
|
508
|
+
end
|
509
|
+
end
|
510
|
+
|
511
|
+
def generate_plugins # :nodoc:
|
512
|
+
latest = Gem::Installer.install_lock.synchronize { Gem::Specification.latest_spec_for(spec.name) }
|
513
|
+
return if latest && latest.version > spec.version
|
514
|
+
|
515
|
+
ensure_writable_dir @plugins_dir
|
523
516
|
|
517
|
+
if spec.plugins.empty?
|
518
|
+
remove_plugins_for(spec, @plugins_dir)
|
519
|
+
else
|
520
|
+
regenerate_plugins_for(spec, @plugins_dir)
|
524
521
|
end
|
525
522
|
end
|
526
523
|
|
@@ -587,9 +584,9 @@ class Gem::Installer
|
|
587
584
|
def shebang(bin_file_name)
|
588
585
|
ruby_name = RbConfig::CONFIG['ruby_install_name'] if @env_shebang
|
589
586
|
path = File.join gem_dir, spec.bindir, bin_file_name
|
590
|
-
first_line = File.open(path, "rb") {|file| file.gets}
|
587
|
+
first_line = File.open(path, "rb") {|file| file.gets } || ""
|
591
588
|
|
592
|
-
if
|
589
|
+
if first_line.start_with?("#!")
|
593
590
|
# Preserve extra words on shebang line, like "-w". Thanks RPA.
|
594
591
|
shebang = first_line.sub(/\A\#!.*?ruby\S*((\s+\S+)+)/, "#!#{Gem.ruby}")
|
595
592
|
opts = $1
|
@@ -684,6 +681,7 @@ class Gem::Installer
|
|
684
681
|
@force = options[:force]
|
685
682
|
@install_dir = options[:install_dir]
|
686
683
|
@gem_home = options[:install_dir] || Gem.dir
|
684
|
+
@plugins_dir = Gem.plugindir(@gem_home)
|
687
685
|
@ignore_dependencies = options[:ignore_dependencies]
|
688
686
|
@format_executable = options[:format_executable]
|
689
687
|
@wrappers = options[:wrappers]
|
@@ -708,8 +706,10 @@ class Gem::Installer
|
|
708
706
|
end
|
709
707
|
|
710
708
|
def check_that_user_bin_dir_is_in_path # :nodoc:
|
709
|
+
return if self.class.path_warning
|
710
|
+
|
711
711
|
user_bin_dir = @bin_dir || Gem.bindir(gem_home)
|
712
|
-
user_bin_dir = user_bin_dir.
|
712
|
+
user_bin_dir = user_bin_dir.tr(File::SEPARATOR, File::ALT_SEPARATOR) if
|
713
713
|
File::ALT_SEPARATOR
|
714
714
|
|
715
715
|
path = ENV['PATH']
|
@@ -722,10 +722,8 @@ class Gem::Installer
|
|
722
722
|
|
723
723
|
unless path.include? user_bin_dir
|
724
724
|
unless !Gem.win_platform? && (path.include? user_bin_dir.sub(ENV['HOME'], '~'))
|
725
|
-
|
726
|
-
|
727
|
-
self.class.path_warning = true
|
728
|
-
end
|
725
|
+
alert_warning "You don't have #{user_bin_dir} in your PATH,\n\t gem executables will not run."
|
726
|
+
self.class.path_warning = true
|
729
727
|
end
|
730
728
|
end
|
731
729
|
end
|
@@ -810,7 +808,7 @@ TEXT
|
|
810
808
|
ruby_exe = "ruby.exe" if ruby_exe.empty?
|
811
809
|
|
812
810
|
if File.exist?(File.join bindir, ruby_exe)
|
813
|
-
# stub & ruby.exe
|
811
|
+
# stub & ruby.exe within same folder. Portable
|
814
812
|
<<-TEXT
|
815
813
|
@ECHO OFF
|
816
814
|
@"%~dp0#{ruby_exe}" "%~dpn0" %*
|
@@ -844,18 +842,6 @@ TEXT
|
|
844
842
|
builder.build_extensions
|
845
843
|
end
|
846
844
|
|
847
|
-
##
|
848
|
-
# Logs the build +output+ in +build_dir+, then raises Gem::Ext::BuildError.
|
849
|
-
#
|
850
|
-
# TODO: Delete this for RubyGems 4. It remains for API compatibility
|
851
|
-
|
852
|
-
def extension_build_error(build_dir, output, backtrace = nil) # :nodoc:
|
853
|
-
builder = Gem::Ext::Builder.new spec, @build_args
|
854
|
-
|
855
|
-
builder.build_error build_dir, output, backtrace
|
856
|
-
end
|
857
|
-
deprecate :extension_build_error, :none, 2018, 12
|
858
|
-
|
859
845
|
##
|
860
846
|
# Reads the file index and extracts each file into the gem directory.
|
861
847
|
#
|
@@ -895,6 +881,13 @@ TEXT
|
|
895
881
|
gem_dir.to_s
|
896
882
|
end
|
897
883
|
|
884
|
+
##
|
885
|
+
# Filename of the gem being installed.
|
886
|
+
|
887
|
+
def gem
|
888
|
+
@package.gem.path
|
889
|
+
end
|
890
|
+
|
898
891
|
##
|
899
892
|
# Performs various checks before installing the gem such as the install
|
900
893
|
# repository is writable and its directories exist, required Ruby and
|
@@ -959,4 +952,14 @@ TEXT
|
|
959
952
|
@package.copy_to cache_file
|
960
953
|
end
|
961
954
|
|
955
|
+
def ensure_writable_dir(dir) # :nodoc:
|
956
|
+
begin
|
957
|
+
Dir.mkdir dir, *[options[:dir_mode] && 0755].compact
|
958
|
+
rescue SystemCallError
|
959
|
+
raise unless File.directory? dir
|
960
|
+
end
|
961
|
+
|
962
|
+
raise Gem::FilePermissionError.new(dir) unless File.writable? dir
|
963
|
+
end
|
964
|
+
|
962
965
|
end
|
@@ -171,10 +171,10 @@ class Gem::InstallerTestCase < Gem::TestCase
|
|
171
171
|
##
|
172
172
|
# Sets up the base @gem, builds it and returns an installer for it.
|
173
173
|
#
|
174
|
-
def util_setup_installer
|
174
|
+
def util_setup_installer(&block)
|
175
175
|
@gem = setup_base_gem
|
176
176
|
|
177
|
-
util_setup_gem
|
177
|
+
util_setup_gem(&block)
|
178
178
|
end
|
179
179
|
|
180
180
|
##
|
@@ -230,4 +230,21 @@ class Gem::InstallerTestCase < Gem::TestCase
|
|
230
230
|
:user_install => user)
|
231
231
|
end
|
232
232
|
|
233
|
+
@@symlink_supported = nil
|
234
|
+
|
235
|
+
# This is needed for Windows environment without symlink support enabled (the default
|
236
|
+
# for non admin) to be able to skip test for features using symlinks.
|
237
|
+
def symlink_supported?
|
238
|
+
if @@symlink_supported.nil?
|
239
|
+
begin
|
240
|
+
File.symlink("", "")
|
241
|
+
rescue Errno::ENOENT, Errno::EEXIST
|
242
|
+
@@symlink_supported = true
|
243
|
+
rescue NotImplementedError, SystemCallError
|
244
|
+
@@symlink_supported = false
|
245
|
+
end
|
246
|
+
end
|
247
|
+
@@symlink_supported
|
248
|
+
end
|
249
|
+
|
233
250
|
end
|