rubygems-update 2.6.14 → 2.7.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of rubygems-update might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/.travis.yml +10 -7
- data/CONTRIBUTING.rdoc +53 -54
- data/History.txt +173 -9
- data/Manifest.txt +39 -11
- data/POLICIES.rdoc +3 -3
- data/README.md +72 -0
- data/Rakefile +30 -5
- data/appveyor.yml +29 -1
- data/bin/gem +1 -1
- data/bin/update_rubygems +2 -2
- data/bundler/CHANGELOG.md +269 -9
- data/bundler/CODE_OF_CONDUCT.md +1 -1
- data/bundler/CONTRIBUTING.md +10 -29
- data/bundler/README.md +22 -10
- data/bundler/exe/bundle +5 -7
- data/bundler/exe/bundle_ruby +4 -3
- data/bundler/lib/bundler.rb +94 -74
- data/bundler/lib/bundler/build_metadata.rb +36 -0
- data/bundler/lib/bundler/capistrano.rb +5 -0
- data/bundler/lib/bundler/cli.rb +229 -66
- data/bundler/lib/bundler/cli/add.rb +25 -0
- data/bundler/lib/bundler/cli/binstubs.rb +9 -7
- data/bundler/lib/bundler/cli/cache.rb +5 -4
- data/bundler/lib/bundler/cli/check.rb +3 -5
- data/bundler/lib/bundler/cli/clean.rb +5 -6
- data/bundler/lib/bundler/cli/common.rb +18 -2
- data/bundler/lib/bundler/cli/config.rb +26 -7
- data/bundler/lib/bundler/cli/console.rb +2 -1
- data/bundler/lib/bundler/cli/doctor.rb +1 -0
- data/bundler/lib/bundler/cli/exec.rb +3 -2
- data/bundler/lib/bundler/cli/gem.rb +36 -15
- data/bundler/lib/bundler/cli/info.rb +50 -0
- data/bundler/lib/bundler/cli/init.rb +20 -7
- data/bundler/lib/bundler/cli/inject.rb +13 -4
- data/bundler/lib/bundler/cli/install.rb +61 -77
- data/bundler/lib/bundler/cli/issue.rb +40 -0
- data/bundler/lib/bundler/cli/list.rb +22 -0
- data/bundler/lib/bundler/cli/lock.rb +4 -2
- data/bundler/lib/bundler/cli/open.rb +2 -2
- data/bundler/lib/bundler/cli/outdated.rb +30 -28
- data/bundler/lib/bundler/cli/package.rb +9 -6
- data/bundler/lib/bundler/cli/platform.rb +1 -0
- data/bundler/lib/bundler/cli/plugin.rb +1 -0
- data/bundler/lib/bundler/cli/pristine.rb +43 -0
- data/bundler/lib/bundler/cli/show.rb +1 -1
- data/bundler/lib/bundler/cli/update.rb +32 -11
- data/bundler/lib/bundler/cli/viz.rb +5 -1
- data/bundler/lib/bundler/compact_index_client.rb +1 -0
- data/bundler/lib/bundler/compact_index_client/cache.rb +1 -2
- data/bundler/lib/bundler/compact_index_client/updater.rb +26 -7
- data/bundler/lib/bundler/compatibility_guard.rb +14 -0
- data/bundler/lib/bundler/constants.rb +1 -0
- data/bundler/lib/bundler/current_ruby.rb +8 -7
- data/bundler/lib/bundler/definition.rb +231 -159
- data/bundler/lib/bundler/dep_proxy.rb +2 -0
- data/bundler/lib/bundler/dependency.rb +6 -7
- data/bundler/lib/bundler/deployment.rb +1 -1
- data/bundler/lib/bundler/deprecate.rb +14 -3
- data/bundler/lib/bundler/dsl.rb +103 -62
- data/bundler/lib/bundler/endpoint_specification.rb +12 -2
- data/bundler/lib/bundler/env.rb +97 -36
- data/bundler/lib/bundler/environment_preserver.rb +27 -6
- data/bundler/lib/bundler/errors.rb +3 -1
- data/bundler/lib/bundler/feature_flag.rb +39 -4
- data/bundler/lib/bundler/fetcher.rb +15 -8
- data/bundler/lib/bundler/fetcher/base.rb +1 -0
- data/bundler/lib/bundler/fetcher/compact_index.rb +2 -12
- data/bundler/lib/bundler/fetcher/dependency.rb +2 -1
- data/bundler/lib/bundler/fetcher/downloader.rb +4 -2
- data/bundler/lib/bundler/fetcher/index.rb +1 -0
- data/bundler/lib/bundler/friendly_errors.rb +5 -2
- data/bundler/lib/bundler/gem_helper.rb +23 -9
- data/bundler/lib/bundler/gem_helpers.rb +1 -0
- data/bundler/lib/bundler/gem_remote_fetcher.rb +1 -0
- data/bundler/lib/bundler/gem_tasks.rb +1 -0
- data/bundler/lib/bundler/gem_version_promoter.rb +1 -0
- data/bundler/lib/bundler/gemdeps.rb +1 -0
- data/bundler/lib/bundler/graph.rb +1 -0
- data/bundler/lib/bundler/index.rb +19 -11
- data/bundler/lib/bundler/injector.rb +51 -27
- data/bundler/lib/bundler/inline.rb +10 -10
- data/bundler/lib/bundler/installer.rb +104 -50
- data/bundler/lib/bundler/installer/gem_installer.rb +5 -2
- data/bundler/lib/bundler/installer/parallel_installer.rb +91 -42
- data/bundler/lib/bundler/installer/standalone.rb +1 -0
- data/bundler/lib/bundler/lazy_specification.rb +17 -4
- data/bundler/lib/bundler/lockfile_generator.rb +95 -0
- data/bundler/lib/bundler/lockfile_parser.rb +49 -35
- data/bundler/lib/bundler/match_platform.rb +1 -0
- data/bundler/lib/bundler/mirror.rb +8 -3
- data/bundler/lib/bundler/plugin.rb +6 -1
- data/bundler/lib/bundler/plugin/api/source.rb +16 -3
- data/bundler/lib/bundler/plugin/index.rb +2 -0
- data/bundler/lib/bundler/plugin/installer.rb +7 -6
- data/bundler/lib/bundler/plugin/source_list.rb +7 -8
- data/bundler/lib/bundler/process_lock.rb +24 -0
- data/bundler/lib/bundler/psyched_yaml.rb +10 -0
- data/bundler/lib/bundler/remote_specification.rb +25 -1
- data/bundler/lib/bundler/resolver.rb +171 -192
- data/bundler/lib/bundler/resolver/spec_group.rb +111 -0
- data/bundler/lib/bundler/retry.rb +1 -0
- data/bundler/lib/bundler/ruby_dsl.rb +1 -0
- data/bundler/lib/bundler/ruby_version.rb +6 -1
- data/bundler/lib/bundler/rubygems_ext.rb +18 -8
- data/bundler/lib/bundler/rubygems_gem_installer.rb +25 -2
- data/bundler/lib/bundler/rubygems_integration.rb +157 -66
- data/bundler/lib/bundler/runtime.rb +28 -18
- data/bundler/lib/bundler/settings.rb +202 -87
- data/bundler/lib/bundler/settings/validator.rb +79 -0
- data/bundler/lib/bundler/setup.rb +4 -7
- data/bundler/lib/bundler/shared_helpers.rb +129 -25
- data/bundler/lib/bundler/similarity_detector.rb +1 -0
- data/bundler/lib/bundler/source.rb +53 -1
- data/bundler/lib/bundler/source/gemspec.rb +1 -0
- data/bundler/lib/bundler/source/git.rb +49 -21
- data/bundler/lib/bundler/source/git/git_proxy.rb +17 -12
- data/bundler/lib/bundler/source/metadata.rb +63 -0
- data/bundler/lib/bundler/source/path.rb +38 -17
- data/bundler/lib/bundler/source/path/installer.rb +4 -2
- data/bundler/lib/bundler/source/rubygems.rb +154 -82
- data/bundler/lib/bundler/source/rubygems/remote.rb +8 -1
- data/bundler/lib/bundler/source_list.rb +75 -15
- data/bundler/lib/bundler/spec_set.rb +34 -21
- data/bundler/lib/bundler/ssl_certs/certificate_manager.rb +2 -1
- data/bundler/lib/bundler/stub_specification.rb +86 -2
- data/bundler/lib/bundler/templates/Executable +5 -1
- data/bundler/lib/bundler/templates/Executable.bundler +105 -0
- data/bundler/lib/bundler/templates/Executable.standalone +5 -5
- data/bundler/lib/bundler/templates/Gemfile +3 -0
- data/bundler/lib/bundler/templates/gems.rb +8 -0
- data/bundler/lib/bundler/templates/newgem/Gemfile.tt +4 -2
- data/bundler/lib/bundler/templates/newgem/LICENSE.txt.tt +1 -1
- data/bundler/lib/bundler/templates/newgem/README.md.tt +14 -8
- data/bundler/lib/bundler/templates/newgem/Rakefile.tt +5 -5
- data/bundler/lib/bundler/templates/newgem/ext/newgem/newgem.c.tt +4 -4
- data/bundler/lib/bundler/templates/newgem/ext/newgem/newgem.h.tt +3 -3
- data/bundler/lib/bundler/templates/newgem/gitignore.tt +0 -1
- data/bundler/lib/bundler/templates/newgem/lib/newgem.rb.tt +6 -6
- data/bundler/lib/bundler/templates/newgem/lib/newgem/version.rb.tt +4 -4
- data/bundler/lib/bundler/templates/newgem/newgem.gemspec.tt +13 -10
- data/bundler/lib/bundler/templates/newgem/rspec.tt +1 -0
- data/bundler/lib/bundler/templates/newgem/spec/newgem_spec.rb.tt +0 -2
- data/bundler/lib/bundler/templates/newgem/spec/spec_helper.rb.tt +3 -0
- data/bundler/lib/bundler/templates/newgem/test/newgem_test.rb.tt +1 -1
- data/bundler/lib/bundler/templates/newgem/test/test_helper.rb.tt +3 -3
- data/bundler/lib/bundler/ui.rb +1 -0
- data/bundler/lib/bundler/ui/rg_proxy.rb +1 -0
- data/bundler/lib/bundler/ui/shell.rb +24 -10
- data/bundler/lib/bundler/ui/silent.rb +12 -1
- data/bundler/lib/bundler/uri_credentials_filter.rb +1 -0
- data/bundler/lib/bundler/vendor/fileutils/lib/fileutils.rb +1638 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo.rb +2 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/compatibility.rb +26 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/delegates/resolution_state.rb +7 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/delegates/specification_provider.rb +1 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph.rb +16 -5
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/action.rb +1 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb +10 -2
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_vertex.rb +1 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/delete_edge.rb +1 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb +1 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/log.rb +1 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/set_payload.rb +1 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/tag.rb +1 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/vertex.rb +5 -4
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/errors.rb +69 -6
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/gem_metadata.rb +2 -1
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/modules/specification_provider.rb +1 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/modules/ui.rb +3 -1
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/resolution.rb +501 -138
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/resolver.rb +1 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/state.rb +8 -4
- data/bundler/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent.rb +3 -1
- data/bundler/lib/bundler/vendor/thor/lib/thor.rb +46 -21
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions.rb +24 -22
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions/create_file.rb +2 -1
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions/create_link.rb +2 -1
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions/directory.rb +2 -2
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions/empty_directory.rb +16 -8
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions/file_manipulation.rb +66 -18
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions/inject_into_file.rb +17 -15
- data/bundler/lib/bundler/vendor/thor/lib/thor/base.rb +55 -32
- data/bundler/lib/bundler/vendor/thor/lib/thor/command.rb +13 -11
- data/bundler/lib/bundler/vendor/thor/lib/thor/core_ext/hash_with_indifferent_access.rb +21 -1
- data/bundler/lib/bundler/vendor/thor/lib/thor/core_ext/io_binary_read.rb +7 -5
- data/bundler/lib/bundler/vendor/thor/lib/thor/core_ext/ordered_hash.rb +94 -63
- data/bundler/lib/bundler/vendor/thor/lib/thor/error.rb +3 -3
- data/bundler/lib/bundler/vendor/thor/lib/thor/group.rb +13 -13
- data/bundler/lib/bundler/vendor/thor/lib/thor/invocation.rb +4 -5
- data/bundler/lib/bundler/vendor/thor/lib/thor/line_editor/basic.rb +2 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/parser/argument.rb +4 -7
- data/bundler/lib/bundler/vendor/thor/lib/thor/parser/arguments.rb +16 -16
- data/bundler/lib/bundler/vendor/thor/lib/thor/parser/option.rb +42 -21
- data/bundler/lib/bundler/vendor/thor/lib/thor/parser/options.rb +13 -10
- data/bundler/lib/bundler/vendor/thor/lib/thor/runner.rb +31 -29
- data/bundler/lib/bundler/vendor/thor/lib/thor/shell.rb +1 -1
- data/bundler/lib/bundler/vendor/thor/lib/thor/shell/basic.rb +49 -33
- data/bundler/lib/bundler/vendor/thor/lib/thor/shell/color.rb +1 -1
- data/bundler/lib/bundler/vendor/thor/lib/thor/shell/html.rb +4 -4
- data/bundler/lib/bundler/vendor/thor/lib/thor/util.rb +8 -7
- data/bundler/lib/bundler/vendor/thor/lib/thor/version.rb +1 -1
- data/bundler/lib/bundler/vendored_fileutils.rb +9 -0
- data/bundler/lib/bundler/vendored_molinillo.rb +1 -0
- data/bundler/lib/bundler/vendored_persistent.rb +35 -0
- data/bundler/lib/bundler/vendored_thor.rb +6 -2
- data/bundler/lib/bundler/version.rb +19 -2
- data/bundler/lib/bundler/version_ranges.rb +76 -0
- data/bundler/lib/bundler/vlad.rb +5 -0
- data/bundler/lib/bundler/worker.rb +3 -1
- data/bundler/lib/bundler/yaml_serializer.rb +3 -3
- data/bundler/man/bundle-add.ronn +29 -0
- data/bundler/man/bundle-binstubs.ronn +14 -0
- data/bundler/man/bundle-check.ronn +26 -0
- data/bundler/man/bundle-clean.ronn +18 -0
- data/bundler/man/bundle-config.ronn +180 -60
- data/bundler/man/bundle-exec.ronn +7 -0
- data/bundler/man/bundle-gem.ronn +3 -2
- data/bundler/man/bundle-info.ronn +17 -0
- data/bundler/man/bundle-init.ronn +18 -0
- data/bundler/man/bundle-inject.ronn +22 -0
- data/bundler/man/bundle-install.ronn +32 -32
- data/bundler/man/bundle-list.ronn +15 -0
- data/bundler/man/bundle-open.ronn +19 -0
- data/bundler/man/bundle-outdated.ronn +1 -1
- data/bundler/man/bundle-package.ronn +5 -0
- data/bundler/man/bundle-pristine.ronn +34 -0
- data/bundler/man/bundle-show.ronn +20 -0
- data/bundler/man/bundle-update.ronn +6 -3
- data/bundler/man/bundle-viz.ronn +30 -0
- data/bundler/man/bundle.ronn +11 -20
- data/bundler/man/gemfile.5.ronn +55 -64
- data/lib/rubygems.rb +79 -36
- data/lib/rubygems/basic_specification.rb +8 -4
- data/lib/rubygems/bundler_version_finder.rb +112 -0
- data/lib/rubygems/command.rb +1 -1
- data/lib/rubygems/command_manager.rb +3 -1
- data/lib/rubygems/commands/cert_command.rb +31 -6
- data/lib/rubygems/commands/cleanup_command.rb +1 -1
- data/lib/rubygems/commands/help_command.rb +1 -1
- data/lib/rubygems/commands/owner_command.rb +3 -1
- data/lib/rubygems/commands/pristine_command.rb +11 -8
- data/lib/rubygems/commands/push_command.rb +2 -1
- data/lib/rubygems/commands/query_command.rb +13 -14
- data/lib/rubygems/commands/setup_command.rb +124 -69
- data/lib/rubygems/commands/signin_command.rb +33 -0
- data/lib/rubygems/commands/signout_command.rb +33 -0
- data/lib/rubygems/commands/uninstall_command.rb +4 -3
- data/lib/rubygems/commands/unpack_command.rb +16 -4
- data/lib/rubygems/commands/update_command.rb +1 -1
- data/lib/rubygems/commands/which_command.rb +1 -1
- data/lib/rubygems/commands/yank_command.rb +4 -11
- data/lib/rubygems/config_file.rb +13 -24
- data/lib/rubygems/core_ext/kernel_require.rb +10 -9
- data/lib/rubygems/dependency.rb +2 -0
- data/lib/rubygems/dependency_installer.rb +4 -0
- data/lib/rubygems/errors.rb +3 -0
- data/lib/rubygems/exceptions.rb +6 -0
- data/lib/rubygems/ext/builder.rb +1 -1
- data/lib/rubygems/ext/ext_conf_builder.rb +2 -4
- data/lib/rubygems/ext/rake_builder.rb +1 -1
- data/lib/rubygems/gem_runner.rb +5 -1
- data/lib/rubygems/install_update_options.rb +5 -28
- data/lib/rubygems/installer.rb +12 -7
- data/lib/rubygems/installer_test_case.rb +6 -3
- data/lib/rubygems/package/old.rb +1 -1
- data/lib/rubygems/request.rb +1 -1
- data/lib/rubygems/request_set.rb +20 -3
- data/lib/rubygems/request_set/gem_dependency_api.rb +3 -3
- data/lib/rubygems/requirement.rb +5 -1
- data/lib/rubygems/resolver.rb +24 -3
- data/lib/rubygems/resolver/installer_set.rb +4 -6
- data/lib/rubygems/safe_yaml.rb +4 -1
- data/lib/rubygems/security.rb +10 -3
- data/lib/rubygems/security_option.rb +43 -0
- data/lib/rubygems/server.rb +4 -12
- data/lib/rubygems/source.rb +7 -4
- data/lib/rubygems/source/git.rb +2 -1
- data/lib/rubygems/source/local.rb +38 -35
- data/lib/rubygems/source/lock.rb +4 -1
- data/lib/rubygems/source_local.rb +3 -1
- data/lib/rubygems/source_specific_file.rb +3 -2
- data/lib/rubygems/spec_fetcher.rb +7 -3
- data/lib/rubygems/specification.rb +281 -231
- data/lib/rubygems/stub_specification.rb +2 -3
- data/lib/rubygems/test_case.rb +14 -1
- data/lib/rubygems/user_interaction.rb +15 -13
- data/lib/rubygems/util.rb +6 -17
- data/lib/rubygems/version.rb +17 -3
- data/lib/rubygems/version_option.rb +6 -1
- data/setup.rb +1 -1
- data/test/rubygems/private3072_key.pem +40 -0
- data/test/rubygems/public3072_cert.pem +25 -0
- data/test/rubygems/test_config.rb +1 -1
- data/test/rubygems/test_gem.rb +72 -14
- data/test/rubygems/test_gem_bundler_version_finder.rb +125 -0
- data/test/rubygems/test_gem_command.rb +1 -1
- data/test/rubygems/test_gem_commands_build_command.rb +27 -1
- data/test/rubygems/test_gem_commands_cert_command.rb +64 -0
- data/test/rubygems/test_gem_commands_install_command.rb +35 -2
- data/test/rubygems/test_gem_commands_pristine_command.rb +1 -1
- data/test/rubygems/test_gem_commands_query_command.rb +19 -0
- data/test/rubygems/test_gem_commands_setup_command.rb +17 -0
- data/test/rubygems/test_gem_commands_signin_command.rb +95 -0
- data/test/rubygems/test_gem_commands_signout_command.rb +37 -0
- data/test/rubygems/test_gem_commands_sources_command.rb +1 -1
- data/test/rubygems/test_gem_commands_uninstall_command.rb +12 -0
- data/test/rubygems/test_gem_commands_update_command.rb +1 -1
- data/test/rubygems/test_gem_commands_which_command.rb +3 -3
- data/test/rubygems/test_gem_dependency.rb +28 -0
- data/test/rubygems/test_gem_ext_builder.rb +2 -2
- data/test/rubygems/test_gem_ext_rake_builder.rb +2 -2
- data/test/rubygems/test_gem_install_update_options.rb +2 -1
- data/test/rubygems/test_gem_installer.rb +29 -27
- data/test/rubygems/test_gem_package.rb +5 -5
- data/test/rubygems/test_gem_remote_fetcher.rb +2 -2
- data/test/rubygems/test_gem_request_set_gem_dependency_api.rb +3 -3
- data/test/rubygems/test_gem_requirement.rb +6 -0
- data/test/rubygems/test_gem_resolver.rb +26 -0
- data/test/rubygems/test_gem_resolver_conflict.rb +1 -1
- data/test/rubygems/test_gem_security.rb +5 -0
- data/test/rubygems/test_gem_security_policy.rb +24 -24
- data/test/rubygems/test_gem_security_signer.rb +6 -6
- data/test/rubygems/test_gem_security_trust_dir.rb +2 -2
- data/test/rubygems/test_gem_server.rb +18 -1
- data/test/rubygems/test_gem_source.rb +9 -0
- data/test/rubygems/test_gem_spec_fetcher.rb +20 -0
- data/test/rubygems/test_gem_specification.rb +85 -10
- data/test/rubygems/test_gem_stream_ui.rb +6 -6
- data/test/rubygems/test_gem_stub_specification.rb +19 -1
- data/test/rubygems/test_gem_util.rb +1 -0
- data/test/rubygems/test_gem_version.rb +28 -7
- data/test/rubygems/test_gem_version_option.rb +15 -0
- data/test/rubygems/test_kernel.rb +30 -0
- data/test/rubygems/test_require.rb +44 -0
- metadata +47 -46
- data/README.rdoc +0 -54
- data/bundler/DEVELOPMENT.md +0 -150
- data/bundler/ISSUES.md +0 -117
- data/bundler/lib/bundler/postit_trampoline.rb +0 -73
- data/bundler/lib/bundler/vendor/postit/lib/postit.rb +0 -15
- data/bundler/lib/bundler/vendor/postit/lib/postit/environment.rb +0 -44
- data/bundler/lib/bundler/vendor/postit/lib/postit/installer.rb +0 -28
- data/bundler/lib/bundler/vendor/postit/lib/postit/parser.rb +0 -21
- data/bundler/lib/bundler/vendor/postit/lib/postit/setup.rb +0 -12
- data/bundler/lib/bundler/vendor/postit/lib/postit/version.rb +0 -3
- data/bundler/man/index.txt +0 -8
@@ -1,4 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
|
2
3
|
module Bundler
|
3
4
|
class GemInstaller
|
4
5
|
attr_reader :spec, :standalone, :worker, :force, :installer
|
@@ -16,7 +17,7 @@ module Bundler
|
|
16
17
|
Bundler.ui.debug "#{worker}: #{spec.name} (#{spec.version}) from #{spec.loaded_from}"
|
17
18
|
generate_executable_stubs
|
18
19
|
return true, post_install_message
|
19
|
-
rescue Bundler::InstallHookError, Bundler::SecurityError
|
20
|
+
rescue Bundler::InstallHookError, Bundler::SecurityError, APIResponseMismatchError
|
20
21
|
raise
|
21
22
|
rescue Errno::ENOSPC
|
22
23
|
return false, out_of_space_message
|
@@ -52,7 +53,7 @@ module Bundler
|
|
52
53
|
end
|
53
54
|
|
54
55
|
def install
|
55
|
-
spec.source.install(spec, :force => force, :ensure_builtin_gems_cached => standalone, :build_args =>
|
56
|
+
spec.source.install(spec, :force => force, :ensure_builtin_gems_cached => standalone, :build_args => Array(spec_settings))
|
56
57
|
end
|
57
58
|
|
58
59
|
def install_with_settings
|
@@ -65,6 +66,8 @@ module Bundler
|
|
65
66
|
end
|
66
67
|
|
67
68
|
def generate_executable_stubs
|
69
|
+
return if Bundler.feature_flag.forget_cli_options?
|
70
|
+
return if Bundler.settings[:inline]
|
68
71
|
if Bundler.settings[:bin] && standalone
|
69
72
|
installer.generate_standalone_bundler_executable_stubs(spec)
|
70
73
|
elsif Bundler.settings[:bin]
|
@@ -1,4 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
|
2
3
|
require "bundler/worker"
|
3
4
|
require "bundler/installer/gem_installer"
|
4
5
|
|
@@ -67,17 +68,16 @@ module Bundler
|
|
67
68
|
def all_dependencies
|
68
69
|
@spec.dependencies
|
69
70
|
end
|
71
|
+
|
72
|
+
def to_s
|
73
|
+
"#<#{self.class} #{@spec.full_name} (#{state})>"
|
74
|
+
end
|
70
75
|
end
|
71
76
|
|
72
77
|
def self.call(*args)
|
73
78
|
new(*args).call
|
74
79
|
end
|
75
80
|
|
76
|
-
# Returns max number of threads machine can handle with a min of 1
|
77
|
-
def self.max_threads
|
78
|
-
[Bundler.settings[:jobs].to_i - 1, 1].max
|
79
|
-
end
|
80
|
-
|
81
81
|
attr_reader :size
|
82
82
|
|
83
83
|
def initialize(installer, all_specs, size, standalone, force)
|
@@ -86,6 +86,7 @@ module Bundler
|
|
86
86
|
@standalone = standalone
|
87
87
|
@force = force
|
88
88
|
@specs = all_specs.map {|s| SpecInstallation.new(s) }
|
89
|
+
@spec_set = all_specs
|
89
90
|
end
|
90
91
|
|
91
92
|
def call
|
@@ -94,49 +95,19 @@ module Bundler
|
|
94
95
|
require "bundler/gem_remote_fetcher" if RUBY_VERSION < "1.9"
|
95
96
|
|
96
97
|
check_for_corrupt_lockfile
|
97
|
-
|
98
|
-
|
98
|
+
|
99
|
+
if @size > 1
|
100
|
+
install_with_worker
|
101
|
+
else
|
102
|
+
install_serially
|
103
|
+
end
|
104
|
+
|
99
105
|
handle_error if @specs.any?(&:failed?)
|
100
106
|
@specs
|
101
107
|
ensure
|
102
108
|
worker_pool && worker_pool.stop
|
103
109
|
end
|
104
110
|
|
105
|
-
def worker_pool
|
106
|
-
@worker_pool ||= Bundler::Worker.new @size, "Parallel Installer", lambda { |spec_install, worker_num|
|
107
|
-
gem_installer = Bundler::GemInstaller.new(
|
108
|
-
spec_install.spec, @installer, @standalone, worker_num, @force
|
109
|
-
)
|
110
|
-
success, message = gem_installer.install_from_spec
|
111
|
-
if success && !message.nil?
|
112
|
-
spec_install.post_install_message = message
|
113
|
-
elsif !success
|
114
|
-
spec_install.state = :failed
|
115
|
-
spec_install.error = message
|
116
|
-
end
|
117
|
-
spec_install
|
118
|
-
}
|
119
|
-
end
|
120
|
-
|
121
|
-
# Dequeue a spec and save its post-install message and then enqueue the
|
122
|
-
# remaining specs.
|
123
|
-
# Some specs might've had to wait til this spec was installed to be
|
124
|
-
# processed so the call to `enqueue_specs` is important after every
|
125
|
-
# dequeue.
|
126
|
-
def process_specs
|
127
|
-
spec = worker_pool.deq
|
128
|
-
spec.state = :installed unless spec.failed?
|
129
|
-
enqueue_specs
|
130
|
-
end
|
131
|
-
|
132
|
-
def handle_error
|
133
|
-
errors = @specs.select(&:failed?).map(&:error)
|
134
|
-
if exception = errors.find {|e| e.is_a?(Bundler::BundlerError) }
|
135
|
-
raise exception
|
136
|
-
end
|
137
|
-
raise Bundler::InstallError, errors.map(&:to_s).join("\n\n")
|
138
|
-
end
|
139
|
-
|
140
111
|
def check_for_corrupt_lockfile
|
141
112
|
missing_dependencies = @specs.map do |s|
|
142
113
|
[
|
@@ -162,6 +133,84 @@ module Bundler
|
|
162
133
|
Bundler.ui.warn(warning.join("\n"))
|
163
134
|
end
|
164
135
|
|
136
|
+
private
|
137
|
+
|
138
|
+
def install_with_worker
|
139
|
+
enqueue_specs
|
140
|
+
process_specs until finished_installing?
|
141
|
+
end
|
142
|
+
|
143
|
+
def install_serially
|
144
|
+
until finished_installing?
|
145
|
+
raise "failed to find a spec to enqueue while installing serially" unless spec_install = @specs.find(&:ready_to_enqueue?)
|
146
|
+
spec_install.state = :enqueued
|
147
|
+
do_install(spec_install, 0)
|
148
|
+
end
|
149
|
+
end
|
150
|
+
|
151
|
+
def worker_pool
|
152
|
+
@worker_pool ||= Bundler::Worker.new @size, "Parallel Installer", lambda { |spec_install, worker_num|
|
153
|
+
do_install(spec_install, worker_num)
|
154
|
+
}
|
155
|
+
end
|
156
|
+
|
157
|
+
def do_install(spec_install, worker_num)
|
158
|
+
gem_installer = Bundler::GemInstaller.new(
|
159
|
+
spec_install.spec, @installer, @standalone, worker_num, @force
|
160
|
+
)
|
161
|
+
success, message = begin
|
162
|
+
gem_installer.install_from_spec
|
163
|
+
rescue => e
|
164
|
+
raise e, "#{e}\n\n#{require_tree_for_spec(spec_install.spec)}"
|
165
|
+
end
|
166
|
+
if success
|
167
|
+
spec_install.state = :installed
|
168
|
+
spec_install.post_install_message = message unless message.nil?
|
169
|
+
else
|
170
|
+
spec_install.state = :failed
|
171
|
+
spec_install.error = "#{message}\n\n#{require_tree_for_spec(spec_install.spec)}"
|
172
|
+
end
|
173
|
+
spec_install
|
174
|
+
end
|
175
|
+
|
176
|
+
# Dequeue a spec and save its post-install message and then enqueue the
|
177
|
+
# remaining specs.
|
178
|
+
# Some specs might've had to wait til this spec was installed to be
|
179
|
+
# processed so the call to `enqueue_specs` is important after every
|
180
|
+
# dequeue.
|
181
|
+
def process_specs
|
182
|
+
worker_pool.deq
|
183
|
+
enqueue_specs
|
184
|
+
end
|
185
|
+
|
186
|
+
def finished_installing?
|
187
|
+
@specs.all? do |spec|
|
188
|
+
return true if spec.failed?
|
189
|
+
spec.installed?
|
190
|
+
end
|
191
|
+
end
|
192
|
+
|
193
|
+
def handle_error
|
194
|
+
errors = @specs.select(&:failed?).map(&:error)
|
195
|
+
if exception = errors.find {|e| e.is_a?(Bundler::BundlerError) }
|
196
|
+
raise exception
|
197
|
+
end
|
198
|
+
raise Bundler::InstallError, errors.map(&:to_s).join("\n\n")
|
199
|
+
end
|
200
|
+
|
201
|
+
def require_tree_for_spec(spec)
|
202
|
+
tree = @spec_set.what_required(spec)
|
203
|
+
t = String.new("In #{File.basename(SharedHelpers.default_gemfile)}:\n")
|
204
|
+
tree.each_with_index do |s, depth|
|
205
|
+
t << " " * depth.succ << s.name
|
206
|
+
unless tree.last == s
|
207
|
+
t << %( was resolved to #{s.version}, which depends on)
|
208
|
+
end
|
209
|
+
t << %(\n)
|
210
|
+
end
|
211
|
+
t
|
212
|
+
end
|
213
|
+
|
165
214
|
# Keys in the remains hash represent uninstalled gems specs.
|
166
215
|
# We enqueue all gem specs that do not have any dependencies.
|
167
216
|
# Later we call this lambda again to install specs that depended on
|
@@ -1,6 +1,6 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
|
2
3
|
require "uri"
|
3
|
-
require "rubygems/spec_fetcher"
|
4
4
|
require "bundler/match_platform"
|
5
5
|
|
6
6
|
module Bundler
|
@@ -30,7 +30,7 @@ module Bundler
|
|
30
30
|
@name = name
|
31
31
|
@version = version
|
32
32
|
@dependencies = []
|
33
|
-
@platform = platform
|
33
|
+
@platform = platform || Gem::Platform::RUBY
|
34
34
|
@source = source
|
35
35
|
@specification = nil
|
36
36
|
end
|
@@ -69,11 +69,19 @@ module Bundler
|
|
69
69
|
end
|
70
70
|
|
71
71
|
def __materialize__
|
72
|
-
search_object = Bundler.
|
72
|
+
search_object = Bundler.feature_flag.specific_platform? || Bundler.settings[:force_ruby_platform] ? self : Dependency.new(name, version)
|
73
73
|
@specification = if source.is_a?(Source::Gemspec) && source.gemspec.name == name
|
74
74
|
source.gemspec.tap {|s| s.source = source }
|
75
75
|
else
|
76
|
-
source.specs.search(search_object).last
|
76
|
+
search = source.specs.search(search_object).last
|
77
|
+
if search && Gem::Platform.new(search.platform) != Gem::Platform.new(platform) && !search.runtime_dependencies.-(dependencies.reject {|d| d.type == :development }).empty?
|
78
|
+
Bundler.ui.warn "Unable to use the platform-specific (#{search.platform}) version of #{name} (#{version}) " \
|
79
|
+
"because it has different dependencies from the #{platform} version. " \
|
80
|
+
"To use the platform-specific version of the gem, run `bundle config specific_platform true` and install again."
|
81
|
+
search = source.specs.search(self).last
|
82
|
+
end
|
83
|
+
search.dependencies = dependencies if search.is_a?(RemoteSpecification) || search.is_a?(EndpointSpecification)
|
84
|
+
search
|
77
85
|
end
|
78
86
|
end
|
79
87
|
|
@@ -93,6 +101,11 @@ module Bundler
|
|
93
101
|
@__identifier ||= Identifier.new(name, version, source, platform, dependencies)
|
94
102
|
end
|
95
103
|
|
104
|
+
def git_version
|
105
|
+
return unless source.is_a?(Bundler::Source::Git)
|
106
|
+
" #{source.revision[0..6]}"
|
107
|
+
end
|
108
|
+
|
96
109
|
private
|
97
110
|
|
98
111
|
def to_ary
|
@@ -0,0 +1,95 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Bundler
|
4
|
+
class LockfileGenerator
|
5
|
+
attr_reader :definition
|
6
|
+
attr_reader :out
|
7
|
+
|
8
|
+
# @private
|
9
|
+
def initialize(definition)
|
10
|
+
@definition = definition
|
11
|
+
@out = String.new
|
12
|
+
end
|
13
|
+
|
14
|
+
def self.generate(definition)
|
15
|
+
new(definition).generate!
|
16
|
+
end
|
17
|
+
|
18
|
+
def generate!
|
19
|
+
add_sources
|
20
|
+
add_platforms
|
21
|
+
add_dependencies
|
22
|
+
add_locked_ruby_version
|
23
|
+
add_bundled_with
|
24
|
+
|
25
|
+
out
|
26
|
+
end
|
27
|
+
|
28
|
+
private
|
29
|
+
|
30
|
+
def add_sources
|
31
|
+
definition.send(:sources).lock_sources.each_with_index do |source, idx|
|
32
|
+
out << "\n" unless idx.zero?
|
33
|
+
|
34
|
+
# Add the source header
|
35
|
+
out << source.to_lock
|
36
|
+
|
37
|
+
# Find all specs for this source
|
38
|
+
specs = definition.resolve.select {|s| source.can_lock?(s) }
|
39
|
+
add_specs(specs)
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
def add_specs(specs)
|
44
|
+
# This needs to be sorted by full name so that
|
45
|
+
# gems with the same name, but different platform
|
46
|
+
# are ordered consistently
|
47
|
+
specs.sort_by(&:full_name).each do |spec|
|
48
|
+
next if spec.name == "bundler".freeze
|
49
|
+
out << spec.to_lock
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
def add_platforms
|
54
|
+
add_section("PLATFORMS", definition.platforms)
|
55
|
+
end
|
56
|
+
|
57
|
+
def add_dependencies
|
58
|
+
out << "\nDEPENDENCIES\n"
|
59
|
+
|
60
|
+
handled = []
|
61
|
+
definition.dependencies.sort_by(&:to_s).each do |dep|
|
62
|
+
next if handled.include?(dep.name)
|
63
|
+
out << dep.to_lock
|
64
|
+
handled << dep.name
|
65
|
+
end
|
66
|
+
end
|
67
|
+
|
68
|
+
def add_locked_ruby_version
|
69
|
+
return unless locked_ruby_version = definition.locked_ruby_version
|
70
|
+
add_section("RUBY VERSION", locked_ruby_version.to_s)
|
71
|
+
end
|
72
|
+
|
73
|
+
def add_bundled_with
|
74
|
+
add_section("BUNDLED WITH", definition.locked_bundler_version.to_s)
|
75
|
+
end
|
76
|
+
|
77
|
+
def add_section(name, value)
|
78
|
+
out << "\n#{name}\n"
|
79
|
+
case value
|
80
|
+
when Array
|
81
|
+
value.map(&:to_s).sort.each do |val|
|
82
|
+
out << " #{val}\n"
|
83
|
+
end
|
84
|
+
when Hash
|
85
|
+
value.to_a.sort_by {|k, _| k.to_s }.each do |key, val|
|
86
|
+
out << " #{key}: #{val}\n"
|
87
|
+
end
|
88
|
+
when String
|
89
|
+
out << " #{value}\n"
|
90
|
+
else
|
91
|
+
raise ArgumentError, "#{value.inspect} can't be serialized in a lockfile"
|
92
|
+
end
|
93
|
+
end
|
94
|
+
end
|
95
|
+
end
|
@@ -61,7 +61,7 @@ module Bundler
|
|
61
61
|
def initialize(lockfile)
|
62
62
|
@platforms = []
|
63
63
|
@sources = []
|
64
|
-
@dependencies =
|
64
|
+
@dependencies = {}
|
65
65
|
@state = nil
|
66
66
|
@specs = {}
|
67
67
|
|
@@ -90,7 +90,7 @@ module Bundler
|
|
90
90
|
send("parse_#{@state}", line)
|
91
91
|
end
|
92
92
|
end
|
93
|
-
@sources << @rubygems_aggregate
|
93
|
+
@sources << @rubygems_aggregate unless Bundler.feature_flag.lockfile_uses_separate_rubygems_sources?
|
94
94
|
@specs = @specs.values.sort_by(&:identifier)
|
95
95
|
warn_for_outdated_bundler_version
|
96
96
|
rescue ArgumentError => e
|
@@ -141,10 +141,16 @@ module Bundler
|
|
141
141
|
@sources << @current_source
|
142
142
|
end
|
143
143
|
when GEM
|
144
|
-
|
145
|
-
@
|
144
|
+
if Bundler.feature_flag.lockfile_uses_separate_rubygems_sources?
|
145
|
+
@opts["remotes"] = @opts.delete("remote")
|
146
|
+
@current_source = TYPES[@type].from_lock(@opts)
|
147
|
+
@sources << @current_source
|
148
|
+
else
|
149
|
+
Array(@opts["remote"]).each do |url|
|
150
|
+
@rubygems_aggregate.add_remote(url)
|
151
|
+
end
|
152
|
+
@current_source = @rubygems_aggregate
|
146
153
|
end
|
147
|
-
@current_source = @rubygems_aggregate
|
148
154
|
when PLUGIN
|
149
155
|
@current_source = Plugin.source_from_lock(@opts)
|
150
156
|
@sources << @current_source
|
@@ -171,43 +177,53 @@ module Bundler
|
|
171
177
|
end
|
172
178
|
end
|
173
179
|
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
180
|
+
space = / /
|
181
|
+
NAME_VERSION = /
|
182
|
+
^(#{space}{2}|#{space}{4}|#{space}{6})(?!#{space}) # Exactly 2, 4, or 6 spaces at the start of the line
|
183
|
+
(.*?) # Name
|
184
|
+
(?:#{space}\(([^-]*) # Space, followed by version
|
185
|
+
(?:-(.*))?\))? # Optional platform
|
186
|
+
(!)? # Optional pinned marker
|
187
|
+
$ # Line end
|
188
|
+
/xo
|
178
189
|
|
179
190
|
def parse_dependency(line)
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
|
191
|
+
return unless line =~ NAME_VERSION
|
192
|
+
spaces = $1
|
193
|
+
return unless spaces.size == 2
|
194
|
+
name = $2
|
195
|
+
version = $3
|
196
|
+
pinned = $5
|
185
197
|
|
186
|
-
|
198
|
+
version = version.split(",").map(&:strip) if version
|
187
199
|
|
188
|
-
|
189
|
-
spec = @specs.find {|_, v| v.name == dep.name }
|
190
|
-
dep.source = spec.last.source if spec
|
200
|
+
dep = Bundler::Dependency.new(name, version)
|
191
201
|
|
192
|
-
|
193
|
-
|
194
|
-
|
195
|
-
# TODO: Use the version from the spec instead of from the dependency
|
196
|
-
if version && version.size == 1 && version.first =~ /^\s*= (.+)\s*$/ && dep.source.is_a?(Bundler::Source::Path)
|
197
|
-
dep.source.name = name
|
198
|
-
dep.source.version = $1
|
199
|
-
end
|
200
|
-
end
|
202
|
+
if pinned && dep.name != "bundler"
|
203
|
+
spec = @specs.find {|_, v| v.name == dep.name }
|
204
|
+
dep.source = spec.last.source if spec
|
201
205
|
|
202
|
-
|
206
|
+
# Path sources need to know what the default name / version
|
207
|
+
# to use in the case that there are no gemspecs present. A fake
|
208
|
+
# gemspec is created based on the version set on the dependency
|
209
|
+
# TODO: Use the version from the spec instead of from the dependency
|
210
|
+
if version && version.size == 1 && version.first =~ /^\s*= (.+)\s*$/ && dep.source.is_a?(Bundler::Source::Path)
|
211
|
+
dep.source.name = name
|
212
|
+
dep.source.version = $1
|
213
|
+
end
|
203
214
|
end
|
215
|
+
|
216
|
+
@dependencies[dep.name] = dep
|
204
217
|
end
|
205
218
|
|
206
219
|
def parse_spec(line)
|
207
|
-
|
208
|
-
|
209
|
-
|
210
|
-
|
220
|
+
return unless line =~ NAME_VERSION
|
221
|
+
spaces = $1
|
222
|
+
name = $2
|
223
|
+
version = $3
|
224
|
+
platform = $4
|
225
|
+
|
226
|
+
if spaces.size == 4
|
211
227
|
version = Gem::Version.new(version)
|
212
228
|
platform = platform ? Gem::Platform.new(platform) : Gem::Platform::RUBY
|
213
229
|
@current_spec = LazySpecification.new(name, version, platform)
|
@@ -216,9 +232,7 @@ module Bundler
|
|
216
232
|
# Avoid introducing multiple copies of the same spec (caused by
|
217
233
|
# duplicate GIT sections)
|
218
234
|
@specs[@current_spec.identifier] ||= @current_spec
|
219
|
-
elsif
|
220
|
-
name = $1
|
221
|
-
version = $2
|
235
|
+
elsif spaces.size == 6
|
222
236
|
version = version.split(",").map(&:strip) if version
|
223
237
|
dep = Gem::Dependency.new(name, version)
|
224
238
|
@current_spec.dependencies << dep
|