mirror of
https://github.com/ruby/ruby.git
synced 2025-08-24 13:34:17 +02:00

After digging into git history a bit, I figure this was about unifying
`bundle cache` and `bundle package`, which already happened a while ago.
So remove this TODO since it's now misleading.
5a0b06b84d
42 lines
1 KiB
Ruby
42 lines
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
|
|
|
|
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
|