class Bundler::Fetcher::CompactIndex
常量
- ClientFetcher
公共类方法
compact_index_request(method_name) 点击切换源代码
# File bundler/fetcher/compact_index.rb, line 9 def self.compact_index_request(method_name) method = instance_method(method_name) undef_method(method_name) define_method(method_name) do |*args, &blk| method.bind_call(self, *args, &blk) rescue NetworkDownError, CompactIndexClient::Updater::MismatchedChecksumError => e raise HTTPError, e.message rescue AuthenticationRequiredError, BadAuthenticationError # Fail since we got a 401 from the server. raise rescue HTTPError => e Bundler.ui.trace(e) nil end end
公共实例方法
api_fetcher?() 点击切换源代码
# File bundler/fetcher/compact_index.rb, line 62 def api_fetcher? true end
available?() 点击切换源代码
# File bundler/fetcher/compact_index.rb, line 49 def available? unless SharedHelpers.md5_available? Bundler.ui.debug("FIPS mode is enabled, bundler can't use the CompactIndex API") return nil end # Read info file checksums out of /versions, so we can know if gems are up to date compact_index_client.available? rescue CompactIndexClient::Updater::MismatchedChecksumError => e Bundler.ui.debug(e.message) nil end
specs(gem_names) 点击切换源代码
# File bundler/fetcher/compact_index.rb, line 25 def specs(gem_names) specs_for_names(gem_names) end
specs_for_names(gem_names) 点击切换源代码
# File bundler/fetcher/compact_index.rb, line 30 def specs_for_names(gem_names) gem_info = [] complete_gems = [] remaining_gems = gem_names.dup until remaining_gems.empty? log_specs { "Looking up gems #{remaining_gems.inspect}" } deps = fetch_gem_infos(remaining_gems).flatten(1) next_gems = deps.flat_map {|d| d[CompactIndexClient::INFO_DEPS].flat_map(&:first) }.uniq deps.each {|dep| gem_info << dep } complete_gems.concat(deps.map(&:first)).uniq! remaining_gems = next_gems - complete_gems end @bundle_worker&.stop @bundle_worker = nil # reset it. Not sure if necessary gem_info end
私有实例方法
bundle_worker(func = nil) 点击切换源代码
# File bundler/fetcher/compact_index.rb, line 91 def bundle_worker(func = nil) @bundle_worker ||= begin worker_name = "Compact Index (#{display_uri.host})" Bundler::Worker.new(Bundler.settings.processor_count, worker_name, func) end @bundle_worker.tap do |worker| worker.instance_variable_set(:@func, func) if func end end
cache_path() 点击切换源代码
# File bundler/fetcher/compact_index.rb, line 101 def cache_path Bundler.user_cache.join("compact_index", remote.cache_slug) end
client_fetcher() 点击切换源代码
# File bundler/fetcher/compact_index.rb, line 105 def client_fetcher ClientFetcher.new(self, Bundler.ui) end
compact_index_client() 点击切换源代码
# File bundler/fetcher/compact_index.rb, line 68 def compact_index_client @compact_index_client ||= SharedHelpers.filesystem_access(cache_path) do CompactIndexClient.new(cache_path, client_fetcher) end end
fetch_gem_infos(names) 点击切换源代码
# File bundler/fetcher/compact_index.rb, line 75 def fetch_gem_infos(names) in_parallel(names) {|name| compact_index_client.info(name) } rescue TooManyRequestsError # rubygems.org is rate limiting us, slow down. @bundle_worker&.stop @bundle_worker = nil # reset it. Not sure if necessary compact_index_client.reset! names.map {|name| compact_index_client.info(name) } end
in_parallel(inputs, &blk) 点击切换源代码
# File bundler/fetcher/compact_index.rb, line 84 def in_parallel(inputs, &blk) func = lambda {|object, _index| blk.call(object) } worker = bundle_worker(func) inputs.each {|input| worker.enq(input) } inputs.map { worker.deq } end