class Gem::Resolver::APISet

The global rubygems pool, available via the rubygems.org API. Returns instances of APISpecification.

Attributes

source [R]

The Gem::Source that gems are fetched from

uri [R]

The corresponding place to fetch gems.

Public Class Methods

new (dep_uri = "https://index.rubygems.org/info/")

Creates a new APISet that will retrieve gems from uri using the RubyGems API URL dep_uri which is described at guides.rubygems.org/rubygems-org-api

Calls superclass method BasicObject::new
# File lib/rubygems/resolver/api_set.rb, line 30
def initialize(dep_uri = "https://index.rubygems.org/info/")
  super()

  dep_uri = Gem::URI dep_uri unless Gem::URI === dep_uri

  @dep_uri = dep_uri
  @uri     = dep_uri + ".."

  @data   = Hash.new {|h,k| h[k] = [] }
  @source = Gem::Source.new @uri

  @to_fetch = []
end

Public Instance Methods

find_all (req)

Return an array of APISpecification objects matching DependencyRequest req.

# File lib/rubygems/resolver/api_set.rb, line 48
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], @prerelease
      res << Gem::Resolver::APISpecification.new(self, ver)
    end
  end

  res
end
prefetch (reqs)

A hint run by the resolver to allow the Set to fetch data for DependencyRequests reqs.

# File lib/rubygems/resolver/api_set.rb, line 70
def prefetch(reqs)
  return unless @remote
  names = reqs.map {|r| r.dependency.name }
  needed = names - @data.keys - @to_fetch

  @to_fetch += needed
end