Class: Gem::AvailableSet

Inherits:
Object
  • Object
show all
Includes:
Enumerable
Defined in:
lib/rubygems/available_set.rb

Defined Under Namespace

Classes: Tuple

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeAvailableSet

Returns a new instance of AvailableSet.



7
8
9
10
# File 'lib/rubygems/available_set.rb', line 7

def initialize
  @set = []
  @sorted = nil
end

Instance Attribute Details

#setObject (readonly)

Returns the value of attribute set



12
13
14
# File 'lib/rubygems/available_set.rb', line 12

def set
  @set
end

Instance Method Details

#<<(o) ⇒ Object



20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
# File 'lib/rubygems/available_set.rb', line 20

def <<(o)
  case o
  when Gem::AvailableSet
    s = o.set
  when Array
    s = o.map do |sp,so|
      if !sp.kind_of?(Gem::Specification) or !so.kind_of?(Gem::Source)
        raise TypeError, "Array must be in [[spec, source], ...] form"
      end

      Tuple.new(sp,so)
    end
  else
    raise TypeError, "must be a Gem::AvailableSet"
  end

  @set += s
  @sorted = nil

  self
end

#add(spec, source) ⇒ Object



14
15
16
17
18
# File 'lib/rubygems/available_set.rb', line 14

def add(spec, source)
  @set << Tuple.new(spec, source)
  @sorted = nil
  self
end

#all_specsObject



68
69
70
# File 'lib/rubygems/available_set.rb', line 68

def all_specs
  @set.map { |t| t.spec }
end

#eachObject

Yields each Tuple in this AvailableSet



45
46
47
48
49
50
51
# File 'lib/rubygems/available_set.rb', line 45

def each
  return enum_for __method__ unless block_given?

  @set.each do |tuple|
    yield tuple
  end
end

#each_specObject

Yields the Gem::Specification for each Tuple in this AvailableSet



56
57
58
59
60
61
62
# File 'lib/rubygems/available_set.rb', line 56

def each_spec
  return enum_for __method__ unless block_given?

  each do |tuple|
    yield tuple.spec
  end
end

#empty?Boolean

Returns:

  • (Boolean)


64
65
66
# File 'lib/rubygems/available_set.rb', line 64

def empty?
  @set.empty?
end

#find_all(req) ⇒ Object

Used by the Resolver, the protocol to use a AvailableSet as a search Set.



122
123
124
125
126
127
128
129
130
131
132
# File 'lib/rubygems/available_set.rb', line 122

def find_all(req)
  dep = req.dependency

  match = @set.find_all do |t|
    dep.matches_spec? t.spec
  end

  match.map do |t|
    Gem::Resolver::LocalSpecification.new(self, t.spec, t.source)
  end
end

#inject_into_list(dep_list) ⇒ Object



158
159
160
# File 'lib/rubygems/available_set.rb', line 158

def inject_into_list(dep_list)
  @set.each { |t| dep_list.add t.spec }
end

#match_platform!Object



72
73
74
75
76
# File 'lib/rubygems/available_set.rb', line 72

def match_platform!
  @set.reject! { |t| !Gem::Platform.match(t.spec.platform) }
  @sorted = nil
  self
end

#pick_best!Object



137
138
139
140
141
142
143
# File 'lib/rubygems/available_set.rb', line 137

def pick_best!
  return self if empty?

  @set = [sorted.first]
  @sorted = nil
  self
end

#prefetch(reqs) ⇒ Object



134
135
# File 'lib/rubygems/available_set.rb', line 134

def prefetch(reqs)
end

#remove_installed!(dep) ⇒ Object



145
146
147
148
149
150
151
152
153
154
155
156
# File 'lib/rubygems/available_set.rb', line 145

def remove_installed!(dep)
  @set.reject! do |t|
    # already locally installed
    Gem::Specification.any? do |installed_spec|
      dep.name == installed_spec.name and
        dep.requirement.satisfied_by? installed_spec.version
    end
  end

  @sorted = nil
  self
end

#sizeObject



85
86
87
# File 'lib/rubygems/available_set.rb', line 85

def size
  @set.size
end

#sortedObject



78
79
80
81
82
83
# File 'lib/rubygems/available_set.rb', line 78

def sorted
  @sorted ||= @set.sort do |a,b|
    i = b.spec <=> a.spec
    i != 0 ? i : (a.source <=> b.source)
  end
end

#source_for(spec) ⇒ Object



89
90
91
92
# File 'lib/rubygems/available_set.rb', line 89

def source_for(spec)
  f = @set.find { |t| t.spec == spec }
  f.source
end

#to_request_set(development = :none) ⇒ Object

Converts this AvailableSet into a RequestSet that can be used to install gems.

If development is :none then no development dependencies are installed. Other options are :shallow for only direct development dependencies of the gems in this set or :all for all development dependencies.



102
103
104
105
106
107
108
109
110
111
112
113
114
115
# File 'lib/rubygems/available_set.rb', line 102

def to_request_set development = :none
  request_set = Gem::RequestSet.new
  request_set.development = :all == development

  each_spec do |spec|
    request_set.always_install << spec

    request_set.gem spec.name, spec.version
    request_set.import spec.development_dependencies if
      :shallow == development
  end

  request_set
end