Class: Bundler::Index
- Inherits:
-
Object
- Object
- Bundler::Index
- Includes:
- Enumerable
- Defined in:
- lib/bundler/index.rb
Constant Summary collapse
- RUBY =
"ruby"
- NULL =
"\0"
Instance Attribute Summary collapse
-
#sources ⇒ Object
readonly
Returns the value of attribute sources.
Class Method Summary collapse
Instance Method Summary collapse
-
#==(other) ⇒ Object
Whether all the specs in self are in other TODO: rename to #include?.
- #add(spec) ⇒ Object (also: #<<)
- #add_source(index) ⇒ Object
- #dependencies_eql?(spec, other_spec) ⇒ Boolean
- #dependency_names ⇒ Object
- #each(&blk) ⇒ Object
- #empty? ⇒ Boolean
-
#initialize ⇒ Index
constructor
A new instance of Index.
- #initialize_copy(o) ⇒ Object
- #inspect ⇒ Object
- #local_search(query) ⇒ Object
-
#merge!(other) ⇒ Object
Combines indexes proritizing specs from ‘other`, like `Hash#merge!` Duplicate specs found in `self` are saved in `@duplicates`.
-
#search(query) ⇒ Object
(also: #[])
Search this index’s specs, and any source indexes that this index knows about, returning all of the results.
- #search_all(name, &blk) ⇒ Object
- #size ⇒ Object
- #spec_names ⇒ Object
- #unmet_dependency_names ⇒ Object
-
#use(other) ⇒ Object
Combines indexes proritizing existing specs, like ‘Hash#reverse_merge!` Duplicate specs found in `other` are stored in `@duplicates`.
Constructor Details
#initialize ⇒ Index
Returns a new instance of Index.
19 20 21 22 23 24 |
# File 'lib/bundler/index.rb', line 19 def initialize @sources = [] @cache = {} @specs = {} @duplicates = {} end |
Instance Attribute Details
#sources ⇒ Object (readonly)
Returns the value of attribute sources.
13 14 15 |
# File 'lib/bundler/index.rb', line 13 def sources @sources end |
Class Method Details
.build {|i| ... } ⇒ Object
7 8 9 10 11 |
# File 'lib/bundler/index.rb', line 7 def self.build i = new yield i i end |
Instance Method Details
#==(other) ⇒ Object
Whether all the specs in self are in other TODO: rename to #include?
149 150 151 152 153 154 |
# File 'lib/bundler/index.rb', line 149 def ==(other) all? do |spec| other_spec = other[spec].first other_spec && dependencies_eql?(spec, other_spec) && spec.source == other_spec.source end end |
#add(spec) ⇒ Object Also known as: <<
81 82 83 |
# File 'lib/bundler/index.rb', line 81 def add(spec) (@specs[spec.name] ||= {}).store(spec.full_name, spec) end |
#add_source(index) ⇒ Object
162 163 164 165 166 |
# File 'lib/bundler/index.rb', line 162 def add_source(index) raise ArgumentError, "Source must be an index, not #{index.class}" unless index.is_a?(Index) @sources << index @sources.uniq! # need to use uniq! here instead of checking for the item before adding end |
#dependencies_eql?(spec, other_spec) ⇒ Boolean
156 157 158 159 160 |
# File 'lib/bundler/index.rb', line 156 def dependencies_eql?(spec, other_spec) deps = spec.dependencies.select {|d| d.type != :development } other_deps = other_spec.dependencies.select {|d| d.type != :development } deps.sort == other_deps.sort end |
#dependency_names ⇒ Object
107 108 109 110 111 112 113 114 115 116 |
# File 'lib/bundler/index.rb', line 107 def dependency_names names = [] each do |spec| spec.dependencies.each do |dep| next if dep.type == :development names << dep.name end end names.uniq end |
#each(&blk) ⇒ Object
86 87 88 89 90 91 92 93 |
# File 'lib/bundler/index.rb', line 86 def each(&blk) return enum_for(:each) unless blk specs.values.each do |spec_sets| spec_sets.values.each(&blk) end sources.each {|s| s.each(&blk) } self end |
#empty? ⇒ Boolean
44 45 46 47 |
# File 'lib/bundler/index.rb', line 44 def empty? each { return false } true end |
#initialize_copy(o) ⇒ Object
26 27 28 29 30 31 32 33 34 35 36 37 38 |
# File 'lib/bundler/index.rb', line 26 def initialize_copy(o) @sources = o.sources.dup @cache = {} @specs = {} @duplicates = {} o.specs.each do |name, hash| @specs[name] = hash.dup end o.duplicates.each do |name, array| @duplicates[name] = array.dup end end |
#inspect ⇒ Object
40 41 42 |
# File 'lib/bundler/index.rb', line 40 def inspect "#<#{self.class}:0x#{object_id} sources=#{sources.map(&:inspect)} specs.size=#{specs.size}>" end |
#local_search(query) ⇒ Object
71 72 73 74 75 76 77 78 79 |
# File 'lib/bundler/index.rb', line 71 def local_search(query) case query when Gem::Specification, RemoteSpecification, LazySpecification, EndpointSpecification then search_by_spec(query) when String then specs_by_name(query) when Array then specs_by_name_and_version(*query) else raise "You can't search for a #{query.inspect}." end end |
#merge!(other) ⇒ Object
Combines indexes proritizing specs from ‘other`, like `Hash#merge!` Duplicate specs found in `self` are saved in `@duplicates`.
130 131 132 133 134 135 136 137 138 139 |
# File 'lib/bundler/index.rb', line 130 def merge!(other) return unless other other.each do |spec| if existing = find_by_spec(spec) add_duplicate(existing) end add spec end self end |
#search(query) ⇒ Object Also known as: []
Search this index’s specs, and any source indexes that this index knows about, returning all of the results.
58 59 60 61 62 63 64 65 66 67 |
# File 'lib/bundler/index.rb', line 58 def search(query) results = local_search(query) return results unless @sources.any? @sources.each do |source| results = safe_concat(results, source.search(query)) end results.uniq!(&:full_name) unless results.empty? # avoid modifying frozen EMPTY_SEARCH results end |
#search_all(name, &blk) ⇒ Object
49 50 51 52 53 54 |
# File 'lib/bundler/index.rb', line 49 def search_all(name, &blk) return enum_for(:search_all, name) unless blk specs_by_name(name).each(&blk) @duplicates[name]&.each(&blk) @sources.each {|source| source.search_all(name, &blk) } end |
#size ⇒ Object
141 142 143 144 145 |
# File 'lib/bundler/index.rb', line 141 def size @sources.inject(@specs.size) do |size, source| size += source.size end end |
#spec_names ⇒ Object
95 96 97 98 99 |
# File 'lib/bundler/index.rb', line 95 def spec_names names = specs.keys + sources.map(&:spec_names) names.uniq! names end |
#unmet_dependency_names ⇒ Object
101 102 103 104 105 |
# File 'lib/bundler/index.rb', line 101 def unmet_dependency_names dependency_names.select do |name| search(name).empty? end end |
#use(other) ⇒ Object
Combines indexes proritizing existing specs, like ‘Hash#reverse_merge!` Duplicate specs found in `other` are stored in `@duplicates`.
120 121 122 123 124 125 126 |
# File 'lib/bundler/index.rb', line 120 def use(other) return unless other other.each do |spec| exist?(spec) ? add_duplicate(spec) : add(spec) end self end |