rubygems-update 3.1.0 → 3.2.0
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 +25 -11
- data/History.txt +435 -179
- data/Manifest.txt +44 -77
- data/POLICIES.md +2 -9
- data/README.md +5 -5
- data/Rakefile +50 -83
- data/bin/update_rubygems +2 -2
- data/bundler/CHANGELOG.md +1590 -1400
- data/bundler/README.md +6 -8
- data/bundler/UPGRADING.md +18 -32
- data/bundler/bundler.gemspec +3 -3
- data/bundler/exe/bundle +3 -0
- data/bundler/lib/bundler.rb +25 -7
- data/bundler/lib/bundler/build_metadata.rb +4 -12
- data/bundler/lib/bundler/cli.rb +56 -20
- data/bundler/lib/bundler/cli/add.rb +1 -1
- data/bundler/lib/bundler/cli/binstubs.rb +6 -2
- data/bundler/lib/bundler/cli/cache.rb +1 -7
- data/bundler/lib/bundler/cli/clean.rb +1 -1
- data/bundler/lib/bundler/cli/common.rb +14 -0
- data/bundler/lib/bundler/cli/console.rb +1 -1
- data/bundler/lib/bundler/cli/doctor.rb +1 -1
- data/bundler/lib/bundler/cli/exec.rb +7 -16
- data/bundler/lib/bundler/cli/fund.rb +36 -0
- data/bundler/lib/bundler/cli/gem.rb +75 -11
- data/bundler/lib/bundler/cli/info.rb +8 -4
- data/bundler/lib/bundler/cli/init.rb +2 -2
- data/bundler/lib/bundler/cli/inject.rb +1 -1
- data/bundler/lib/bundler/cli/install.rb +12 -18
- data/bundler/lib/bundler/cli/issue.rb +2 -2
- data/bundler/lib/bundler/cli/list.rb +1 -1
- data/bundler/lib/bundler/cli/outdated.rb +2 -4
- data/bundler/lib/bundler/cli/plugin.rb +10 -0
- data/bundler/lib/bundler/cli/pristine.rb +1 -1
- data/bundler/lib/bundler/cli/show.rb +1 -1
- data/bundler/lib/bundler/cli/update.rb +2 -0
- data/bundler/lib/bundler/compact_index_client.rb +1 -1
- data/bundler/lib/bundler/compact_index_client/cache.rb +1 -1
- data/bundler/lib/bundler/compact_index_client/updater.rb +5 -5
- data/bundler/lib/bundler/definition.rb +47 -61
- data/bundler/lib/bundler/dep_proxy.rb +1 -1
- data/bundler/lib/bundler/dependency.rb +0 -9
- data/bundler/lib/bundler/dsl.rb +5 -9
- data/bundler/lib/bundler/endpoint_specification.rb +1 -1
- data/bundler/lib/bundler/env.rb +1 -1
- 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 -3
- data/bundler/lib/bundler/fetcher.rb +4 -3
- data/bundler/lib/bundler/fetcher/base.rb +1 -1
- data/bundler/lib/bundler/fetcher/compact_index.rb +1 -1
- data/bundler/lib/bundler/fetcher/downloader.rb +1 -1
- data/bundler/lib/bundler/fetcher/index.rb +3 -4
- data/bundler/lib/bundler/friendly_errors.rb +22 -13
- data/bundler/lib/bundler/gem_helper.rb +33 -19
- data/bundler/lib/bundler/gem_helpers.rb +6 -1
- data/bundler/lib/bundler/gem_version_promoter.rb +2 -2
- data/bundler/lib/bundler/graph.rb +1 -1
- data/bundler/lib/bundler/index.rb +6 -2
- data/bundler/lib/bundler/injector.rb +22 -4
- data/bundler/lib/bundler/inline.rb +2 -2
- data/bundler/lib/bundler/installer.rb +35 -32
- data/bundler/lib/bundler/installer/gem_installer.rb +3 -3
- data/bundler/lib/bundler/installer/parallel_installer.rb +10 -10
- data/bundler/lib/bundler/installer/standalone.rb +2 -2
- data/bundler/lib/bundler/lazy_specification.rb +20 -9
- data/bundler/lib/bundler/lockfile_generator.rb +1 -1
- data/bundler/lib/bundler/lockfile_parser.rb +1 -1
- data/bundler/lib/bundler/man/.document +1 -0
- data/bundler/{man/bundle-add.ronn → lib/bundler/man/bundle-add.1.ronn} +0 -0
- data/bundler/{man/bundle-binstubs.ronn → lib/bundler/man/bundle-binstubs.1.ronn} +2 -4
- data/bundler/{man/bundle-cache.ronn → lib/bundler/man/bundle-cache.1.ronn} +0 -0
- data/bundler/{man/bundle-check.ronn → lib/bundler/man/bundle-check.1.ronn} +0 -0
- data/bundler/{man/bundle-clean.ronn → lib/bundler/man/bundle-clean.1.ronn} +0 -0
- data/bundler/{man/bundle-config.ronn → lib/bundler/man/bundle-config.1.ronn} +19 -30
- data/bundler/{man/bundle-doctor.ronn → lib/bundler/man/bundle-doctor.1.ronn} +0 -0
- data/bundler/{man/bundle-exec.ronn → lib/bundler/man/bundle-exec.1.ronn} +0 -0
- data/bundler/{man/bundle-gem.ronn → lib/bundler/man/bundle-gem.1.ronn} +30 -7
- data/bundler/{man/bundle-info.ronn → lib/bundler/man/bundle-info.1.ronn} +0 -0
- data/bundler/{man/bundle-init.ronn → lib/bundler/man/bundle-init.1.ronn} +0 -0
- data/bundler/{man/bundle-inject.ronn → lib/bundler/man/bundle-inject.1.ronn} +0 -0
- data/bundler/{man/bundle-install.ronn → lib/bundler/man/bundle-install.1.ronn} +25 -3
- data/bundler/{man/bundle-list.ronn → lib/bundler/man/bundle-list.1.ronn} +0 -0
- data/bundler/{man/bundle-lock.ronn → lib/bundler/man/bundle-lock.1.ronn} +0 -0
- data/bundler/{man/bundle-open.ronn → lib/bundler/man/bundle-open.1.ronn} +0 -0
- data/bundler/{man/bundle-outdated.ronn → lib/bundler/man/bundle-outdated.1.ronn} +0 -0
- data/bundler/{man/bundle-platform.ronn → lib/bundler/man/bundle-platform.1.ronn} +0 -0
- data/bundler/{man/bundle-pristine.ronn → lib/bundler/man/bundle-pristine.1.ronn} +0 -0
- data/bundler/{man/bundle-remove.ronn → lib/bundler/man/bundle-remove.1.ronn} +0 -0
- data/bundler/{man/bundle-show.ronn → lib/bundler/man/bundle-show.1.ronn} +0 -0
- data/bundler/{man/bundle-update.ronn → lib/bundler/man/bundle-update.1.ronn} +0 -0
- data/bundler/{man/bundle-viz.ronn → lib/bundler/man/bundle-viz.1.ronn} +0 -0
- data/bundler/{man/bundle.ronn → lib/bundler/man/bundle.1.ronn} +0 -0
- data/bundler/{man → lib/bundler/man}/gemfile.5.ronn +4 -4
- data/bundler/lib/bundler/mirror.rb +2 -2
- data/bundler/lib/bundler/plugin.rb +30 -5
- data/bundler/lib/bundler/plugin/api/source.rb +1 -1
- data/bundler/lib/bundler/plugin/dsl.rb +1 -1
- data/bundler/lib/bundler/plugin/index.rb +10 -1
- data/bundler/lib/bundler/plugin/installer.rb +1 -1
- data/bundler/lib/bundler/plugin/installer/rubygems.rb +1 -1
- data/bundler/lib/bundler/plugin/source_list.rb +1 -1
- data/bundler/lib/bundler/psyched_yaml.rb +0 -15
- data/bundler/lib/bundler/remote_specification.rb +5 -2
- data/bundler/lib/bundler/resolver.rb +32 -10
- data/bundler/lib/bundler/resolver/spec_group.rb +27 -6
- data/bundler/lib/bundler/retry.rb +1 -1
- data/bundler/lib/bundler/ruby_version.rb +1 -1
- data/bundler/lib/bundler/rubygems_ext.rb +53 -9
- data/bundler/lib/bundler/rubygems_gem_installer.rb +3 -9
- data/bundler/lib/bundler/rubygems_integration.rb +35 -25
- data/bundler/lib/bundler/runtime.rb +4 -14
- data/bundler/lib/bundler/settings.rb +49 -46
- data/bundler/lib/bundler/setup.rb +5 -0
- data/bundler/lib/bundler/shared_helpers.rb +2 -2
- data/bundler/lib/bundler/similarity_detector.rb +1 -1
- data/bundler/lib/bundler/source.rb +1 -1
- data/bundler/lib/bundler/source/git.rb +1 -1
- data/bundler/lib/bundler/source/git/git_proxy.rb +57 -60
- data/bundler/lib/bundler/source/path.rb +7 -3
- data/bundler/lib/bundler/source/path/installer.rb +8 -10
- data/bundler/lib/bundler/source/rubygems.rb +13 -16
- data/bundler/lib/bundler/source/rubygems/remote.rb +1 -1
- data/bundler/lib/bundler/source_list.rb +2 -2
- data/bundler/lib/bundler/spec_set.rb +2 -1
- data/bundler/lib/bundler/stub_specification.rb +17 -5
- data/bundler/lib/bundler/templates/newgem/CODE_OF_CONDUCT.md.tt +57 -47
- data/bundler/lib/bundler/templates/newgem/Gemfile.tt +7 -2
- data/bundler/lib/bundler/templates/newgem/README.md.tt +1 -2
- data/bundler/lib/bundler/templates/newgem/Rakefile.tt +12 -5
- data/bundler/lib/bundler/templates/newgem/bin/console.tt +1 -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 +4 -2
- data/bundler/lib/bundler/templates/newgem/lib/newgem/version.rb.tt +2 -0
- data/bundler/lib/bundler/templates/newgem/newgem.gemspec.tt +13 -5
- 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 -1
- 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/ui/shell.rb +5 -5
- data/bundler/lib/bundler/uri_credentials_filter.rb +3 -1
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo.rb +0 -1
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph.rb +34 -1
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/tag.rb +2 -2
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/errors.rb +1 -1
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/gem_metadata.rb +1 -1
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/resolution.rb +38 -40
- data/bundler/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent.rb +72 -208
- 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/vendor/tmpdir/lib/tmpdir.rb +154 -0
- data/bundler/lib/bundler/vendored_persistent.rb +0 -7
- data/bundler/lib/bundler/vendored_tmpdir.rb +4 -0
- data/bundler/lib/bundler/version.rb +1 -1
- data/bundler/lib/bundler/worker.rb +1 -1
- data/bundler/lib/bundler/yaml_serializer.rb +1 -1
- data/bundler/man/bundle-add.1 +1 -1
- data/bundler/man/bundle-binstubs.1 +5 -3
- data/bundler/man/bundle-cache.1 +1 -1
- data/bundler/man/bundle-check.1 +1 -1
- data/bundler/man/bundle-clean.1 +1 -1
- data/bundler/man/bundle-config.1 +16 -25
- data/bundler/man/bundle-doctor.1 +1 -1
- data/bundler/man/bundle-exec.1 +1 -1
- data/bundler/man/bundle-gem.1 +25 -3
- data/bundler/man/bundle-info.1 +1 -1
- data/bundler/man/bundle-init.1 +1 -1
- data/bundler/man/bundle-inject.1 +1 -1
- data/bundler/man/bundle-install.1 +30 -3
- data/bundler/man/bundle-list.1 +1 -1
- data/bundler/man/bundle-lock.1 +1 -1
- data/bundler/man/bundle-open.1 +1 -1
- data/bundler/man/bundle-outdated.1 +1 -1
- data/bundler/man/bundle-platform.1 +1 -1
- data/bundler/man/bundle-pristine.1 +1 -1
- data/bundler/man/bundle-remove.1 +1 -1
- data/bundler/man/bundle-show.1 +1 -1
- data/bundler/man/bundle-update.1 +1 -1
- data/bundler/man/bundle-viz.1 +1 -1
- data/bundler/man/bundle.1 +1 -1
- data/bundler/man/gemfile.5 +4 -4
- data/lib/rubygems.rb +138 -187
- data/lib/rubygems/available_set.rb +4 -6
- data/lib/rubygems/basic_specification.rb +12 -10
- data/lib/rubygems/bundler_version_finder.rb +14 -9
- data/lib/rubygems/command.rb +17 -17
- data/lib/rubygems/command_manager.rb +5 -6
- data/lib/rubygems/commands/build_command.rb +40 -20
- data/lib/rubygems/commands/cert_command.rb +2 -10
- data/lib/rubygems/commands/check_command.rb +0 -2
- data/lib/rubygems/commands/cleanup_command.rb +11 -7
- data/lib/rubygems/commands/contents_command.rb +4 -6
- data/lib/rubygems/commands/dependency_command.rb +6 -8
- data/lib/rubygems/commands/environment_command.rb +1 -3
- data/lib/rubygems/commands/fetch_command.rb +2 -4
- data/lib/rubygems/commands/generate_index_command.rb +0 -2
- data/lib/rubygems/commands/help_command.rb +4 -4
- data/lib/rubygems/commands/info_command.rb +8 -5
- data/lib/rubygems/commands/install_command.rb +3 -5
- data/lib/rubygems/commands/list_command.rb +8 -7
- data/lib/rubygems/commands/lock_command.rb +1 -3
- data/lib/rubygems/commands/mirror_command.rb +0 -2
- data/lib/rubygems/commands/open_command.rb +0 -4
- data/lib/rubygems/commands/outdated_command.rb +0 -2
- data/lib/rubygems/commands/owner_command.rb +9 -3
- data/lib/rubygems/commands/pristine_command.rb +11 -5
- data/lib/rubygems/commands/push_command.rb +10 -46
- data/lib/rubygems/commands/query_command.rb +14 -344
- data/lib/rubygems/commands/rdoc_command.rb +0 -2
- data/lib/rubygems/commands/search_command.rb +7 -7
- data/lib/rubygems/commands/server_command.rb +3 -1
- data/lib/rubygems/commands/setup_command.rb +158 -70
- data/lib/rubygems/commands/signin_command.rb +0 -2
- data/lib/rubygems/commands/signout_command.rb +0 -2
- data/lib/rubygems/commands/sources_command.rb +9 -7
- data/lib/rubygems/commands/specification_command.rb +8 -4
- data/lib/rubygems/commands/stale_command.rb +1 -3
- data/lib/rubygems/commands/uninstall_command.rb +2 -4
- data/lib/rubygems/commands/unpack_command.rb +1 -3
- data/lib/rubygems/commands/update_command.rb +59 -14
- data/lib/rubygems/commands/which_command.rb +0 -2
- data/lib/rubygems/commands/yank_command.rb +4 -6
- data/lib/rubygems/config_file.rb +11 -4
- data/lib/rubygems/core_ext/kernel_require.rb +29 -36
- data/lib/rubygems/core_ext/kernel_warn.rb +12 -13
- data/lib/rubygems/defaults.rb +101 -7
- data/lib/rubygems/dependency.rb +3 -8
- data/lib/rubygems/dependency_installer.rb +5 -78
- data/lib/rubygems/dependency_list.rb +7 -9
- data/lib/rubygems/deprecate.rb +46 -1
- data/lib/rubygems/doctor.rb +4 -4
- data/lib/rubygems/errors.rb +3 -14
- data/lib/rubygems/exceptions.rb +2 -33
- data/lib/rubygems/ext.rb +6 -6
- data/lib/rubygems/ext/build_error.rb +2 -0
- data/lib/rubygems/ext/builder.rb +16 -35
- data/lib/rubygems/ext/cmake_builder.rb +5 -7
- data/lib/rubygems/ext/configure_builder.rb +4 -6
- data/lib/rubygems/ext/ext_conf_builder.rb +21 -19
- data/lib/rubygems/ext/rake_builder.rb +3 -5
- data/lib/rubygems/gem_runner.rb +3 -10
- data/lib/rubygems/gemcutter_utilities.rb +91 -15
- data/lib/rubygems/indexer.rb +1 -22
- data/lib/rubygems/install_update_options.rb +7 -7
- data/lib/rubygems/installer.rb +59 -57
- data/lib/rubygems/installer_test_case.rb +25 -11
- data/lib/rubygems/installer_uninstaller_utils.rb +24 -0
- data/lib/rubygems/local_remote_options.rb +1 -1
- data/lib/rubygems/mock_gem_ui.rb +0 -6
- data/lib/rubygems/name_tuple.rb +3 -7
- data/lib/rubygems/openssl.rb +7 -0
- data/lib/rubygems/package.rb +14 -25
- data/lib/rubygems/package/digest_io.rb +0 -2
- data/lib/rubygems/package/file_source.rb +0 -2
- data/lib/rubygems/package/io_source.rb +0 -2
- data/lib/rubygems/package/old.rb +1 -3
- data/lib/rubygems/package/tar_header.rb +4 -6
- data/lib/rubygems/package/tar_reader.rb +0 -3
- data/lib/rubygems/package/tar_reader/entry.rb +0 -3
- data/lib/rubygems/package/tar_test_case.rb +2 -4
- data/lib/rubygems/package/tar_writer.rb +2 -12
- data/lib/rubygems/package_task.rb +1 -7
- data/lib/rubygems/path_support.rb +1 -3
- data/lib/rubygems/platform.rb +21 -12
- data/lib/rubygems/psych_tree.rb +0 -2
- data/lib/rubygems/query_utils.rb +353 -0
- data/lib/rubygems/rdoc.rb +0 -12
- data/lib/rubygems/remote_fetcher.rb +10 -27
- data/lib/rubygems/request.rb +4 -11
- data/lib/rubygems/request/connection_pools.rb +1 -5
- data/lib/rubygems/request/http_pool.rb +0 -2
- data/lib/rubygems/request/https_pool.rb +0 -2
- data/lib/rubygems/request_set.rb +5 -7
- data/lib/rubygems/request_set/gem_dependency_api.rb +6 -8
- data/lib/rubygems/request_set/lockfile.rb +8 -12
- data/lib/rubygems/request_set/lockfile/parser.rb +0 -2
- data/lib/rubygems/request_set/lockfile/tokenizer.rb +1 -3
- data/lib/rubygems/requirement.rb +20 -21
- data/lib/rubygems/resolver.rb +8 -11
- data/lib/rubygems/resolver/activation_request.rb +9 -3
- data/lib/rubygems/resolver/api_set.rb +4 -6
- data/lib/rubygems/resolver/api_specification.rb +21 -8
- data/lib/rubygems/resolver/best_set.rb +0 -2
- data/lib/rubygems/resolver/composed_set.rb +3 -5
- data/lib/rubygems/resolver/conflict.rb +2 -4
- data/lib/rubygems/resolver/current_set.rb +0 -2
- data/lib/rubygems/resolver/dependency_request.rb +1 -3
- data/lib/rubygems/resolver/git_set.rb +0 -2
- data/lib/rubygems/resolver/git_specification.rb +0 -2
- data/lib/rubygems/resolver/index_set.rb +1 -3
- data/lib/rubygems/resolver/index_specification.rb +11 -2
- data/lib/rubygems/resolver/installed_specification.rb +0 -2
- data/lib/rubygems/resolver/installer_set.rb +4 -7
- data/lib/rubygems/resolver/local_specification.rb +0 -2
- data/lib/rubygems/resolver/lock_set.rb +2 -4
- data/lib/rubygems/resolver/lock_specification.rb +0 -2
- data/lib/rubygems/resolver/molinillo/lib/molinillo.rb +6 -5
- data/lib/rubygems/resolver/molinillo/lib/molinillo/delegates/resolution_state.rb +7 -0
- data/lib/rubygems/resolver/molinillo/lib/molinillo/delegates/specification_provider.rb +1 -0
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph.rb +39 -5
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/action.rb +1 -0
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb +2 -1
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/add_vertex.rb +2 -1
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/delete_edge.rb +2 -1
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb +2 -1
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/log.rb +7 -6
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/set_payload.rb +2 -1
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/tag.rb +4 -3
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/vertex.rb +43 -10
- data/lib/rubygems/resolver/molinillo/lib/molinillo/errors.rb +75 -7
- data/lib/rubygems/resolver/molinillo/lib/molinillo/gem_metadata.rb +2 -1
- data/lib/rubygems/resolver/molinillo/lib/molinillo/modules/specification_provider.rb +1 -0
- data/lib/rubygems/resolver/molinillo/lib/molinillo/modules/ui.rb +3 -1
- data/lib/rubygems/resolver/molinillo/lib/molinillo/resolution.rb +506 -165
- data/lib/rubygems/resolver/molinillo/lib/molinillo/resolver.rb +3 -2
- data/lib/rubygems/resolver/molinillo/lib/molinillo/state.rb +8 -4
- data/lib/rubygems/resolver/requirement_list.rb +0 -2
- data/lib/rubygems/resolver/set.rb +0 -2
- data/lib/rubygems/resolver/source_set.rb +0 -2
- data/lib/rubygems/resolver/spec_specification.rb +0 -2
- data/lib/rubygems/resolver/specification.rb +1 -3
- data/lib/rubygems/resolver/stats.rb +0 -2
- data/lib/rubygems/resolver/vendor_set.rb +0 -2
- data/lib/rubygems/resolver/vendor_specification.rb +0 -2
- data/lib/rubygems/s3_uri_signer.rb +2 -8
- data/lib/rubygems/safe_yaml.rb +4 -4
- data/lib/rubygems/security.rb +27 -34
- data/lib/rubygems/security/policy.rb +4 -8
- data/lib/rubygems/security/signer.rb +5 -7
- data/lib/rubygems/security/trust_dir.rb +1 -3
- data/lib/rubygems/server.rb +10 -12
- data/lib/rubygems/source.rb +13 -7
- data/lib/rubygems/source/git.rb +7 -8
- data/lib/rubygems/source/installed.rb +0 -2
- data/lib/rubygems/source/local.rb +2 -4
- data/lib/rubygems/source/lock.rb +0 -2
- data/lib/rubygems/source/specific_file.rb +0 -2
- data/lib/rubygems/source/vendor.rb +0 -2
- data/lib/rubygems/source_list.rb +6 -7
- data/lib/rubygems/spec_fetcher.rb +19 -18
- data/lib/rubygems/specification.rb +113 -126
- data/lib/rubygems/specification_policy.rb +88 -30
- data/lib/rubygems/ssl_certs/{index.rubygems.org → rubygems.org}/GlobalSignRootCA.pem +0 -0
- data/lib/rubygems/ssl_certs/rubygems.org/GlobalSignRootCA_R3.pem +21 -0
- data/lib/rubygems/stub_specification.rb +1 -5
- data/lib/rubygems/syck_hack.rb +0 -2
- data/lib/rubygems/test_case.rb +135 -118
- data/lib/rubygems/test_utilities.rb +6 -14
- data/lib/rubygems/uninstaller.rb +35 -16
- data/lib/rubygems/uri_formatter.rb +2 -3
- data/lib/rubygems/uri_parser.rb +0 -2
- data/lib/rubygems/user_interaction.rb +1 -26
- data/lib/rubygems/util.rb +15 -3
- data/lib/rubygems/util/licenses.rb +4 -6
- data/lib/rubygems/util/list.rb +0 -2
- data/lib/rubygems/validator.rb +1 -3
- data/lib/rubygems/version.rb +5 -7
- data/lib/rubygems/version_option.rb +6 -0
- data/rubygems-update.gemspec +2 -2
- data/setup.rb +2 -7
- data/test/rubygems/plugin/load/rubygems_plugin.rb +0 -2
- data/test/rubygems/rubygems/commands/crash_command.rb +0 -2
- data/test/rubygems/rubygems_plugin.rb +0 -2
- data/test/rubygems/specifications/bar-0.0.2.gemspec +0 -2
- data/test/rubygems/specifications/rubyforge-0.0.1.gemspec +12 -0
- data/test/rubygems/test_bundled_ca.rb +42 -45
- data/test/rubygems/test_config.rb +0 -2
- data/test/rubygems/test_deprecate.rb +40 -7
- data/test/rubygems/test_gem.rb +153 -106
- data/test/rubygems/test_gem_available_set.rb +3 -5
- data/test/rubygems/test_gem_bundler_version_finder.rb +19 -3
- data/test/rubygems/test_gem_command.rb +24 -7
- data/test/rubygems/test_gem_command_manager.rb +36 -5
- data/test/rubygems/test_gem_commands_build_command.rb +250 -15
- data/test/rubygems/test_gem_commands_cert_command.rb +4 -6
- data/test/rubygems/test_gem_commands_check_command.rb +0 -2
- data/test/rubygems/test_gem_commands_cleanup_command.rb +14 -5
- data/test/rubygems/test_gem_commands_contents_command.rb +50 -19
- data/test/rubygems/test_gem_commands_dependency_command.rb +0 -2
- data/test/rubygems/test_gem_commands_environment_command.rb +21 -23
- data/test/rubygems/test_gem_commands_fetch_command.rb +0 -2
- data/test/rubygems/test_gem_commands_generate_index_command.rb +1 -7
- data/test/rubygems/test_gem_commands_help_command.rb +15 -4
- data/test/rubygems/test_gem_commands_info_command.rb +6 -8
- data/test/rubygems/test_gem_commands_install_command.rb +32 -34
- data/test/rubygems/test_gem_commands_list_command.rb +0 -2
- data/test/rubygems/test_gem_commands_lock_command.rb +0 -2
- data/test/rubygems/test_gem_commands_mirror.rb +1 -3
- data/test/rubygems/test_gem_commands_open_command.rb +4 -6
- data/test/rubygems/test_gem_commands_outdated_command.rb +0 -2
- data/test/rubygems/test_gem_commands_owner_command.rb +59 -5
- data/test/rubygems/test_gem_commands_pristine_command.rb +43 -12
- data/test/rubygems/test_gem_commands_push_command.rb +38 -9
- data/test/rubygems/test_gem_commands_query_command.rb +12 -12
- data/test/rubygems/test_gem_commands_search_command.rb +0 -2
- data/test/rubygems/test_gem_commands_server_command.rb +0 -2
- data/test/rubygems/test_gem_commands_setup_command.rb +211 -124
- data/test/rubygems/test_gem_commands_signin_command.rb +33 -9
- data/test/rubygems/test_gem_commands_signout_command.rb +0 -7
- data/test/rubygems/test_gem_commands_sources_command.rb +99 -3
- data/test/rubygems/test_gem_commands_specification_command.rb +46 -20
- data/test/rubygems/test_gem_commands_stale_command.rb +0 -2
- data/test/rubygems/test_gem_commands_uninstall_command.rb +2 -3
- data/test/rubygems/test_gem_commands_unpack_command.rb +0 -2
- data/test/rubygems/test_gem_commands_update_command.rb +116 -7
- data/test/rubygems/test_gem_commands_which_command.rb +3 -5
- data/test/rubygems/test_gem_commands_yank_command.rb +44 -8
- data/test/rubygems/test_gem_config_file.rb +7 -12
- data/test/rubygems/test_gem_dependency.rb +0 -2
- data/test/rubygems/test_gem_dependency_installer.rb +90 -193
- data/test/rubygems/test_gem_dependency_list.rb +10 -12
- data/test/rubygems/test_gem_dependency_resolution_error.rb +1 -3
- data/test/rubygems/test_gem_doctor.rb +28 -2
- data/test/rubygems/test_gem_ext_builder.rb +26 -47
- data/test/rubygems/test_gem_ext_cmake_builder.rb +16 -23
- data/test/rubygems/test_gem_ext_configure_builder.rb +4 -20
- data/test/rubygems/test_gem_ext_ext_conf_builder.rb +9 -29
- data/test/rubygems/test_gem_ext_rake_builder.rb +14 -24
- data/test/rubygems/test_gem_gem_runner.rb +44 -1
- data/test/rubygems/test_gem_gemcutter_utilities.rb +8 -5
- data/test/rubygems/test_gem_impossible_dependencies_error.rb +0 -2
- data/test/rubygems/test_gem_indexer.rb +9 -15
- data/test/rubygems/test_gem_install_update_options.rb +14 -4
- data/test/rubygems/test_gem_installer.rb +265 -81
- data/test/rubygems/test_gem_local_remote_options.rb +0 -2
- data/test/rubygems/test_gem_name_tuple.rb +0 -2
- data/test/rubygems/test_gem_package.rb +41 -39
- data/test/rubygems/test_gem_package_old.rb +4 -6
- data/test/rubygems/test_gem_package_tar_header.rb +18 -1
- data/test/rubygems/test_gem_package_tar_reader.rb +0 -2
- data/test/rubygems/test_gem_package_tar_reader_entry.rb +0 -2
- data/test/rubygems/test_gem_package_tar_writer.rb +9 -6
- data/test/rubygems/test_gem_package_task.rb +46 -13
- data/test/rubygems/test_gem_path_support.rb +0 -2
- data/test/rubygems/test_gem_platform.rb +63 -6
- data/test/rubygems/test_gem_rdoc.rb +0 -2
- data/test/rubygems/test_gem_remote_fetcher.rb +168 -211
- data/test/rubygems/test_gem_request.rb +13 -17
- data/test/rubygems/test_gem_request_connection_pools.rb +0 -4
- data/test/rubygems/test_gem_request_set.rb +72 -22
- data/test/rubygems/test_gem_request_set_gem_dependency_api.rb +3 -5
- data/test/rubygems/test_gem_request_set_lockfile.rb +4 -6
- data/test/rubygems/test_gem_request_set_lockfile_parser.rb +9 -11
- data/test/rubygems/test_gem_request_set_lockfile_tokenizer.rb +118 -120
- data/test/rubygems/test_gem_requirement.rb +10 -4
- data/test/rubygems/test_gem_resolver.rb +6 -8
- data/test/rubygems/test_gem_resolver_activation_request.rb +0 -2
- data/test/rubygems/test_gem_resolver_api_set.rb +11 -13
- data/test/rubygems/test_gem_resolver_api_specification.rb +0 -2
- data/test/rubygems/test_gem_resolver_best_set.rb +2 -4
- data/test/rubygems/test_gem_resolver_composed_set.rb +0 -2
- data/test/rubygems/test_gem_resolver_conflict.rb +1 -3
- data/test/rubygems/test_gem_resolver_dependency_request.rb +0 -2
- data/test/rubygems/test_gem_resolver_git_set.rb +0 -2
- data/test/rubygems/test_gem_resolver_git_specification.rb +0 -2
- data/test/rubygems/test_gem_resolver_index_set.rb +2 -4
- data/test/rubygems/test_gem_resolver_index_specification.rb +0 -2
- data/test/rubygems/test_gem_resolver_installed_specification.rb +0 -2
- data/test/rubygems/test_gem_resolver_installer_set.rb +7 -9
- data/test/rubygems/test_gem_resolver_local_specification.rb +0 -2
- data/test/rubygems/test_gem_resolver_lock_set.rb +3 -5
- data/test/rubygems/test_gem_resolver_lock_specification.rb +0 -2
- data/test/rubygems/test_gem_resolver_requirement_list.rb +0 -2
- data/test/rubygems/test_gem_resolver_specification.rb +0 -4
- data/test/rubygems/test_gem_resolver_vendor_set.rb +1 -3
- data/test/rubygems/test_gem_resolver_vendor_specification.rb +0 -2
- data/test/rubygems/test_gem_security.rb +22 -24
- data/test/rubygems/test_gem_security_policy.rb +7 -12
- data/test/rubygems/test_gem_security_signer.rb +10 -12
- data/test/rubygems/test_gem_security_trust_dir.rb +4 -6
- data/test/rubygems/test_gem_server.rb +10 -14
- data/test/rubygems/test_gem_silent_ui.rb +0 -2
- data/test/rubygems/test_gem_source.rb +17 -16
- data/test/rubygems/test_gem_source_fetch_problem.rb +0 -2
- data/test/rubygems/test_gem_source_git.rb +12 -13
- data/test/rubygems/test_gem_source_installed.rb +7 -9
- data/test/rubygems/test_gem_source_list.rb +1 -2
- data/test/rubygems/test_gem_source_local.rb +8 -10
- data/test/rubygems/test_gem_source_lock.rb +10 -12
- data/test/rubygems/test_gem_source_specific_file.rb +7 -9
- data/test/rubygems/test_gem_source_subpath_problem.rb +49 -0
- data/test/rubygems/test_gem_source_vendor.rb +7 -9
- data/test/rubygems/test_gem_spec_fetcher.rb +11 -4
- data/test/rubygems/test_gem_specification.rb +182 -131
- data/test/rubygems/test_gem_stream_ui.rb +3 -3
- data/test/rubygems/test_gem_stub_specification.rb +4 -7
- data/test/rubygems/test_gem_text.rb +1 -3
- data/test/rubygems/test_gem_uninstaller.rb +134 -12
- data/test/rubygems/test_gem_unsatisfiable_dependency_error.rb +0 -2
- data/test/rubygems/test_gem_uri_formatter.rb +0 -2
- data/test/rubygems/test_gem_util.rb +7 -7
- data/test/rubygems/test_gem_validator.rb +1 -3
- data/test/rubygems/test_gem_version.rb +1 -3
- data/test/rubygems/test_gem_version_option.rb +1 -3
- data/test/rubygems/test_kernel.rb +25 -10
- data/test/rubygems/test_project_sanity.rb +7 -2
- data/test/rubygems/test_remote_fetch_error.rb +0 -2
- data/test/rubygems/test_require.rb +291 -56
- metadata +66 -100
- 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/bundler/lib/bundler/vendor/molinillo/lib/molinillo/compatibility.rb +0 -26
- data/bundler/man/bundle-add.1.txt +0 -58
- data/bundler/man/bundle-binstubs.1.txt +0 -48
- data/bundler/man/bundle-cache.1.txt +0 -78
- data/bundler/man/bundle-check.1.txt +0 -33
- data/bundler/man/bundle-clean.1.txt +0 -26
- data/bundler/man/bundle-config.1.txt +0 -528
- data/bundler/man/bundle-doctor.1.txt +0 -44
- data/bundler/man/bundle-exec.1.txt +0 -178
- data/bundler/man/bundle-gem.1.txt +0 -91
- data/bundler/man/bundle-info.1.txt +0 -21
- data/bundler/man/bundle-init.1.txt +0 -34
- data/bundler/man/bundle-inject.1.txt +0 -32
- data/bundler/man/bundle-install.1.txt +0 -401
- data/bundler/man/bundle-list.1.txt +0 -44
- data/bundler/man/bundle-lock.1.txt +0 -93
- data/bundler/man/bundle-open.1.txt +0 -29
- data/bundler/man/bundle-outdated.1.txt +0 -131
- data/bundler/man/bundle-platform.1.txt +0 -57
- data/bundler/man/bundle-pristine.1.txt +0 -44
- data/bundler/man/bundle-remove.1.txt +0 -34
- data/bundler/man/bundle-show.1.txt +0 -27
- data/bundler/man/bundle-update.1.txt +0 -390
- data/bundler/man/bundle-viz.1.txt +0 -39
- data/bundler/man/bundle.1.txt +0 -116
- data/bundler/man/gemfile.5.txt +0 -649
- data/lib/rubygems/source_local.rb +0 -7
- data/lib/rubygems/source_specific_file.rb +0 -6
- data/lib/rubygems/ssl_certs/rubygems.global.ssl.fastly.net/DigiCertHighAssuranceEVRootCA.pem +0 -23
- data/lib/rubygems/ssl_certs/rubygems.org/AddTrustExternalCARoot.pem +0 -25
- 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 -139
- data/util/update_changelog.rb +0 -67
@@ -5,7 +5,6 @@
|
|
5
5
|
require "rubygems/user_interaction"
|
6
6
|
|
7
7
|
class Gem::Security::Signer
|
8
|
-
|
9
8
|
include Gem::UserInteraction
|
10
9
|
|
11
10
|
##
|
@@ -35,11 +34,11 @@ class Gem::Security::Signer
|
|
35
34
|
attr_reader :options
|
36
35
|
|
37
36
|
DEFAULT_OPTIONS = {
|
38
|
-
expiration_length_days: 365
|
37
|
+
expiration_length_days: 365,
|
39
38
|
}.freeze
|
40
39
|
|
41
40
|
##
|
42
|
-
#
|
41
|
+
# Attempts to re-sign an expired cert with a given private key
|
43
42
|
def self.re_sign_cert(expired_cert, expired_cert_path, private_key)
|
44
43
|
return unless expired_cert.not_after < Time.now
|
45
44
|
|
@@ -81,8 +80,8 @@ class Gem::Security::Signer
|
|
81
80
|
@cert_chain = [default_cert] if File.exist? default_cert
|
82
81
|
end
|
83
82
|
|
84
|
-
@digest_algorithm = Gem::Security::DIGEST_ALGORITHM
|
85
83
|
@digest_name = Gem::Security::DIGEST_NAME
|
84
|
+
@digest_algorithm = Gem::Security.create_digest(@digest_name)
|
86
85
|
|
87
86
|
if @key && !@key.is_a?(OpenSSL::PKey::RSA)
|
88
87
|
@key = OpenSSL::PKey::RSA.new(File.read(@key), @passphrase)
|
@@ -106,10 +105,10 @@ class Gem::Security::Signer
|
|
106
105
|
# this value is preferred, otherwise the subject is used.
|
107
106
|
|
108
107
|
def extract_name(cert) # :nodoc:
|
109
|
-
subject_alt_name = cert.extensions.find {
|
108
|
+
subject_alt_name = cert.extensions.find {|e| 'subjectAltName' == e.oid }
|
110
109
|
|
111
110
|
if subject_alt_name
|
112
|
-
/\Aemail:/ =~ subject_alt_name.value
|
111
|
+
/\Aemail:/ =~ subject_alt_name.value # rubocop:disable Performance/StartWith
|
113
112
|
|
114
113
|
$' || subject_alt_name.value
|
115
114
|
else
|
@@ -202,5 +201,4 @@ class Gem::Security::Signer
|
|
202
201
|
end
|
203
202
|
end
|
204
203
|
end
|
205
|
-
|
206
204
|
end
|
@@ -4,7 +4,6 @@
|
|
4
4
|
# verification.
|
5
5
|
|
6
6
|
class Gem::Security::TrustDir
|
7
|
-
|
8
7
|
##
|
9
8
|
# Default permissions for the trust directory and its contents
|
10
9
|
|
@@ -26,7 +25,7 @@ class Gem::Security::TrustDir
|
|
26
25
|
@dir = dir
|
27
26
|
@permissions = permissions
|
28
27
|
|
29
|
-
@digester = Gem::Security
|
28
|
+
@digester = Gem::Security.create_digest
|
30
29
|
end
|
31
30
|
|
32
31
|
##
|
@@ -115,5 +114,4 @@ class Gem::Security::TrustDir
|
|
115
114
|
FileUtils.mkdir_p @dir, :mode => @permissions[:trust_dir]
|
116
115
|
end
|
117
116
|
end
|
118
|
-
|
119
117
|
end
|
data/lib/rubygems/server.rb
CHANGED
@@ -29,7 +29,6 @@ require 'rubygems/rdoc'
|
|
29
29
|
# TODO Refactor into a real WEBrick servlet to remove code duplication.
|
30
30
|
|
31
31
|
class Gem::Server
|
32
|
-
|
33
32
|
attr_reader :spec_dirs
|
34
33
|
|
35
34
|
include ERB::Util
|
@@ -442,8 +441,8 @@ div.method-source-code pre { color: #ffdead; overflow: hidden; }
|
|
442
441
|
logger = WEBrick::Log.new nil, WEBrick::BasicLog::FATAL
|
443
442
|
@server = WEBrick::HTTPServer.new :DoNotListen => true, :Logger => logger
|
444
443
|
|
445
|
-
@spec_dirs = @gem_dirs.map {
|
446
|
-
@spec_dirs.reject! {
|
444
|
+
@spec_dirs = @gem_dirs.map {|gem_dir| File.join gem_dir, 'specifications' }
|
445
|
+
@spec_dirs.reject! {|spec_dir| !File.directory? spec_dir }
|
447
446
|
|
448
447
|
reset_gems
|
449
448
|
|
@@ -458,7 +457,7 @@ div.method-source-code pre { color: #ffdead; overflow: hidden; }
|
|
458
457
|
|
459
458
|
def uri_encode(str)
|
460
459
|
str.gsub(URI::UNSAFE) do |match|
|
461
|
-
match.each_byte.map {
|
460
|
+
match.each_byte.map {|c| sprintf('%%%02X', c.ord) }.join
|
462
461
|
end
|
463
462
|
end
|
464
463
|
|
@@ -573,7 +572,7 @@ div.method-source-code pre { color: #ffdead; overflow: hidden; }
|
|
573
572
|
add_date res
|
574
573
|
|
575
574
|
case req.request_uri.path
|
576
|
-
when %r
|
575
|
+
when %r{^/quick/(Marshal.#{Regexp.escape Gem.marshal_version}/)?(.*?)\.gemspec\.rz$} then
|
577
576
|
marshal_format, full_name = $1, $2
|
578
577
|
specs = Gem::Specification.find_all_by_full_name(full_name)
|
579
578
|
|
@@ -615,11 +614,11 @@ div.method-source-code pre { color: #ffdead; overflow: hidden; }
|
|
615
614
|
}
|
616
615
|
end
|
617
616
|
|
618
|
-
deps = deps.sort_by {
|
617
|
+
deps = deps.sort_by {|dep| [dep["name"].downcase, dep["version"]] }
|
619
618
|
deps.last["is_last"] = true unless deps.empty?
|
620
619
|
|
621
620
|
# executables
|
622
|
-
executables = spec.executables.sort.collect {
|
621
|
+
executables = spec.executables.sort.collect {|exec| {"executable" => exec} }
|
623
622
|
executables = nil if executables.empty?
|
624
623
|
executables.last["is_last"] = true if executables
|
625
624
|
|
@@ -661,14 +660,14 @@ div.method-source-code pre { color: #ffdead; overflow: hidden; }
|
|
661
660
|
"only_one_executable" => true,
|
662
661
|
"full_name" => "rubygems-#{Gem::VERSION}",
|
663
662
|
"has_deps" => false,
|
664
|
-
"homepage" => "
|
663
|
+
"homepage" => "https://guides.rubygems.org/",
|
665
664
|
"name" => 'rubygems',
|
666
665
|
"ri_installed" => true,
|
667
666
|
"summary" => "RubyGems itself",
|
668
667
|
"version" => Gem::VERSION,
|
669
668
|
}
|
670
669
|
|
671
|
-
specs = specs.sort_by {
|
670
|
+
specs = specs.sort_by {|spec| [spec["name"].downcase, spec["version"]] }
|
672
671
|
specs.last["is_last"] = true
|
673
672
|
|
674
673
|
# tag all specs with first_name_entry
|
@@ -772,7 +771,7 @@ div.method-source-code pre { color: #ffdead; overflow: hidden; }
|
|
772
771
|
doc_items << {
|
773
772
|
:name => base_name,
|
774
773
|
:url => doc_root(new_path),
|
775
|
-
:summary => ''
|
774
|
+
:summary => '',
|
776
775
|
}
|
777
776
|
end
|
778
777
|
|
@@ -869,11 +868,10 @@ div.method-source-code pre { color: #ffdead; overflow: hidden; }
|
|
869
868
|
listeners = @server.listeners.map{|l| l.addr[2] }
|
870
869
|
|
871
870
|
# TODO: 0.0.0.0 == any, not localhost.
|
872
|
-
host = listeners.any?{|l| l == '0.0.0.0'} ? 'localhost' : listeners.first
|
871
|
+
host = listeners.any?{|l| l == '0.0.0.0' } ? 'localhost' : listeners.first
|
873
872
|
|
874
873
|
say "Launching browser to http://#{host}:#{@port}"
|
875
874
|
|
876
875
|
system("#{@launch} http://#{host}:#{@port}")
|
877
876
|
end
|
878
|
-
|
879
877
|
end
|
data/lib/rubygems/source.rb
CHANGED
@@ -1,5 +1,4 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
-
autoload :FileUtils, 'fileutils'
|
3
2
|
|
4
3
|
require "rubygems/text"
|
5
4
|
##
|
@@ -9,7 +8,6 @@ require "rubygems/text"
|
|
9
8
|
# bundler dependency API and so-forth.
|
10
9
|
|
11
10
|
class Gem::Source
|
12
|
-
|
13
11
|
include Comparable
|
14
12
|
include Gem::Text
|
15
13
|
|
@@ -81,7 +79,7 @@ class Gem::Source
|
|
81
79
|
def dependency_resolver_set # :nodoc:
|
82
80
|
return Gem::Resolver::IndexSet.new self if 'file' == uri.scheme
|
83
81
|
|
84
|
-
bundler_api_uri = uri + './api/v1/dependencies'
|
82
|
+
bundler_api_uri = enforce_trailing_slash(uri) + './api/v1/dependencies'
|
85
83
|
|
86
84
|
begin
|
87
85
|
fetcher = Gem::RemoteFetcher.fetcher
|
@@ -132,7 +130,7 @@ class Gem::Source
|
|
132
130
|
|
133
131
|
spec_file_name = name_tuple.spec_name
|
134
132
|
|
135
|
-
source_uri = uri + "#{Gem::MARSHAL_SPEC_DIR}#{spec_file_name}"
|
133
|
+
source_uri = enforce_trailing_slash(uri) + "#{Gem::MARSHAL_SPEC_DIR}#{spec_file_name}"
|
136
134
|
|
137
135
|
cache_dir = cache_dir source_uri
|
138
136
|
|
@@ -176,12 +174,15 @@ class Gem::Source
|
|
176
174
|
file = FILES[type]
|
177
175
|
fetcher = Gem::RemoteFetcher.fetcher
|
178
176
|
file_name = "#{file}.#{Gem.marshal_version}"
|
179
|
-
spec_path = uri + "#{file_name}.gz"
|
177
|
+
spec_path = enforce_trailing_slash(uri) + "#{file_name}.gz"
|
180
178
|
cache_dir = cache_dir spec_path
|
181
179
|
local_file = File.join(cache_dir, file_name)
|
182
180
|
retried = false
|
183
181
|
|
184
|
-
|
182
|
+
if update_cache?
|
183
|
+
require "fileutils"
|
184
|
+
FileUtils.mkdir_p cache_dir
|
185
|
+
end
|
185
186
|
|
186
187
|
spec_dump = fetcher.cache_update_path spec_path, local_file, update_cache?
|
187
188
|
|
@@ -222,9 +223,14 @@ class Gem::Source
|
|
222
223
|
|
223
224
|
def typo_squatting?(host, distance_threshold=4)
|
224
225
|
return if @uri.host.nil?
|
225
|
-
levenshtein_distance(@uri.host, host)
|
226
|
+
levenshtein_distance(@uri.host, host).between? 1, distance_threshold
|
226
227
|
end
|
227
228
|
|
229
|
+
private
|
230
|
+
|
231
|
+
def enforce_trailing_slash(uri)
|
232
|
+
uri.merge(uri.path.gsub(/\/+$/, '') + '/')
|
233
|
+
end
|
228
234
|
end
|
229
235
|
|
230
236
|
require 'rubygems/source/git'
|
data/lib/rubygems/source/git.rb
CHANGED
@@ -1,5 +1,4 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
-
require 'rubygems/util'
|
3
2
|
|
4
3
|
##
|
5
4
|
# A git gem for use in a gem dependencies file.
|
@@ -12,7 +11,6 @@ require 'rubygems/util'
|
|
12
11
|
# source.specs
|
13
12
|
|
14
13
|
class Gem::Source::Git < Gem::Source
|
15
|
-
|
16
14
|
##
|
17
15
|
# The name of the gem created by this git gem.
|
18
16
|
|
@@ -103,9 +101,11 @@ class Gem::Source::Git < Gem::Source
|
|
103
101
|
|
104
102
|
success = system @git, 'reset', '--quiet', '--hard', rev_parse
|
105
103
|
|
106
|
-
|
107
|
-
|
108
|
-
|
104
|
+
if @need_submodules
|
105
|
+
_, status = Open3.capture2e(@git, 'submodule', 'update', '--quiet', '--init', '--recursive')
|
106
|
+
|
107
|
+
success &&= status.success?
|
108
|
+
end
|
109
109
|
|
110
110
|
success
|
111
111
|
end
|
@@ -228,8 +228,8 @@ class Gem::Source::Git < Gem::Source
|
|
228
228
|
require 'digest' # required here to avoid deadlocking in Gem.activate_bin_path (because digest is a gem on 2.5+)
|
229
229
|
|
230
230
|
normalized =
|
231
|
-
if @repository =~ %r
|
232
|
-
uri = URI(@repository).normalize.to_s.sub %r
|
231
|
+
if @repository =~ %r{^\w+://(\w+@)?}
|
232
|
+
uri = URI(@repository).normalize.to_s.sub %r{/$},''
|
233
233
|
uri.sub(/\A(\w+)/) { $1.downcase }
|
234
234
|
else
|
235
235
|
@repository
|
@@ -237,5 +237,4 @@ class Gem::Source::Git < Gem::Source
|
|
237
237
|
|
238
238
|
Digest::SHA1.hexdigest normalized
|
239
239
|
end
|
240
|
-
|
241
240
|
end
|
@@ -3,7 +3,6 @@
|
|
3
3
|
# Represents an installed gem. This is used for dependency resolution.
|
4
4
|
|
5
5
|
class Gem::Source::Installed < Gem::Source
|
6
|
-
|
7
6
|
def initialize # :nodoc:
|
8
7
|
@uri = nil
|
9
8
|
end
|
@@ -36,5 +35,4 @@ class Gem::Source::Installed < Gem::Source
|
|
36
35
|
def pretty_print(q) # :nodoc:
|
37
36
|
q.text '[Installed]'
|
38
37
|
end
|
39
|
-
|
40
38
|
end
|
@@ -4,7 +4,6 @@
|
|
4
4
|
# dependencies.
|
5
5
|
|
6
6
|
class Gem::Source::Local < Gem::Source
|
7
|
-
|
8
7
|
def initialize # :nodoc:
|
9
8
|
@specs = nil
|
10
9
|
@api_uri = nil
|
@@ -61,7 +60,7 @@ class Gem::Source::Local < Gem::Source
|
|
61
60
|
when :latest
|
62
61
|
tup = pkg.spec.name_tuple
|
63
62
|
|
64
|
-
cur = names.find {
|
63
|
+
cur = names.find {|x| x.name == tup.name }
|
65
64
|
if !cur
|
66
65
|
names << tup
|
67
66
|
elsif cur.version < tup.version
|
@@ -98,7 +97,7 @@ class Gem::Source::Local < Gem::Source
|
|
98
97
|
end
|
99
98
|
end
|
100
99
|
|
101
|
-
found.max_by {
|
100
|
+
found.max_by {|s| s.version }
|
102
101
|
end
|
103
102
|
|
104
103
|
def fetch_spec(name) # :nodoc:
|
@@ -129,5 +128,4 @@ class Gem::Source::Local < Gem::Source
|
|
129
128
|
end
|
130
129
|
end
|
131
130
|
end
|
132
|
-
|
133
131
|
end
|
data/lib/rubygems/source/lock.rb
CHANGED
@@ -3,7 +3,6 @@
|
|
3
3
|
# This represents a vendored source that is similar to an installed gem.
|
4
4
|
|
5
5
|
class Gem::Source::Vendor < Gem::Source::Installed
|
6
|
-
|
7
6
|
##
|
8
7
|
# Creates a new Vendor source for a gem that was unpacked at +path+.
|
9
8
|
|
@@ -23,5 +22,4 @@ class Gem::Source::Vendor < Gem::Source::Installed
|
|
23
22
|
nil
|
24
23
|
end
|
25
24
|
end
|
26
|
-
|
27
25
|
end
|
data/lib/rubygems/source_list.rb
CHANGED
@@ -1,5 +1,4 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
-
require 'rubygems/source'
|
3
2
|
|
4
3
|
##
|
5
4
|
# The SourceList represents the sources rubygems has been configured to use.
|
@@ -15,7 +14,6 @@ require 'rubygems/source'
|
|
15
14
|
# The most common way to get a SourceList is Gem.sources.
|
16
15
|
|
17
16
|
class Gem::SourceList
|
18
|
-
|
19
17
|
include Enumerable
|
20
18
|
|
21
19
|
##
|
@@ -50,6 +48,8 @@ class Gem::SourceList
|
|
50
48
|
# String.
|
51
49
|
|
52
50
|
def <<(obj)
|
51
|
+
require "uri"
|
52
|
+
|
53
53
|
src = case obj
|
54
54
|
when URI
|
55
55
|
Gem::Source.new(obj)
|
@@ -88,7 +88,7 @@ class Gem::SourceList
|
|
88
88
|
# Yields each source URI in the list.
|
89
89
|
|
90
90
|
def each
|
91
|
-
@sources.each {
|
91
|
+
@sources.each {|s| yield s.uri.to_s }
|
92
92
|
end
|
93
93
|
|
94
94
|
##
|
@@ -113,7 +113,7 @@ class Gem::SourceList
|
|
113
113
|
# Returns an Array of source URI Strings.
|
114
114
|
|
115
115
|
def to_a
|
116
|
-
@sources.map {
|
116
|
+
@sources.map {|x| x.uri.to_s }
|
117
117
|
end
|
118
118
|
|
119
119
|
alias_method :to_ary, :to_a
|
@@ -133,7 +133,7 @@ class Gem::SourceList
|
|
133
133
|
if other.kind_of? Gem::Source
|
134
134
|
@sources.include? other
|
135
135
|
else
|
136
|
-
@sources.find {
|
136
|
+
@sources.find {|x| x.uri.to_s == other.to_s }
|
137
137
|
end
|
138
138
|
end
|
139
139
|
|
@@ -144,8 +144,7 @@ class Gem::SourceList
|
|
144
144
|
if source.kind_of? Gem::Source
|
145
145
|
@sources.delete source
|
146
146
|
else
|
147
|
-
@sources.delete_if {
|
147
|
+
@sources.delete_if {|x| x.uri.to_s == source.to_s }
|
148
148
|
end
|
149
149
|
end
|
150
|
-
|
151
150
|
end
|
@@ -9,7 +9,6 @@ require 'rubygems/name_tuple'
|
|
9
9
|
# SpecFetcher handles metadata updates from remote gem repositories.
|
10
10
|
|
11
11
|
class Gem::SpecFetcher
|
12
|
-
|
13
12
|
include Gem::UserInteraction
|
14
13
|
include Gem::Text
|
15
14
|
|
@@ -92,14 +91,14 @@ class Gem::SpecFetcher
|
|
92
91
|
|
93
92
|
list.each do |source, specs|
|
94
93
|
if dependency.name.is_a?(String) && specs.respond_to?(:bsearch)
|
95
|
-
start_index = (0 ... specs.length).bsearch{
|
96
|
-
end_index = (0 ... specs.length).bsearch{
|
94
|
+
start_index = (0 ... specs.length).bsearch{|i| specs[i].name >= dependency.name }
|
95
|
+
end_index = (0 ... specs.length).bsearch{|i| specs[i].name > dependency.name }
|
97
96
|
specs = specs[start_index ... end_index] if start_index && end_index
|
98
97
|
end
|
99
98
|
|
100
99
|
found[source] = specs.select do |tup|
|
101
100
|
if dependency.match?(tup)
|
102
|
-
if matching_platform and !Gem::Platform.
|
101
|
+
if matching_platform and !Gem::Platform.match_gem?(tup.platform, tup.name)
|
103
102
|
pm = (
|
104
103
|
rejected_specs[dependency] ||= \
|
105
104
|
Gem::PlatformMismatch.new(tup.name, tup.version))
|
@@ -122,7 +121,7 @@ class Gem::SpecFetcher
|
|
122
121
|
end
|
123
122
|
end
|
124
123
|
|
125
|
-
tuples = tuples.sort_by {
|
124
|
+
tuples = tuples.sort_by {|x| x[0] }
|
126
125
|
|
127
126
|
return [tuples, errors]
|
128
127
|
end
|
@@ -171,30 +170,33 @@ class Gem::SpecFetcher
|
|
171
170
|
# Suggests gems based on the supplied +gem_name+. Returns an array of
|
172
171
|
# alternative gem names.
|
173
172
|
|
174
|
-
def suggest_gems_from_name(gem_name, type = :latest)
|
173
|
+
def suggest_gems_from_name(gem_name, type = :latest, num_results = 5)
|
175
174
|
gem_name = gem_name.downcase.tr('_-', '')
|
176
175
|
max = gem_name.size / 2
|
177
176
|
names = available_specs(type).first.values.flatten(1)
|
178
177
|
|
179
178
|
matches = names.map do |n|
|
180
179
|
next unless n.match_platform?
|
181
|
-
|
182
|
-
distance = levenshtein_distance gem_name, n.name.downcase.tr('_-', '')
|
183
|
-
|
184
|
-
next if distance >= max
|
185
|
-
|
186
|
-
return [n.name] if distance == 0
|
187
|
-
|
188
|
-
[n.name, distance]
|
180
|
+
[n.name, 0] if n.name.downcase.tr('_-', '').include?(gem_name)
|
189
181
|
end.compact
|
190
182
|
|
183
|
+
if matches.length < num_results
|
184
|
+
matches += names.map do |n|
|
185
|
+
next unless n.match_platform?
|
186
|
+
distance = levenshtein_distance gem_name, n.name.downcase.tr('_-', '')
|
187
|
+
next if distance >= max
|
188
|
+
return [n.name] if distance == 0
|
189
|
+
[n.name, distance]
|
190
|
+
end.compact
|
191
|
+
end
|
192
|
+
|
191
193
|
matches = if matches.empty? && type != :prerelease
|
192
194
|
suggest_gems_from_name gem_name, :prerelease
|
193
195
|
else
|
194
|
-
matches.uniq.sort_by {
|
196
|
+
matches.uniq.sort_by {|name, dist| dist }
|
195
197
|
end
|
196
198
|
|
197
|
-
matches.
|
199
|
+
matches.map {|name, dist| name }.uniq.first(num_results)
|
198
200
|
end
|
199
201
|
|
200
202
|
##
|
@@ -251,10 +253,9 @@ class Gem::SpecFetcher
|
|
251
253
|
|
252
254
|
def tuples_for(source, type, gracefully_ignore=false) # :nodoc:
|
253
255
|
@caches[type][source.uri] ||=
|
254
|
-
source.load_specs(type).sort_by {
|
256
|
+
source.load_specs(type).sort_by {|tup| tup.name }
|
255
257
|
rescue Gem::RemoteFetcher::FetchError
|
256
258
|
raise unless gracefully_ignore
|
257
259
|
[]
|
258
260
|
end
|
259
|
-
|
260
261
|
end
|