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
- #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
- 
  
    
      #subset?(other)  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Whether all the specs in self are in other. 
- #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
#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
| 161 162 163 164 165 | # File 'lib/bundler/index.rb', line 161 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
| 155 156 157 158 159 | # File 'lib/bundler/index.rb', line 155 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 | 
#subset?(other) ⇒ Boolean
Whether all the specs in self are in other
| 148 149 150 151 152 153 | # File 'lib/bundler/index.rb', line 148 def subset?(other) all? do |spec| other_spec = other[spec].first other_spec && dependencies_eql?(spec, other_spec) && spec.source == other_spec.source end 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 |