2013-11-10 12:51:40 -05:00
|
|
|
##
|
2013-11-18 19:34:13 -05:00
|
|
|
# Resolver sets are used to look up specifications (and their
|
2013-11-10 12:51:40 -05:00
|
|
|
# dependencies) used in resolution. This set is abstract.
|
|
|
|
|
2013-11-18 19:34:13 -05:00
|
|
|
class Gem::Resolver::Set
|
2013-11-10 12:51:40 -05:00
|
|
|
|
2014-02-03 19:48:31 -05:00
|
|
|
##
|
|
|
|
# Set to true to disable network access for this set
|
|
|
|
|
|
|
|
attr_accessor :remote
|
|
|
|
|
|
|
|
def initialize # :nodoc:
|
|
|
|
@remote = true
|
|
|
|
end
|
|
|
|
|
2013-11-10 12:51:40 -05:00
|
|
|
##
|
2013-11-18 19:34:13 -05:00
|
|
|
# The find_all method must be implemented. It returns all Resolver
|
|
|
|
# Specification objects matching the given DependencyRequest +req+.
|
2013-11-10 12:51:40 -05:00
|
|
|
|
|
|
|
def find_all req
|
|
|
|
raise NotImplementedError
|
|
|
|
end
|
|
|
|
|
|
|
|
##
|
|
|
|
# The #prefetch method may be overridden, but this is not necessary. This
|
|
|
|
# default implementation does nothing, which is suitable for sets where
|
|
|
|
# looking up a specification is cheap (such as installed gems).
|
|
|
|
#
|
|
|
|
# When overridden, the #prefetch method should look up specifications
|
|
|
|
# matching +reqs+.
|
|
|
|
|
|
|
|
def prefetch reqs
|
|
|
|
end
|
|
|
|
|
2014-02-03 19:48:31 -05:00
|
|
|
##
|
|
|
|
# When true, this set is allowed to access the network when looking up
|
|
|
|
# specifications or dependencies.
|
|
|
|
|
|
|
|
def remote? # :nodoc:
|
|
|
|
@remote
|
|
|
|
end
|
|
|
|
|
2013-11-10 12:51:40 -05:00
|
|
|
end
|
|
|
|
|