bundler 2.2.27 → 2.6.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +1328 -4
- data/README.md +4 -8
- data/bundler.gemspec +11 -11
- data/exe/bundle +5 -26
- data/exe/bundler +1 -1
- data/lib/bundler/.document +1 -0
- data/lib/bundler/build_metadata.rb +4 -4
- data/lib/bundler/capistrano.rb +1 -1
- data/lib/bundler/checksum.rb +254 -0
- data/lib/bundler/ci_detector.rb +75 -0
- data/lib/bundler/cli/add.rb +7 -5
- data/lib/bundler/cli/binstubs.rb +10 -6
- data/lib/bundler/cli/cache.rb +1 -1
- data/lib/bundler/cli/check.rb +4 -4
- data/lib/bundler/cli/common.rb +13 -3
- data/lib/bundler/cli/config.rb +18 -8
- data/lib/bundler/cli/console.rb +2 -5
- data/lib/bundler/cli/doctor.rb +16 -9
- data/lib/bundler/cli/exec.rb +2 -1
- data/lib/bundler/cli/fund.rb +1 -1
- data/lib/bundler/cli/gem.rb +153 -40
- data/lib/bundler/cli/info.rb +27 -17
- data/lib/bundler/cli/init.rb +6 -2
- data/lib/bundler/cli/inject.rb +1 -1
- data/lib/bundler/cli/install.rb +34 -42
- data/lib/bundler/cli/issue.rb +5 -4
- data/lib/bundler/cli/lock.rb +54 -28
- data/lib/bundler/cli/open.rb +9 -9
- data/lib/bundler/cli/outdated.rb +34 -29
- data/lib/bundler/cli/platform.rb +8 -6
- data/lib/bundler/cli/plugin.rb +9 -15
- data/lib/bundler/cli/pristine.rb +38 -30
- data/lib/bundler/cli/remove.rb +1 -2
- data/lib/bundler/cli/show.rb +5 -5
- data/lib/bundler/cli/update.rb +12 -7
- data/lib/bundler/cli/viz.rb +1 -1
- data/lib/bundler/cli.rb +265 -313
- data/lib/bundler/compact_index_client/cache.rb +53 -67
- data/lib/bundler/compact_index_client/cache_file.rb +148 -0
- data/lib/bundler/compact_index_client/gem_parser.rb +7 -3
- data/lib/bundler/compact_index_client/parser.rb +84 -0
- data/lib/bundler/compact_index_client/updater.rb +73 -77
- data/lib/bundler/compact_index_client.rb +59 -87
- data/lib/bundler/constants.rb +9 -2
- data/lib/bundler/current_ruby.rb +12 -16
- data/lib/bundler/definition.rb +604 -347
- data/lib/bundler/dependency.rb +33 -71
- data/lib/bundler/digest.rb +71 -0
- data/lib/bundler/dsl.rb +136 -102
- data/lib/bundler/endpoint_specification.rb +42 -16
- data/lib/bundler/env.rb +5 -7
- data/lib/bundler/environment_preserver.rb +8 -22
- data/lib/bundler/errors.rb +113 -13
- data/lib/bundler/feature_flag.rb +1 -2
- data/lib/bundler/fetcher/base.rb +11 -11
- data/lib/bundler/fetcher/compact_index.rb +32 -52
- data/lib/bundler/fetcher/dependency.rb +3 -7
- data/lib/bundler/fetcher/downloader.rb +17 -16
- data/lib/bundler/fetcher/gem_remote_fetcher.rb +16 -0
- data/lib/bundler/fetcher/index.rb +2 -29
- data/lib/bundler/fetcher.rb +98 -83
- data/lib/bundler/force_platform.rb +16 -0
- data/lib/bundler/friendly_errors.rb +29 -40
- data/lib/bundler/gem_helper.rb +12 -24
- data/lib/bundler/gem_helpers.rb +47 -7
- data/lib/bundler/gem_version_promoter.rb +68 -109
- data/lib/bundler/graph.rb +9 -9
- data/lib/bundler/index.rb +71 -79
- data/lib/bundler/injector.rb +25 -13
- data/lib/bundler/inline.rb +41 -28
- data/lib/bundler/installer/gem_installer.rb +22 -13
- data/lib/bundler/installer/parallel_installer.rb +19 -66
- data/lib/bundler/installer/standalone.rb +58 -17
- data/lib/bundler/installer.rb +31 -93
- data/lib/bundler/lazy_specification.rb +151 -72
- data/lib/bundler/lockfile_generator.rb +13 -4
- data/lib/bundler/lockfile_parser.rb +146 -71
- data/lib/bundler/man/bundle-add.1 +54 -44
- data/lib/bundler/man/bundle-add.1.ronn +62 -21
- data/lib/bundler/man/bundle-binstubs.1 +10 -19
- data/lib/bundler/man/bundle-binstubs.1.ronn +6 -3
- data/lib/bundler/man/bundle-cache.1 +38 -25
- data/lib/bundler/man/bundle-cache.1.ronn +40 -4
- data/lib/bundler/man/bundle-check.1 +7 -14
- data/lib/bundler/man/bundle-check.1.ronn +7 -2
- data/lib/bundler/man/bundle-clean.1 +4 -11
- data/lib/bundler/man/bundle-clean.1.ronn +1 -1
- data/lib/bundler/man/bundle-config.1 +48 -227
- data/lib/bundler/man/bundle-config.1.ronn +41 -34
- data/lib/bundler/man/bundle-console.1 +33 -0
- data/lib/bundler/man/bundle-console.1.ronn +39 -0
- data/lib/bundler/man/bundle-doctor.1 +5 -19
- data/lib/bundler/man/bundle-doctor.1.ronn +1 -1
- data/lib/bundler/man/bundle-env.1 +9 -0
- data/lib/bundler/man/bundle-env.1.ronn +10 -0
- data/lib/bundler/man/bundle-exec.1 +20 -78
- data/lib/bundler/man/bundle-exec.1.ronn +12 -10
- data/lib/bundler/man/bundle-fund.1 +22 -0
- data/lib/bundler/man/bundle-fund.1.ronn +25 -0
- data/lib/bundler/man/bundle-gem.1 +57 -72
- data/lib/bundler/man/bundle-gem.1.ronn +57 -9
- data/lib/bundler/man/bundle-help.1 +9 -0
- data/lib/bundler/man/bundle-help.1.ronn +12 -0
- data/lib/bundler/man/bundle-info.1 +8 -11
- data/lib/bundler/man/bundle-info.1.ronn +9 -5
- data/lib/bundler/man/bundle-init.1 +7 -12
- data/lib/bundler/man/bundle-init.1.ronn +4 -1
- data/lib/bundler/man/bundle-inject.1 +17 -19
- data/lib/bundler/man/bundle-inject.1.ronn +12 -2
- data/lib/bundler/man/bundle-install.1 +43 -163
- data/lib/bundler/man/bundle-install.1.ronn +33 -51
- data/lib/bundler/man/bundle-issue.1 +45 -0
- data/lib/bundler/man/bundle-issue.1.ronn +37 -0
- data/lib/bundler/man/bundle-licenses.1 +9 -0
- data/lib/bundler/man/bundle-licenses.1.ronn +10 -0
- data/lib/bundler/man/bundle-list.1 +4 -19
- data/lib/bundler/man/bundle-list.1.ronn +4 -1
- data/lib/bundler/man/bundle-lock.1 +25 -34
- data/lib/bundler/man/bundle-lock.1.ronn +25 -4
- data/lib/bundler/man/bundle-open.1 +18 -18
- data/lib/bundler/man/bundle-open.1.ronn +10 -1
- data/lib/bundler/man/bundle-outdated.1 +23 -75
- data/lib/bundler/man/bundle-outdated.1.ronn +21 -22
- data/lib/bundler/man/bundle-platform.1 +16 -28
- data/lib/bundler/man/bundle-platform.1.ronn +14 -7
- data/lib/bundler/man/bundle-plugin.1 +58 -0
- data/lib/bundler/man/bundle-plugin.1.ronn +63 -0
- data/lib/bundler/man/bundle-pristine.1 +5 -16
- data/lib/bundler/man/bundle-pristine.1.ronn +1 -1
- data/lib/bundler/man/bundle-remove.1 +4 -14
- data/lib/bundler/man/bundle-remove.1.ronn +1 -1
- data/lib/bundler/man/bundle-show.1 +7 -11
- data/lib/bundler/man/bundle-show.1.ronn +4 -0
- data/lib/bundler/man/bundle-update.1 +31 -144
- data/lib/bundler/man/bundle-update.1.ronn +16 -7
- data/lib/bundler/man/bundle-version.1 +22 -0
- data/lib/bundler/man/bundle-version.1.ronn +24 -0
- data/lib/bundler/man/bundle-viz.1 +9 -18
- data/lib/bundler/man/bundle-viz.1.ronn +9 -3
- data/lib/bundler/man/bundle.1 +17 -51
- data/lib/bundler/man/bundle.1.ronn +12 -7
- data/lib/bundler/man/gemfile.5 +132 -346
- data/lib/bundler/man/gemfile.5.ronn +127 -86
- data/lib/bundler/man/index.txt +8 -0
- data/lib/bundler/match_metadata.rb +17 -0
- data/lib/bundler/match_platform.rb +1 -2
- data/lib/bundler/match_remote_metadata.rb +29 -0
- data/lib/bundler/materialization.rb +59 -0
- data/lib/bundler/mirror.rb +8 -10
- data/lib/bundler/plugin/api/source.rb +11 -14
- data/lib/bundler/plugin/events.rb +24 -0
- data/lib/bundler/plugin/index.rb +13 -5
- data/lib/bundler/plugin/installer/git.rb +0 -4
- data/lib/bundler/plugin/installer/path.rb +18 -0
- data/lib/bundler/plugin/installer/rubygems.rb +0 -8
- data/lib/bundler/plugin/installer.rb +43 -20
- data/lib/bundler/plugin/source_list.rb +4 -4
- data/lib/bundler/plugin.rb +35 -7
- data/lib/bundler/process_lock.rb +10 -14
- data/lib/bundler/remote_specification.rb +17 -6
- data/lib/bundler/resolver/base.rb +117 -0
- data/lib/bundler/resolver/candidate.rb +82 -0
- data/lib/bundler/resolver/incompatibility.rb +15 -0
- data/lib/bundler/resolver/package.rb +90 -0
- data/lib/bundler/resolver/root.rb +25 -0
- data/lib/bundler/resolver/spec_group.rb +54 -66
- data/lib/bundler/resolver.rb +440 -306
- data/lib/bundler/retry.rb +2 -2
- data/lib/bundler/ruby_dsl.rb +42 -7
- data/lib/bundler/ruby_version.rb +22 -22
- data/lib/bundler/rubygems_ext.rb +323 -84
- data/lib/bundler/rubygems_gem_installer.rb +93 -65
- data/lib/bundler/rubygems_integration.rb +89 -237
- data/lib/bundler/runtime.rb +30 -20
- data/lib/bundler/safe_marshal.rb +31 -0
- data/lib/bundler/self_manager.rb +205 -0
- data/lib/bundler/settings.rb +145 -58
- data/lib/bundler/setup.rb +13 -1
- data/lib/bundler/shared_helpers.rb +94 -51
- data/lib/bundler/source/git/git_proxy.rb +283 -82
- data/lib/bundler/source/git.rb +187 -78
- data/lib/bundler/source/metadata.rb +16 -16
- data/lib/bundler/source/path/installer.rb +1 -22
- data/lib/bundler/source/path.rb +17 -27
- data/lib/bundler/source/rubygems/remote.rb +1 -1
- data/lib/bundler/source/rubygems.rb +165 -245
- data/lib/bundler/source/rubygems_aggregate.rb +1 -1
- data/lib/bundler/source.rb +7 -6
- data/lib/bundler/source_list.rb +41 -33
- data/lib/bundler/source_map.rb +15 -2
- data/lib/bundler/spec_set.rb +193 -58
- data/lib/bundler/stub_specification.rb +39 -7
- data/lib/bundler/templates/Executable +3 -5
- data/lib/bundler/templates/Executable.bundler +7 -12
- data/lib/bundler/templates/Executable.standalone +4 -4
- data/lib/bundler/templates/Gemfile +0 -2
- data/lib/bundler/templates/newgem/CODE_OF_CONDUCT.md.tt +77 -29
- data/lib/bundler/templates/newgem/Cargo.toml.tt +7 -0
- data/lib/bundler/templates/newgem/Gemfile.tt +5 -2
- data/lib/bundler/templates/newgem/README.md.tt +12 -12
- data/lib/bundler/templates/newgem/Rakefile.tt +28 -4
- data/lib/bundler/templates/newgem/bin/console.tt +0 -4
- data/lib/bundler/templates/newgem/circleci/config.yml.tt +12 -0
- data/lib/bundler/templates/newgem/ext/newgem/Cargo.toml.tt +15 -0
- data/lib/bundler/templates/newgem/ext/newgem/extconf-c.rb.tt +10 -0
- data/lib/bundler/templates/newgem/ext/newgem/extconf-rust.rb.tt +6 -0
- data/lib/bundler/templates/newgem/ext/newgem/newgem.c.tt +1 -1
- data/lib/bundler/templates/newgem/ext/newgem/src/lib.rs.tt +12 -0
- data/lib/bundler/templates/newgem/github/workflows/main.yml.tt +20 -10
- data/lib/bundler/templates/newgem/gitignore.tt +3 -0
- data/lib/bundler/templates/newgem/gitlab-ci.yml.tt +13 -4
- data/lib/bundler/templates/newgem/newgem.gemspec.tt +26 -18
- data/lib/bundler/templates/newgem/rubocop.yml.tt +0 -5
- data/lib/bundler/templates/newgem/sig/newgem.rbs.tt +8 -0
- data/lib/bundler/templates/newgem/standard.yml.tt +3 -0
- data/lib/bundler/templates/newgem/test/minitest/{newgem_test.rb.tt → test_newgem.rb.tt} +1 -1
- data/lib/bundler/ui/rg_proxy.rb +1 -1
- data/lib/bundler/ui/shell.rb +61 -16
- data/lib/bundler/ui/silent.rb +33 -6
- data/lib/bundler/uri_credentials_filter.rb +3 -3
- data/lib/bundler/uri_normalizer.rb +23 -0
- data/lib/bundler/vendor/.document +1 -0
- data/lib/bundler/vendor/connection_pool/.document +1 -0
- data/lib/bundler/vendor/connection_pool/LICENSE +20 -0
- data/lib/bundler/vendor/connection_pool/lib/connection_pool/timed_stack.rb +19 -21
- data/lib/bundler/vendor/connection_pool/lib/connection_pool/version.rb +1 -1
- data/lib/bundler/vendor/connection_pool/lib/connection_pool/wrapper.rb +56 -0
- data/lib/bundler/vendor/connection_pool/lib/connection_pool.rb +92 -78
- data/lib/bundler/vendor/fileutils/.document +1 -0
- data/lib/bundler/vendor/fileutils/COPYING +56 -0
- data/lib/bundler/vendor/fileutils/lib/fileutils.rb +1350 -418
- data/lib/bundler/vendor/net-http-persistent/.document +1 -0
- data/lib/bundler/vendor/net-http-persistent/README.rdoc +82 -0
- data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent/connection.rb +4 -3
- data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent/pool.rb +23 -11
- data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent/timed_stack_multi.rb +1 -1
- data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent.rb +102 -64
- data/lib/bundler/vendor/pub_grub/.document +1 -0
- data/lib/bundler/vendor/pub_grub/LICENSE.txt +21 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/assignment.rb +20 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/basic_package_source.rb +189 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/failure_writer.rb +182 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/incompatibility.rb +150 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/package.rb +43 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/partial_solution.rb +121 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/rubygems.rb +45 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/solve_failure.rb +19 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/static_package_source.rb +61 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/term.rb +105 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/version.rb +3 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/version_constraint.rb +129 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/version_range.rb +411 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/version_solver.rb +248 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub/version_union.rb +178 -0
- data/lib/bundler/vendor/pub_grub/lib/pub_grub.rb +31 -0
- data/lib/bundler/vendor/securerandom/.document +1 -0
- data/lib/bundler/vendor/securerandom/COPYING +56 -0
- data/lib/bundler/vendor/securerandom/lib/securerandom.rb +102 -0
- data/lib/bundler/vendor/thor/.document +1 -0
- data/lib/bundler/vendor/thor/LICENSE.md +20 -0
- data/lib/bundler/vendor/thor/lib/thor/actions/create_file.rb +3 -2
- data/lib/bundler/vendor/thor/lib/thor/actions/directory.rb +1 -1
- data/lib/bundler/vendor/thor/lib/thor/actions/empty_directory.rb +1 -1
- data/lib/bundler/vendor/thor/lib/thor/actions/file_manipulation.rb +15 -19
- data/lib/bundler/vendor/thor/lib/thor/actions/inject_into_file.rb +16 -6
- data/lib/bundler/vendor/thor/lib/thor/actions.rb +21 -17
- data/lib/bundler/vendor/thor/lib/thor/base.rb +140 -14
- data/lib/bundler/vendor/thor/lib/thor/command.rb +13 -4
- data/lib/bundler/vendor/thor/lib/thor/core_ext/hash_with_indifferent_access.rb +10 -0
- data/lib/bundler/vendor/thor/lib/thor/error.rb +16 -20
- data/lib/bundler/vendor/thor/lib/thor/group.rb +12 -1
- data/lib/bundler/vendor/thor/lib/thor/invocation.rb +1 -1
- data/lib/bundler/vendor/thor/lib/thor/nested_context.rb +2 -2
- data/lib/bundler/vendor/thor/lib/thor/parser/argument.rb +17 -1
- data/lib/bundler/vendor/thor/lib/thor/parser/arguments.rb +33 -17
- data/lib/bundler/vendor/thor/lib/thor/parser/option.rb +28 -9
- data/lib/bundler/vendor/thor/lib/thor/parser/options.rb +65 -8
- data/lib/bundler/vendor/thor/lib/thor/rake_compat.rb +2 -2
- data/lib/bundler/vendor/thor/lib/thor/runner.rb +40 -30
- data/lib/bundler/vendor/thor/lib/thor/shell/basic.rb +56 -162
- data/lib/bundler/vendor/thor/lib/thor/shell/color.rb +1 -46
- data/lib/bundler/vendor/thor/lib/thor/shell/column_printer.rb +29 -0
- data/lib/bundler/vendor/thor/lib/thor/shell/html.rb +1 -46
- data/lib/bundler/vendor/thor/lib/thor/shell/table_printer.rb +118 -0
- data/lib/bundler/vendor/thor/lib/thor/shell/terminal.rb +42 -0
- data/lib/bundler/vendor/thor/lib/thor/shell/wrapped_printer.rb +38 -0
- data/lib/bundler/vendor/thor/lib/thor/shell.rb +2 -2
- data/lib/bundler/vendor/thor/lib/thor/util.rb +9 -8
- data/lib/bundler/vendor/thor/lib/thor/version.rb +1 -1
- data/lib/bundler/vendor/thor/lib/thor.rb +166 -8
- data/lib/bundler/vendor/tsort/.document +1 -0
- data/lib/bundler/vendor/tsort/LICENSE.txt +22 -0
- data/lib/bundler/vendor/tsort/lib/tsort.rb +455 -0
- data/lib/bundler/vendor/uri/.document +1 -0
- data/lib/bundler/vendor/uri/COPYING +56 -0
- data/lib/bundler/vendor/uri/lib/uri/common.rb +351 -219
- data/lib/bundler/vendor/uri/lib/uri/file.rb +10 -4
- data/lib/bundler/vendor/uri/lib/uri/ftp.rb +3 -3
- data/lib/bundler/vendor/uri/lib/uri/generic.rb +49 -39
- data/lib/bundler/vendor/uri/lib/uri/http.rb +40 -3
- data/lib/bundler/vendor/uri/lib/uri/https.rb +2 -2
- data/lib/bundler/vendor/uri/lib/uri/ldap.rb +2 -2
- data/lib/bundler/vendor/uri/lib/uri/ldaps.rb +2 -1
- data/lib/bundler/vendor/uri/lib/uri/mailto.rb +2 -3
- data/lib/bundler/vendor/uri/lib/uri/rfc2396_parser.rb +26 -26
- data/lib/bundler/vendor/uri/lib/uri/rfc3986_parser.rb +131 -50
- data/lib/bundler/vendor/uri/lib/uri/version.rb +1 -1
- data/lib/bundler/vendor/uri/lib/uri/ws.rb +83 -0
- data/lib/bundler/vendor/uri/lib/uri/wss.rb +23 -0
- data/lib/bundler/vendor/uri/lib/uri.rb +12 -12
- data/lib/bundler/vendored_net_http.rb +23 -0
- data/lib/bundler/vendored_persistent.rb +0 -36
- data/lib/bundler/{vendored_molinillo.rb → vendored_pub_grub.rb} +1 -1
- data/lib/bundler/vendored_securerandom.rb +12 -0
- data/lib/bundler/vendored_timeout.rb +12 -0
- data/lib/bundler/{vendored_tmpdir.rb → vendored_tsort.rb} +1 -1
- data/lib/bundler/vendored_uri.rb +18 -1
- data/lib/bundler/version.rb +5 -1
- data/lib/bundler/vlad.rb +1 -1
- data/lib/bundler/worker.rb +7 -9
- data/lib/bundler/yaml_serializer.rb +22 -13
- data/lib/bundler.rb +176 -151
- metadata +98 -41
- data/lib/bundler/dep_proxy.rb +0 -55
- data/lib/bundler/gemdeps.rb +0 -29
- data/lib/bundler/psyched_yaml.rb +0 -22
- data/lib/bundler/templates/gems.rb +0 -8
- data/lib/bundler/templates/newgem/ext/newgem/extconf.rb.tt +0 -5
- data/lib/bundler/templates/newgem/travis.yml.tt +0 -6
- data/lib/bundler/vendor/connection_pool/lib/connection_pool/monotonic_time.rb +0 -66
- data/lib/bundler/vendor/molinillo/lib/molinillo/delegates/resolution_state.rb +0 -57
- data/lib/bundler/vendor/molinillo/lib/molinillo/delegates/specification_provider.rb +0 -88
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/action.rb +0 -36
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb +0 -66
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_vertex.rb +0 -62
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/delete_edge.rb +0 -63
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb +0 -61
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/log.rb +0 -126
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/set_payload.rb +0 -46
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/tag.rb +0 -36
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/vertex.rb +0 -164
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph.rb +0 -255
- data/lib/bundler/vendor/molinillo/lib/molinillo/errors.rb +0 -143
- data/lib/bundler/vendor/molinillo/lib/molinillo/gem_metadata.rb +0 -6
- data/lib/bundler/vendor/molinillo/lib/molinillo/modules/specification_provider.rb +0 -112
- data/lib/bundler/vendor/molinillo/lib/molinillo/modules/ui.rb +0 -67
- data/lib/bundler/vendor/molinillo/lib/molinillo/resolution.rb +0 -839
- data/lib/bundler/vendor/molinillo/lib/molinillo/resolver.rb +0 -46
- data/lib/bundler/vendor/molinillo/lib/molinillo/state.rb +0 -58
- data/lib/bundler/vendor/molinillo/lib/molinillo.rb +0 -11
- data/lib/bundler/vendor/tmpdir/lib/tmpdir.rb +0 -154
- data/lib/bundler/version_ranges.rb +0 -122
@@ -17,7 +17,11 @@ module Bundler
|
|
17
17
|
if v.is_a?(Hash)
|
18
18
|
yaml << dump_hash(v).gsub(/^(?!$)/, " ") # indent all non-empty lines
|
19
19
|
elsif v.is_a?(Array) # Expected to be array of strings
|
20
|
-
|
20
|
+
if v.empty?
|
21
|
+
yaml << " []\n"
|
22
|
+
else
|
23
|
+
yaml << "\n- " << v.map {|s| s.to_s.gsub(/\s+/, " ").inspect }.join("\n- ") << "\n"
|
24
|
+
end
|
21
25
|
else
|
22
26
|
yaml << " " << v.to_s.gsub(/\s+/, " ").inspect << "\n"
|
23
27
|
end
|
@@ -32,30 +36,31 @@ module Bundler
|
|
32
36
|
(.*) # value
|
33
37
|
\1 # matching closing quote
|
34
38
|
$
|
35
|
-
/xo
|
39
|
+
/xo
|
36
40
|
|
37
41
|
HASH_REGEX = /
|
38
42
|
^
|
39
43
|
([ ]*) # indentations
|
40
|
-
(
|
44
|
+
([^#]+) # key excludes comment char '#'
|
41
45
|
(?::(?=(?:\s|$))) # : (without the lookahead the #key includes this when : is present in value)
|
42
46
|
[ ]?
|
43
47
|
(['"]?) # optional opening quote
|
44
48
|
(.*) # value
|
45
49
|
\3 # matching closing quote
|
46
50
|
$
|
47
|
-
/xo
|
51
|
+
/xo
|
48
52
|
|
49
53
|
def load(str)
|
50
54
|
res = {}
|
51
55
|
stack = [res]
|
52
56
|
last_hash = nil
|
53
57
|
last_empty_key = nil
|
54
|
-
str.split(/\r?\n/)
|
58
|
+
str.split(/\r?\n/) do |line|
|
55
59
|
if match = HASH_REGEX.match(line)
|
56
60
|
indent, key, quote, val = match.captures
|
57
|
-
|
58
|
-
|
61
|
+
val = strip_comment(val)
|
62
|
+
|
63
|
+
depth = indent.size / 2
|
59
64
|
if quote.empty? && val.empty?
|
60
65
|
new_hash = {}
|
61
66
|
stack[depth][key] = new_hash
|
@@ -63,10 +68,13 @@ module Bundler
|
|
63
68
|
last_empty_key = key
|
64
69
|
last_hash = stack[depth]
|
65
70
|
else
|
71
|
+
val = [] if val == "[]" # empty array
|
66
72
|
stack[depth][key] = val
|
67
73
|
end
|
68
74
|
elsif match = ARRAY_REGEX.match(line)
|
69
75
|
_, val = match.captures
|
76
|
+
val = strip_comment(val)
|
77
|
+
|
70
78
|
last_hash[last_empty_key] = [] unless last_hash[last_empty_key].is_a?(Array)
|
71
79
|
|
72
80
|
last_hash[last_empty_key].push(val)
|
@@ -75,15 +83,16 @@ module Bundler
|
|
75
83
|
res
|
76
84
|
end
|
77
85
|
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
86
|
+
def strip_comment(val)
|
87
|
+
if val.include?("#") && !val.start_with?("#")
|
88
|
+
val.split("#", 2).first.strip
|
89
|
+
else
|
90
|
+
val
|
91
|
+
end
|
83
92
|
end
|
84
93
|
|
85
94
|
class << self
|
86
|
-
private :dump_hash
|
95
|
+
private :dump_hash
|
87
96
|
end
|
88
97
|
end
|
89
98
|
end
|
data/lib/bundler.rb
CHANGED
@@ -10,16 +10,15 @@ require_relative "bundler/plugin"
|
|
10
10
|
require_relative "bundler/rubygems_ext"
|
11
11
|
require_relative "bundler/rubygems_integration"
|
12
12
|
require_relative "bundler/version"
|
13
|
-
require_relative "bundler/constants"
|
14
13
|
require_relative "bundler/current_ruby"
|
15
14
|
require_relative "bundler/build_metadata"
|
16
15
|
|
17
16
|
# Bundler provides a consistent environment for Ruby projects by
|
18
17
|
# tracking and installing the exact gems and versions that are needed.
|
19
18
|
#
|
20
|
-
#
|
19
|
+
# Bundler is a part of Ruby's standard library.
|
21
20
|
#
|
22
|
-
#
|
21
|
+
# Bundler is used by creating _gemfiles_ listing all the project dependencies
|
23
22
|
# and (optionally) their versions and then using
|
24
23
|
#
|
25
24
|
# require 'bundler/setup'
|
@@ -37,17 +36,22 @@ module Bundler
|
|
37
36
|
environment_preserver = EnvironmentPreserver.from_env
|
38
37
|
ORIGINAL_ENV = environment_preserver.restore
|
39
38
|
environment_preserver.replace_with_backup
|
40
|
-
SUDO_MUTEX = Mutex.new
|
39
|
+
SUDO_MUTEX = Thread::Mutex.new
|
41
40
|
|
41
|
+
autoload :Checksum, File.expand_path("bundler/checksum", __dir__)
|
42
|
+
autoload :CLI, File.expand_path("bundler/cli", __dir__)
|
43
|
+
autoload :CIDetector, File.expand_path("bundler/ci_detector", __dir__)
|
44
|
+
autoload :CompactIndexClient, File.expand_path("bundler/compact_index_client", __dir__)
|
42
45
|
autoload :Definition, File.expand_path("bundler/definition", __dir__)
|
43
46
|
autoload :Dependency, File.expand_path("bundler/dependency", __dir__)
|
44
|
-
autoload :DepProxy, File.expand_path("bundler/dep_proxy", __dir__)
|
45
47
|
autoload :Deprecate, File.expand_path("bundler/deprecate", __dir__)
|
48
|
+
autoload :Digest, File.expand_path("bundler/digest", __dir__)
|
46
49
|
autoload :Dsl, File.expand_path("bundler/dsl", __dir__)
|
47
50
|
autoload :EndpointSpecification, File.expand_path("bundler/endpoint_specification", __dir__)
|
48
51
|
autoload :Env, File.expand_path("bundler/env", __dir__)
|
49
52
|
autoload :Fetcher, File.expand_path("bundler/fetcher", __dir__)
|
50
53
|
autoload :FeatureFlag, File.expand_path("bundler/feature_flag", __dir__)
|
54
|
+
autoload :FREEBSD, File.expand_path("bundler/constants", __dir__)
|
51
55
|
autoload :GemHelper, File.expand_path("bundler/gem_helper", __dir__)
|
52
56
|
autoload :GemHelpers, File.expand_path("bundler/gem_helpers", __dir__)
|
53
57
|
autoload :GemVersionPromoter, File.expand_path("bundler/gem_version_promoter", __dir__)
|
@@ -57,7 +61,9 @@ module Bundler
|
|
57
61
|
autoload :Installer, File.expand_path("bundler/installer", __dir__)
|
58
62
|
autoload :LazySpecification, File.expand_path("bundler/lazy_specification", __dir__)
|
59
63
|
autoload :LockfileParser, File.expand_path("bundler/lockfile_parser", __dir__)
|
60
|
-
autoload :
|
64
|
+
autoload :MatchRemoteMetadata, File.expand_path("bundler/match_remote_metadata", __dir__)
|
65
|
+
autoload :Materialization, File.expand_path("bundler/materialization", __dir__)
|
66
|
+
autoload :NULL, File.expand_path("bundler/constants", __dir__)
|
61
67
|
autoload :ProcessLock, File.expand_path("bundler/process_lock", __dir__)
|
62
68
|
autoload :RemoteSpecification, File.expand_path("bundler/remote_specification", __dir__)
|
63
69
|
autoload :Resolver, File.expand_path("bundler/resolver", __dir__)
|
@@ -65,6 +71,7 @@ module Bundler
|
|
65
71
|
autoload :RubyDsl, File.expand_path("bundler/ruby_dsl", __dir__)
|
66
72
|
autoload :RubyVersion, File.expand_path("bundler/ruby_version", __dir__)
|
67
73
|
autoload :Runtime, File.expand_path("bundler/runtime", __dir__)
|
74
|
+
autoload :SelfManager, File.expand_path("bundler/self_manager", __dir__)
|
68
75
|
autoload :Settings, File.expand_path("bundler/settings", __dir__)
|
69
76
|
autoload :SharedHelpers, File.expand_path("bundler/shared_helpers", __dir__)
|
70
77
|
autoload :Source, File.expand_path("bundler/source", __dir__)
|
@@ -74,11 +81,13 @@ module Bundler
|
|
74
81
|
autoload :StubSpecification, File.expand_path("bundler/stub_specification", __dir__)
|
75
82
|
autoload :UI, File.expand_path("bundler/ui", __dir__)
|
76
83
|
autoload :URICredentialsFilter, File.expand_path("bundler/uri_credentials_filter", __dir__)
|
77
|
-
autoload :
|
84
|
+
autoload :URINormalizer, File.expand_path("bundler/uri_normalizer", __dir__)
|
85
|
+
autoload :WINDOWS, File.expand_path("bundler/constants", __dir__)
|
86
|
+
autoload :SafeMarshal, File.expand_path("bundler/safe_marshal", __dir__)
|
78
87
|
|
79
88
|
class << self
|
80
89
|
def configure
|
81
|
-
@
|
90
|
+
@configure ||= configure_gem_home_and_path
|
82
91
|
end
|
83
92
|
|
84
93
|
def ui
|
@@ -95,6 +104,15 @@ module Bundler
|
|
95
104
|
@bundle_path ||= Pathname.new(configured_bundle_path.path).expand_path(root)
|
96
105
|
end
|
97
106
|
|
107
|
+
def create_bundle_path
|
108
|
+
mkdir_p(bundle_path) unless bundle_path.exist?
|
109
|
+
|
110
|
+
@bundle_path = bundle_path.realpath
|
111
|
+
rescue Errno::EEXIST
|
112
|
+
raise PathError, "Could not install to path `#{bundle_path}` " \
|
113
|
+
"because a file already exists at that path. Either remove or rename the file so the directory can be created."
|
114
|
+
end
|
115
|
+
|
98
116
|
def configured_bundle_path
|
99
117
|
@configured_bundle_path ||= settings.path.tap(&:validate!)
|
100
118
|
end
|
@@ -104,7 +122,7 @@ module Bundler
|
|
104
122
|
@bin_path ||= begin
|
105
123
|
path = settings[:bin] || "bin"
|
106
124
|
path = Pathname.new(path).expand_path(root).expand_path
|
107
|
-
|
125
|
+
mkdir_p(path)
|
108
126
|
path
|
109
127
|
end
|
110
128
|
end
|
@@ -152,6 +170,29 @@ module Bundler
|
|
152
170
|
end
|
153
171
|
end
|
154
172
|
|
173
|
+
def auto_switch
|
174
|
+
self_manager.restart_with_locked_bundler_if_needed
|
175
|
+
end
|
176
|
+
|
177
|
+
# Automatically install dependencies if Bundler.settings[:auto_install] exists.
|
178
|
+
# This is set through config cmd `bundle config set --global auto_install 1`.
|
179
|
+
#
|
180
|
+
# Note that this method `nil`s out the global Definition object, so it
|
181
|
+
# should be called first, before you instantiate anything like an
|
182
|
+
# `Installer` that'll keep a reference to the old one instead.
|
183
|
+
def auto_install
|
184
|
+
return unless settings[:auto_install]
|
185
|
+
|
186
|
+
begin
|
187
|
+
definition.specs
|
188
|
+
rescue GemNotFound, GitError
|
189
|
+
ui.info "Automatically installing missing gems."
|
190
|
+
reset!
|
191
|
+
CLI::Install.new({}).run
|
192
|
+
reset!
|
193
|
+
end
|
194
|
+
end
|
195
|
+
|
155
196
|
# Setups Bundler environment (see Bundler.setup) if it is not already set,
|
156
197
|
# and loads all gems from groups specified. Unlike ::setup, can be called
|
157
198
|
# multiple times with different groups (if they were allowed by setup).
|
@@ -171,6 +212,7 @@ module Bundler
|
|
171
212
|
# Bundler.require(:test) # requires second_gem
|
172
213
|
#
|
173
214
|
def require(*groups)
|
215
|
+
load_plugins
|
174
216
|
setup(*groups).require(*groups)
|
175
217
|
end
|
176
218
|
|
@@ -179,7 +221,7 @@ module Bundler
|
|
179
221
|
end
|
180
222
|
|
181
223
|
def environment
|
182
|
-
SharedHelpers.major_deprecation 2, "Bundler.environment has been removed in favor of Bundler.load", :
|
224
|
+
SharedHelpers.major_deprecation 2, "Bundler.environment has been removed in favor of Bundler.load", print_caller_location: true
|
183
225
|
load
|
184
226
|
end
|
185
227
|
|
@@ -187,19 +229,21 @@ module Bundler
|
|
187
229
|
#
|
188
230
|
# @param unlock [Hash, Boolean, nil] Gems that have been requested
|
189
231
|
# to be updated or true if all gems should be updated
|
232
|
+
# @param lockfile [Pathname] Path to Gemfile.lock
|
190
233
|
# @return [Bundler::Definition]
|
191
|
-
def definition(unlock = nil)
|
234
|
+
def definition(unlock = nil, lockfile = default_lockfile)
|
192
235
|
@definition = nil if unlock
|
193
236
|
@definition ||= begin
|
194
237
|
configure
|
195
|
-
Definition.build(default_gemfile,
|
238
|
+
Definition.build(default_gemfile, lockfile, unlock)
|
196
239
|
end
|
197
240
|
end
|
198
241
|
|
199
242
|
def frozen_bundle?
|
200
|
-
frozen = settings[:
|
201
|
-
frozen
|
202
|
-
|
243
|
+
frozen = settings[:frozen]
|
244
|
+
return frozen unless frozen.nil?
|
245
|
+
|
246
|
+
settings[:deployment]
|
203
247
|
end
|
204
248
|
|
205
249
|
def locked_gems
|
@@ -212,12 +256,6 @@ module Bundler
|
|
212
256
|
end
|
213
257
|
end
|
214
258
|
|
215
|
-
def most_specific_locked_platform?(platform)
|
216
|
-
return false unless defined?(@definition) && @definition
|
217
|
-
|
218
|
-
definition.most_specific_locked_platform == platform
|
219
|
-
end
|
220
|
-
|
221
259
|
def ruby_scope
|
222
260
|
"#{Bundler.rubygems.ruby_engine}/#{RbConfig::CONFIG["ruby_version"]}"
|
223
261
|
end
|
@@ -316,20 +354,12 @@ module Bundler
|
|
316
354
|
|
317
355
|
def rm_rf(path)
|
318
356
|
FileUtils.remove_entry_secure(path) if path && File.exist?(path)
|
319
|
-
rescue ArgumentError
|
320
|
-
message = <<EOF
|
321
|
-
It is a security vulnerability to allow your home directory to be world-writable, and bundler can not continue.
|
322
|
-
You should probably consider fixing this issue by running `chmod o-w ~` on *nix.
|
323
|
-
Please refer to https://ruby-doc.org/stdlib-2.1.2/libdoc/fileutils/rdoc/FileUtils.html#method-c-remove_entry_secure for details.
|
324
|
-
EOF
|
325
|
-
File.world_writable?(path) ? Bundler.ui.warn(message) : raise
|
326
|
-
raise PathError, "Please fix the world-writable issue with your #{path} directory"
|
327
357
|
end
|
328
358
|
|
329
359
|
def settings
|
330
360
|
@settings ||= Settings.new(app_config_path)
|
331
361
|
rescue GemfileNotFound
|
332
|
-
@settings = Settings.new
|
362
|
+
@settings = Settings.new
|
333
363
|
end
|
334
364
|
|
335
365
|
# @return [Hash] Environment present before Bundler was activated
|
@@ -339,40 +369,24 @@ EOF
|
|
339
369
|
|
340
370
|
# @deprecated Use `unbundled_env` instead
|
341
371
|
def clean_env
|
342
|
-
|
343
|
-
2,
|
372
|
+
message =
|
344
373
|
"`Bundler.clean_env` has been deprecated in favor of `Bundler.unbundled_env`. " \
|
345
|
-
"If you instead want the environment before bundler was originally loaded, use `Bundler.original_env`"
|
346
|
-
|
347
|
-
|
348
|
-
|
374
|
+
"If you instead want the environment before bundler was originally loaded, use `Bundler.original_env`"
|
375
|
+
removed_message =
|
376
|
+
"`Bundler.clean_env` has been removed in favor of `Bundler.unbundled_env`. " \
|
377
|
+
"If you instead want the environment before bundler was originally loaded, use `Bundler.original_env`"
|
378
|
+
Bundler::SharedHelpers.major_deprecation(2, message, removed_message: removed_message, print_caller_location: true)
|
349
379
|
unbundled_env
|
350
380
|
end
|
351
381
|
|
352
382
|
# @return [Hash] Environment with all bundler-related variables removed
|
353
383
|
def unbundled_env
|
354
|
-
|
355
|
-
|
356
|
-
if env.key?("BUNDLER_ORIG_MANPATH")
|
357
|
-
env["MANPATH"] = env["BUNDLER_ORIG_MANPATH"]
|
358
|
-
end
|
359
|
-
|
360
|
-
env.delete_if {|k, _| k[0, 7] == "BUNDLE_" }
|
361
|
-
|
362
|
-
if env.key?("RUBYOPT")
|
363
|
-
rubyopt = env["RUBYOPT"].split(" ")
|
364
|
-
rubyopt.delete("-r#{File.expand_path("bundler/setup", __dir__)}")
|
365
|
-
rubyopt.delete("-rbundler/setup")
|
366
|
-
env["RUBYOPT"] = rubyopt.join(" ")
|
367
|
-
end
|
368
|
-
|
369
|
-
if env.key?("RUBYLIB")
|
370
|
-
rubylib = env["RUBYLIB"].split(File::PATH_SEPARATOR)
|
371
|
-
rubylib.delete(File.expand_path("..", __FILE__))
|
372
|
-
env["RUBYLIB"] = rubylib.join(File::PATH_SEPARATOR)
|
373
|
-
end
|
384
|
+
unbundle_env(original_env)
|
385
|
+
end
|
374
386
|
|
375
|
-
|
387
|
+
# Remove all bundler-related variables from ENV
|
388
|
+
def unbundle_env!
|
389
|
+
ENV.replace(unbundle_env(ENV))
|
376
390
|
end
|
377
391
|
|
378
392
|
# Run block with environment present before Bundler was activated
|
@@ -382,13 +396,13 @@ EOF
|
|
382
396
|
|
383
397
|
# @deprecated Use `with_unbundled_env` instead
|
384
398
|
def with_clean_env
|
385
|
-
|
386
|
-
2,
|
399
|
+
message =
|
387
400
|
"`Bundler.with_clean_env` has been deprecated in favor of `Bundler.with_unbundled_env`. " \
|
388
|
-
"If you instead want the environment before bundler was originally loaded, use `Bundler.with_original_env`"
|
389
|
-
|
390
|
-
|
391
|
-
|
401
|
+
"If you instead want the environment before bundler was originally loaded, use `Bundler.with_original_env`"
|
402
|
+
removed_message =
|
403
|
+
"`Bundler.with_clean_env` has been removed in favor of `Bundler.with_unbundled_env`. " \
|
404
|
+
"If you instead want the environment before bundler was originally loaded, use `Bundler.with_original_env`"
|
405
|
+
Bundler::SharedHelpers.major_deprecation(2, message, removed_message: removed_message, print_caller_location: true)
|
392
406
|
with_env(unbundled_env) { yield }
|
393
407
|
end
|
394
408
|
|
@@ -404,13 +418,13 @@ EOF
|
|
404
418
|
|
405
419
|
# @deprecated Use `unbundled_system` instead
|
406
420
|
def clean_system(*args)
|
407
|
-
|
408
|
-
2,
|
421
|
+
message =
|
409
422
|
"`Bundler.clean_system` has been deprecated in favor of `Bundler.unbundled_system`. " \
|
410
|
-
"If you instead want to run the command in the environment before bundler was originally loaded, use `Bundler.original_system`"
|
411
|
-
|
412
|
-
|
413
|
-
|
423
|
+
"If you instead want to run the command in the environment before bundler was originally loaded, use `Bundler.original_system`"
|
424
|
+
removed_message =
|
425
|
+
"`Bundler.clean_system` has been removed in favor of `Bundler.unbundled_system`. " \
|
426
|
+
"If you instead want to run the command in the environment before bundler was originally loaded, use `Bundler.original_system`"
|
427
|
+
Bundler::SharedHelpers.major_deprecation(2, message, removed_message: removed_message, print_caller_location: true)
|
414
428
|
with_env(unbundled_env) { Kernel.system(*args) }
|
415
429
|
end
|
416
430
|
|
@@ -426,13 +440,13 @@ EOF
|
|
426
440
|
|
427
441
|
# @deprecated Use `unbundled_exec` instead
|
428
442
|
def clean_exec(*args)
|
429
|
-
|
430
|
-
2,
|
443
|
+
message =
|
431
444
|
"`Bundler.clean_exec` has been deprecated in favor of `Bundler.unbundled_exec`. " \
|
432
|
-
"If you instead want to exec to a command in the environment before bundler was originally loaded, use `Bundler.original_exec`"
|
433
|
-
|
434
|
-
|
435
|
-
|
445
|
+
"If you instead want to exec to a command in the environment before bundler was originally loaded, use `Bundler.original_exec`"
|
446
|
+
removed_message =
|
447
|
+
"`Bundler.clean_exec` has been removed in favor of `Bundler.unbundled_exec`. " \
|
448
|
+
"If you instead want to exec to a command in the environment before bundler was originally loaded, use `Bundler.original_exec`"
|
449
|
+
Bundler::SharedHelpers.major_deprecation(2, message, removed_message: removed_message, print_caller_location: true)
|
436
450
|
with_env(unbundled_env) { Kernel.exec(*args) }
|
437
451
|
end
|
438
452
|
|
@@ -442,7 +456,7 @@ EOF
|
|
442
456
|
end
|
443
457
|
|
444
458
|
def local_platform
|
445
|
-
return Gem::Platform::RUBY if settings[:force_ruby_platform]
|
459
|
+
return Gem::Platform::RUBY if settings[:force_ruby_platform]
|
446
460
|
Gem::Platform.local
|
447
461
|
end
|
448
462
|
|
@@ -475,80 +489,32 @@ EOF
|
|
475
489
|
configured_bundle_path.use_system_gems?
|
476
490
|
end
|
477
491
|
|
478
|
-
def
|
479
|
-
|
480
|
-
|
481
|
-
sudo_present = which "sudo" if settings.allow_sudo?
|
482
|
-
|
483
|
-
if sudo_present
|
484
|
-
# the bundle path and subdirectories need to be writable for RubyGems
|
485
|
-
# to be able to unpack and install gems without exploding
|
486
|
-
path = bundle_path
|
487
|
-
path = path.parent until path.exist?
|
488
|
-
|
489
|
-
# bins are written to a different location on OS X
|
490
|
-
bin_dir = Pathname.new(Bundler.system_bindir)
|
491
|
-
bin_dir = bin_dir.parent until bin_dir.exist?
|
492
|
-
|
493
|
-
# if any directory is not writable, we need sudo
|
494
|
-
files = [path, bin_dir] | Dir[bundle_path.join("build_info/*").to_s] | Dir[bundle_path.join("*").to_s]
|
495
|
-
unwritable_files = files.reject {|f| File.writable?(f) }
|
496
|
-
sudo_needed = !unwritable_files.empty?
|
497
|
-
if sudo_needed
|
498
|
-
Bundler.ui.warn "Following files may not be writable, so sudo is needed:\n #{unwritable_files.map(&:to_s).sort.join("\n ")}"
|
499
|
-
end
|
500
|
-
end
|
501
|
-
|
502
|
-
@requires_sudo_ran = true
|
503
|
-
@requires_sudo = settings.allow_sudo? && sudo_present && sudo_needed
|
504
|
-
end
|
505
|
-
|
506
|
-
def mkdir_p(path, options = {})
|
507
|
-
if requires_sudo? && !options[:no_sudo]
|
508
|
-
sudo "mkdir -p '#{path}'" unless File.exist?(path)
|
509
|
-
else
|
510
|
-
SharedHelpers.filesystem_access(path, :write) do |p|
|
511
|
-
FileUtils.mkdir_p(p)
|
512
|
-
end
|
492
|
+
def mkdir_p(path)
|
493
|
+
SharedHelpers.filesystem_access(path, :create) do |p|
|
494
|
+
FileUtils.mkdir_p(p)
|
513
495
|
end
|
514
496
|
end
|
515
497
|
|
516
498
|
def which(executable)
|
517
|
-
|
518
|
-
|
519
|
-
|
520
|
-
|
499
|
+
executable_path = find_executable(executable)
|
500
|
+
return executable_path if executable_path
|
501
|
+
|
502
|
+
if (paths = ENV["PATH"])
|
503
|
+
quote = '"'
|
521
504
|
paths.split(File::PATH_SEPARATOR).find do |path|
|
522
505
|
path = path[1..-2] if path.start_with?(quote) && path.end_with?(quote)
|
523
|
-
executable_path = File.expand_path(executable, path)
|
524
|
-
return executable_path if
|
506
|
+
executable_path = find_executable(File.expand_path(executable, path))
|
507
|
+
return executable_path if executable_path
|
525
508
|
end
|
526
509
|
end
|
527
510
|
end
|
528
511
|
|
529
|
-
def
|
530
|
-
|
531
|
-
|
532
|
-
|
533
|
-
You can cancel this installation and run:
|
534
|
-
|
535
|
-
bundle config set --local path 'vendor/bundle'
|
536
|
-
bundle install
|
537
|
-
|
538
|
-
to install the gems into ./vendor/bundle/, or you can enter your password
|
539
|
-
and install the bundled gems to RubyGems using sudo.
|
512
|
+
def find_executable(path)
|
513
|
+
extensions = RbConfig::CONFIG["EXECUTABLE_EXTS"]&.split
|
514
|
+
extensions = [RbConfig::CONFIG["EXEEXT"]] unless extensions&.any?
|
515
|
+
candidates = extensions.map {|ext| "#{path}#{ext}" }
|
540
516
|
|
541
|
-
|
542
|
-
PROMPT
|
543
|
-
|
544
|
-
unless @prompted_for_sudo ||= system(%(sudo -k -p "#{prompt}" true))
|
545
|
-
raise SudoNotPermittedError,
|
546
|
-
"Bundler requires sudo access to install at the moment. " \
|
547
|
-
"Try installing again, granting Bundler sudo access when prompted, or installing into a different path."
|
548
|
-
end
|
549
|
-
|
550
|
-
`sudo -p "#{prompt}" #{str}`
|
551
|
-
end
|
517
|
+
candidates.find {|candidate| File.file?(candidate) && File.executable?(candidate) }
|
552
518
|
end
|
553
519
|
|
554
520
|
def read_file(file)
|
@@ -557,10 +523,17 @@ EOF
|
|
557
523
|
end
|
558
524
|
end
|
559
525
|
|
560
|
-
def
|
561
|
-
|
562
|
-
|
563
|
-
|
526
|
+
def safe_load_marshal(data)
|
527
|
+
if Gem.respond_to?(:load_safe_marshal)
|
528
|
+
Gem.load_safe_marshal
|
529
|
+
begin
|
530
|
+
Gem::SafeMarshal.safe_load(data)
|
531
|
+
rescue Gem::SafeMarshal::Reader::Error, Gem::SafeMarshal::Visitors::ToRuby::Error => e
|
532
|
+
raise MarshalError, "#{e.class}: #{e.message}"
|
533
|
+
end
|
534
|
+
else
|
535
|
+
load_marshal(data, marshal_proc: SafeMarshal.proc)
|
536
|
+
end
|
564
537
|
end
|
565
538
|
|
566
539
|
def load_gemspec(file, validate = false)
|
@@ -569,7 +542,7 @@ EOF
|
|
569
542
|
@gemspec_cache[key] ||= load_gemspec_uncached(file, validate)
|
570
543
|
# Protect against caching side-effected gemspecs by returning a
|
571
544
|
# new instance each time.
|
572
|
-
@gemspec_cache[key]
|
545
|
+
@gemspec_cache[key]&.dup
|
573
546
|
end
|
574
547
|
|
575
548
|
def load_gemspec_uncached(file, validate = false)
|
@@ -596,13 +569,30 @@ EOF
|
|
596
569
|
|
597
570
|
def git_present?
|
598
571
|
return @git_present if defined?(@git_present)
|
599
|
-
@git_present = Bundler.which("git")
|
572
|
+
@git_present = Bundler.which("git")
|
600
573
|
end
|
601
574
|
|
602
575
|
def feature_flag
|
603
576
|
@feature_flag ||= FeatureFlag.new(VERSION)
|
604
577
|
end
|
605
578
|
|
579
|
+
def load_plugins(definition = Bundler.definition)
|
580
|
+
return if defined?(@load_plugins_ran)
|
581
|
+
|
582
|
+
Bundler.rubygems.load_plugins
|
583
|
+
|
584
|
+
requested_path_gems = definition.requested_specs.select {|s| s.source.is_a?(Source::Path) }
|
585
|
+
path_plugin_files = requested_path_gems.flat_map do |spec|
|
586
|
+
spec.matches_for_glob("rubygems_plugin#{Bundler.rubygems.suffix_pattern}")
|
587
|
+
rescue TypeError
|
588
|
+
error_message = "#{spec.name} #{spec.version} has an invalid gemspec"
|
589
|
+
raise Gem::InvalidSpecificationException, error_message
|
590
|
+
end
|
591
|
+
Bundler.rubygems.load_plugin_files(path_plugin_files)
|
592
|
+
Bundler.rubygems.load_env_plugins
|
593
|
+
@load_plugins_ran = true
|
594
|
+
end
|
595
|
+
|
606
596
|
def reset!
|
607
597
|
reset_paths!
|
608
598
|
Plugin.reset!
|
@@ -618,7 +608,7 @@ EOF
|
|
618
608
|
@bin_path = nil
|
619
609
|
@bundler_major_version = nil
|
620
610
|
@bundle_path = nil
|
621
|
-
@
|
611
|
+
@configure = nil
|
622
612
|
@configured_bundle_path = nil
|
623
613
|
@definition = nil
|
624
614
|
@load = nil
|
@@ -642,15 +632,50 @@ EOF
|
|
642
632
|
Bundler.rubygems.clear_paths
|
643
633
|
end
|
644
634
|
|
635
|
+
def self_manager
|
636
|
+
@self_manager ||= begin
|
637
|
+
require_relative "bundler/self_manager"
|
638
|
+
Bundler::SelfManager.new
|
639
|
+
end
|
640
|
+
end
|
641
|
+
|
645
642
|
private
|
646
643
|
|
644
|
+
def unbundle_env(env)
|
645
|
+
if env.key?("BUNDLER_ORIG_MANPATH")
|
646
|
+
env["MANPATH"] = env["BUNDLER_ORIG_MANPATH"]
|
647
|
+
end
|
648
|
+
|
649
|
+
env.delete_if {|k, _| k[0, 7] == "BUNDLE_" }
|
650
|
+
env.delete("BUNDLER_SETUP")
|
651
|
+
|
652
|
+
if env.key?("RUBYOPT")
|
653
|
+
rubyopt = env["RUBYOPT"].split(" ")
|
654
|
+
rubyopt.delete("-r#{File.expand_path("bundler/setup", __dir__)}")
|
655
|
+
rubyopt.delete("-rbundler/setup")
|
656
|
+
env["RUBYOPT"] = rubyopt.join(" ")
|
657
|
+
end
|
658
|
+
|
659
|
+
if env.key?("RUBYLIB")
|
660
|
+
rubylib = env["RUBYLIB"].split(File::PATH_SEPARATOR)
|
661
|
+
rubylib.delete(__dir__)
|
662
|
+
env["RUBYLIB"] = rubylib.join(File::PATH_SEPARATOR)
|
663
|
+
end
|
664
|
+
|
665
|
+
env
|
666
|
+
end
|
667
|
+
|
668
|
+
def load_marshal(data, marshal_proc: nil)
|
669
|
+
Marshal.load(data, marshal_proc)
|
670
|
+
rescue TypeError => e
|
671
|
+
raise MarshalError, "#{e.class}: #{e.message}"
|
672
|
+
end
|
673
|
+
|
647
674
|
def eval_yaml_gemspec(path, contents)
|
648
|
-
|
675
|
+
Kernel.require "psych"
|
649
676
|
|
650
|
-
# If the YAML is invalid, Syck raises an ArgumentError, and Psych
|
651
|
-
# raises a Psych::SyntaxError. See psyched_yaml.rb for more info.
|
652
677
|
Gem::Specification.from_yaml(contents)
|
653
|
-
rescue
|
678
|
+
rescue ::Psych::SyntaxError, ArgumentError, Gem::EndOfYAMLException, Gem::Exception
|
654
679
|
eval_gemspec(path, contents)
|
655
680
|
end
|
656
681
|
|
@@ -659,7 +684,7 @@ EOF
|
|
659
684
|
rescue ScriptError, StandardError => e
|
660
685
|
msg = "There was an error while loading `#{path.basename}`: #{e.message}"
|
661
686
|
|
662
|
-
raise GemspecError, Dsl::DSLError.new(msg, path, e.backtrace, contents)
|
687
|
+
raise GemspecError, Dsl::DSLError.new(msg, path.to_s, e.backtrace, contents)
|
663
688
|
end
|
664
689
|
|
665
690
|
def configure_gem_path
|