2013-07-09 19:21:36 -04:00
|
|
|
##
|
|
|
|
# The global rubygems pool, available via the rubygems.org API.
|
|
|
|
# Returns instances of APISpecification.
|
|
|
|
|
2013-11-18 19:34:13 -05:00
|
|
|
class Gem::Resolver::APISet < Gem::Resolver::Set
|
2013-07-09 19:21:36 -04:00
|
|
|
|
2013-11-10 12:51:40 -05:00
|
|
|
##
|
|
|
|
# The URI for the dependency API this APISet uses.
|
|
|
|
|
|
|
|
attr_reader :dep_uri # :nodoc:
|
|
|
|
|
2013-11-21 18:27:30 -05:00
|
|
|
##
|
|
|
|
# The Gem::Source that gems are fetched from
|
|
|
|
|
|
|
|
attr_reader :source
|
|
|
|
|
|
|
|
##
|
|
|
|
# The corresponding place to fetch gems.
|
|
|
|
|
|
|
|
attr_reader :uri
|
|
|
|
|
2013-11-10 12:51:40 -05:00
|
|
|
##
|
|
|
|
# Creates a new APISet that will retrieve gems from +uri+ using the RubyGems
|
2013-11-21 18:27:30 -05:00
|
|
|
# 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'
|
2014-02-03 19:48:31 -05:00
|
|
|
super()
|
|
|
|
|
2013-11-21 18:27:30 -05:00
|
|
|
dep_uri = URI dep_uri unless URI === dep_uri # for ruby 1.8
|
2013-11-10 12:51:40 -05:00
|
|
|
|
2013-11-21 18:27:30 -05:00
|
|
|
@dep_uri = dep_uri
|
2014-02-03 19:48:31 -05:00
|
|
|
@uri = dep_uri + '../..'
|
2013-11-21 18:27:30 -05:00
|
|
|
|
|
|
|
@data = Hash.new { |h,k| h[k] = [] }
|
|
|
|
@source = Gem::Source.new @uri
|
2014-09-13 23:30:02 -04:00
|
|
|
|
|
|
|
@to_fetch = []
|
2013-07-09 19:21:36 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
##
|
|
|
|
# Return an array of APISpecification objects matching
|
|
|
|
# DependencyRequest +req+.
|
|
|
|
|
|
|
|
def find_all req
|
|
|
|
res = []
|
|
|
|
|
2014-02-03 19:48:31 -05:00
|
|
|
return res unless @remote
|
|
|
|
|
2014-09-13 23:30:02 -04:00
|
|
|
if @to_fetch.include?(req.name)
|
|
|
|
prefetch_now
|
|
|
|
end
|
|
|
|
|
2013-07-09 19:21:36 -04:00
|
|
|
versions(req.name).each do |ver|
|
|
|
|
if req.dependency.match? req.name, ver[:number]
|
2013-11-18 19:34:13 -05:00
|
|
|
res << Gem::Resolver::APISpecification.new(self, ver)
|
2013-07-09 19:21:36 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
res
|
|
|
|
end
|
|
|
|
|
|
|
|
##
|
|
|
|
# A hint run by the resolver to allow the Set to fetch
|
|
|
|
# data for DependencyRequests +reqs+.
|
|
|
|
|
|
|
|
def prefetch reqs
|
2014-02-03 19:48:31 -05:00
|
|
|
return unless @remote
|
2013-07-09 19:21:36 -04:00
|
|
|
names = reqs.map { |r| r.dependency.name }
|
2014-09-13 23:30:02 -04:00
|
|
|
needed = names - @data.keys - @to_fetch
|
|
|
|
|
|
|
|
@to_fetch += needed
|
|
|
|
end
|
2013-07-09 19:21:36 -04:00
|
|
|
|
2014-12-06 19:53:01 -05:00
|
|
|
def prefetch_now # :nodoc:
|
2014-09-13 23:30:02 -04:00
|
|
|
needed, @to_fetch = @to_fetch, []
|
2013-07-09 19:21:36 -04:00
|
|
|
|
|
|
|
uri = @dep_uri + "?gems=#{needed.sort.join ','}"
|
|
|
|
str = Gem::RemoteFetcher.fetcher.fetch_path uri
|
|
|
|
|
2013-11-21 18:27:30 -05:00
|
|
|
loaded = []
|
|
|
|
|
2013-07-09 19:21:36 -04:00
|
|
|
Marshal.load(str).each do |ver|
|
2013-11-21 18:27:30 -05:00
|
|
|
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
|
2013-07-09 19:21:36 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
##
|
|
|
|
# Return data for all versions of the gem +name+.
|
|
|
|
|
2013-11-10 12:51:40 -05:00
|
|
|
def versions name # :nodoc:
|
2013-07-09 19:21:36 -04:00
|
|
|
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
|
|
|
|
|