Class: Gem::Resolver::Set

Inherits:
Object
  • Object
show all
Defined in:
lib/rubygems/resolver/set.rb

Overview

Resolver sets are used to look up specifications (and their dependencies) used in resolution. This set is abstract.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeSet

:nodoc:



23
24
25
26
27
28
# File 'lib/rubygems/resolver/set.rb', line 23

def initialize # :nodoc:
  require 'uri'
  @prerelease = false
  @remote     = true
  @errors     = []
end

Instance Attribute Details

#errorsObject

Errors encountered when resolving gems



16
17
18
# File 'lib/rubygems/resolver/set.rb', line 16

def errors
  @errors
end

#prereleaseObject

When true, allows matching of requests to prerelease gems.



21
22
23
# File 'lib/rubygems/resolver/set.rb', line 21

def prerelease
  @prerelease
end

#remoteObject

Set to true to disable network access for this set



11
12
13
# File 'lib/rubygems/resolver/set.rb', line 11

def remote
  @remote
end

Instance Method Details

#find_all(req) ⇒ Object

The find_all method must be implemented. It returns all Resolver Specification objects matching the given DependencyRequest req.

Raises:

  • (NotImplementedError)


34
35
36
# File 'lib/rubygems/resolver/set.rb', line 34

def find_all(req)
  raise NotImplementedError
end

#prefetch(reqs) ⇒ Object

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.



46
47
# File 'lib/rubygems/resolver/set.rb', line 46

def prefetch(reqs)
end

#remote?Boolean

When true, this set is allowed to access the network when looking up specifications or dependencies.

Returns:

  • (Boolean)


53
54
55
# File 'lib/rubygems/resolver/set.rb', line 53

def remote? # :nodoc:
  @remote
end