mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
4f5eb48dea
This is a regression from https://github.com/rubygems/rubygems/commit/cf749f8ffabd. The funny thing is that we have a spec for this feature, so it was unclear how we regressed here. It turns out there was a bug in one of our negative matchers checking that gems ARE NOT included in a bundle. This commit fixes the bug in the negative matcher and reverts https://github.com/rubygems/rubygems/commit/cf749f8ffabd (with a slightly simpler diff). https://github.com/rubygems/rubygems/commit/3f9a4ff32a
43 lines
1.1 KiB
Ruby
43 lines
1.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Bundler
|
|
class CLI::Cache
|
|
attr_reader :options
|
|
|
|
def initialize(options)
|
|
@options = options
|
|
end
|
|
|
|
def run
|
|
Bundler.ui.level = "warn" if options[:quiet]
|
|
Bundler.settings.set_command_option_if_given :path, options[:path]
|
|
Bundler.settings.set_command_option_if_given :cache_path, options["cache-path"]
|
|
|
|
setup_cache_all
|
|
install
|
|
|
|
# TODO: move cache contents here now that all bundles are locked
|
|
custom_path = Bundler.settings[:path] if options[:path]
|
|
|
|
Bundler.settings.temporary(:cache_all_platforms => options["all-platforms"]) do
|
|
Bundler.load.cache(custom_path)
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def install
|
|
require_relative "install"
|
|
options = self.options.dup
|
|
options["local"] = false if Bundler.settings[:cache_all_platforms]
|
|
options["no-cache"] = true
|
|
Bundler::CLI::Install.new(options).run
|
|
end
|
|
|
|
def setup_cache_all
|
|
all = options.fetch(:all, Bundler.feature_flag.cache_all? || nil)
|
|
|
|
Bundler.settings.set_command_option_if_given :cache_all, all
|
|
end
|
|
end
|
|
end
|