opt
/
alt
/
ruby26
/
lib64
/
ruby
/
2.6.0
/
rubygems
/
resolver
/
Go to Home Directory
+
Upload
Create File
root@0UT1S:~$
Execute
By Order of Mr.0UT1S
[DIR] ..
N/A
[DIR] molinillo
N/A
activation_request.rb
3.73 KB
Rename
Delete
api_set.rb
2.46 KB
Rename
Delete
api_specification.rb
2.19 KB
Rename
Delete
best_set.rb
1.61 KB
Rename
Delete
composed_set.rb
1.19 KB
Rename
Delete
conflict.rb
3.35 KB
Rename
Delete
current_set.rb
282 bytes
Rename
Delete
dependency_request.rb
2.29 KB
Rename
Delete
git_set.rb
2.88 KB
Rename
Delete
git_specification.rb
1.27 KB
Rename
Delete
index_set.rb
1.41 KB
Rename
Delete
index_specification.rb
1.48 KB
Rename
Delete
installed_specification.rb
1.22 KB
Rename
Delete
installer_set.rb
5.02 KB
Rename
Delete
local_specification.rb
807 bytes
Rename
Delete
lock_set.rb
1.67 KB
Rename
Delete
lock_specification.rb
1.81 KB
Rename
Delete
molinillo.rb
82 bytes
Rename
Delete
requirement_list.rb
1.34 KB
Rename
Delete
set.rb
1.24 KB
Rename
Delete
source_set.rb
902 bytes
Rename
Delete
spec_specification.rb
1.06 KB
Rename
Delete
specification.rb
2.33 KB
Rename
Delete
stats.rb
957 bytes
Rename
Delete
vendor_set.rb
1.91 KB
Rename
Delete
vendor_specification.rb
581 bytes
Rename
Delete
# frozen_string_literal: true ## # The global rubygems pool, available via the rubygems.org API. # Returns instances of APISpecification. class Gem::Resolver::APISet < Gem::Resolver::Set ## # The URI for the dependency API this APISet uses. attr_reader :dep_uri # :nodoc: ## # The Gem::Source that gems are fetched from attr_reader :source ## # The corresponding place to fetch gems. attr_reader :uri ## # Creates a new APISet that will retrieve gems from +uri+ using the RubyGems # API URL +dep_uri+ which is described at # http://guides.rubygems.org/rubygems-org-api def initialize(dep_uri = 'https://rubygems.org/api/v1/dependencies') super() dep_uri = URI dep_uri unless URI === dep_uri # for ruby 1.8 @dep_uri = dep_uri @uri = dep_uri + '../..' @data = Hash.new { |h,k| h[k] = [] } @source = Gem::Source.new @uri @to_fetch = [] end ## # Return an array of APISpecification objects matching # DependencyRequest +req+. def find_all(req) res = [] return res unless @remote if @to_fetch.include?(req.name) prefetch_now end versions(req.name).each do |ver| if req.dependency.match? req.name, ver[:number] res << Gem::Resolver::APISpecification.new(self, ver) end end res end ## # A hint run by the resolver to allow the Set to fetch # data for DependencyRequests +reqs+. def prefetch(reqs) return unless @remote names = reqs.map { |r| r.dependency.name } needed = names - @data.keys - @to_fetch @to_fetch += needed end def prefetch_now # :nodoc: needed, @to_fetch = @to_fetch, [] uri = @dep_uri + "?gems=#{needed.sort.join ','}" str = Gem::RemoteFetcher.fetcher.fetch_path uri loaded = [] Marshal.load(str).each do |ver| name = ver[:name] @data[name] << ver loaded << name end (needed - loaded).each do |missing| @data[missing] = [] end end def pretty_print(q) # :nodoc: q.group 2, '[APISet', ']' do q.breakable q.text "URI: #{@dep_uri}" q.breakable q.text 'gem names:' q.pp @data.keys end end ## # Return data for all versions of the gem +name+. def versions(name) # :nodoc: if @data.key?(name) return @data[name] end uri = @dep_uri + "?gems=#{name}" str = Gem::RemoteFetcher.fetcher.fetch_path uri Marshal.load(str).each do |ver| @data[ver[:name]] << ver end @data[name] end end
Save