Class: Gem::Source
| Relationships & Source Files | |
| Namespace Children | |
| Classes: | |
| Extension / Inclusion / Inheritance Descendants | |
| Subclasses: | |
| Super Chains via Extension / Inclusion / Inheritance | |
| Instance Chain: 
          self,
          Comparable
         | |
| Inherits: | Object | 
| Defined in: | lib/rubygems/source.rb | 
Overview
A Source knows how to list and fetch gems from a RubyGems marshal index.
There are other Source subclasses for installed gems, local gems, the bundler dependency API and so-forth.
Constant Summary
- 
    FILES =
    Internal use only
    
 # File 'lib/rubygems/source.rb', line 15{ # :nodoc: :released => 'specs', :latest => 'latest_specs', :prerelease => 'prerelease_specs', }
Class Method Summary
- 
    
      .new(uri)  ⇒ Source 
    
    constructor
    Creates a new Sourcewhich will use the index located at #uri.
Instance Attribute Summary
- 
    
      #update_cache?  ⇒ Boolean 
    
    readonly
    Returns true when it is possible and safe to update the cache directory. 
- 
    
      #uri  
    
    readonly
    The URI this source will fetch gems from. 
Instance Method Summary
- 
    
      #<=>(other)  
    
    Sources are ordered by installation preference. 
- 
    
      #cache_dir(uri)  
    
    Returns the local directory to write #uri to. 
- 
    
      #download(spec, dir = Dir.pwd)  
    
    Downloads specand writes it to dir.
- 
    
      #fetch_spec(name_tuple)  
    
    Fetches a specification for the given name_tuple.
- 
    
      #load_specs(type)  
    
    Loads typekind of specs fetching from @uri if the on-disk cache is out of date.
- #==(other) (also: #eql?) Internal use only
- 
    
      #api_uri  
    
    Internal use only
    Use an SRV record on the host to look up the true endpoint for the index. 
- 
    
      #dependency_resolver_set  
    
    Internal use only
    Returns a Set that can fetch specifications from this source. 
- 
    
      #eql?(other)  
    
    Internal use only
    Alias for #==. 
- #hash Internal use only
- #pretty_print(q) Internal use only
Constructor Details
    .new(uri)  ⇒ Source 
  
Creates a new Source which will use the index located at #uri.
Instance Attribute Details
    #update_cache?  ⇒ Boolean  (readonly)
  
Returns true when it is possible and safe to update the cache directory.
#uri (readonly)
The URI this source will fetch gems from.
# File 'lib/rubygems/source.rb', line 24
attr_reader :uri
Instance Method Details
#<=>(other)
Sources are ordered by installation preference.
# File 'lib/rubygems/source.rb', line 53
def <=>(other) case other when Gem::Source::Installed, Gem::Source::Local, Gem::Source::Lock, Gem::Source::SpecificFile, Gem::Source::Git, Gem::Source::Vendor then -1 when Gem::Source then if !@uri return 0 unless other.uri return 1 end return -1 if !other.uri # Returning 1 here ensures that when sorting a list of sources, the # original ordering of sources supplied by the user is preserved. return 1 unless @uri.to_s == other.uri.to_s 0 else nil end end
#==(other) Also known as: #eql?
# File 'lib/rubygems/source.rb', line 80
def == other # :nodoc: self.class === other and @uri == other.uri end
#api_uri
Use an SRV record on the host to look up the true endpoint for the index.
# File 'lib/rubygems/source.rb', line 45
def api_uri # :nodoc: require 'rubygems/remote_fetcher' @api_uri ||= Gem::RemoteFetcher.fetcher.api_endpoint uri end
#cache_dir(uri)
Returns the local directory to write #uri to.
#dependency_resolver_set
Returns a Set that can fetch specifications from this source.
# File 'lib/rubygems/source.rb', line 89
def dependency_resolver_set # :nodoc: return Gem::Resolver::IndexSet.new self if 'file' == api_uri.scheme bundler_api_uri = api_uri + './api/v1/dependencies' begin fetcher = Gem::RemoteFetcher.fetcher response = fetcher.fetch_path bundler_api_uri, nil, true rescue Gem::RemoteFetcher::FetchError Gem::Resolver::IndexSet.new self else if response.respond_to? :uri then Gem::Resolver::APISet.new response.uri else Gem::Resolver::APISet.new bundler_api_uri end end end
#download(spec, dir = Dir.pwd)
Downloads spec and writes it to Gem.dir.  See also RemoteFetcher#download.
#eql?(other)
Alias for #==.
# File 'lib/rubygems/source.rb', line 84
alias_method :eql?, :== # :nodoc:
#fetch_spec(name_tuple)
Fetches a specification for the given name_tuple.
# File 'lib/rubygems/source.rb', line 138
def fetch_spec name_tuple fetcher = Gem::RemoteFetcher.fetcher spec_file_name = name_tuple.spec_name uri = api_uri + "#{Gem::MARSHAL_SPEC_DIR}#{spec_file_name}" cache_dir = cache_dir uri local_spec = File.join cache_dir, spec_file_name if File.exist? local_spec then spec = Gem.read_binary local_spec spec = Marshal.load(spec) rescue nil return spec if spec end uri.path << '.rz' spec = fetcher.fetch_path uri spec = Gem.inflate spec if update_cache? then FileUtils.mkdir_p cache_dir File.open local_spec, 'wb' do |io| io.write spec end end # TODO: Investigate setting Gem::Specification#loaded_from to a URI Marshal.load spec end
#hash
# File 'lib/rubygems/source.rb', line 108
def hash # :nodoc: @uri.hash end
#load_specs(type)
Loads type kind of specs fetching from @uri if the on-disk cache is out of date.
type is one of the following:
:released   => Return the list of all released specs :latest     => Return the list of only the highest version of each gem :prerelease => Return the list of all prerelease only specs
# File 'lib/rubygems/source.rb', line 183
def load_specs(type) file = FILES[type] fetcher = Gem::RemoteFetcher.fetcher file_name = "#{file}.#{Gem.marshal_version}" spec_path = api_uri + "#{file_name}.gz" cache_dir = cache_dir spec_path local_file = File.join(cache_dir, file_name) retried = false FileUtils.mkdir_p cache_dir if update_cache? spec_dump = fetcher.cache_update_path spec_path, local_file, update_cache? begin Gem::NameTuple.from_list Marshal.load(spec_dump) rescue ArgumentError if update_cache? && !retried FileUtils.rm local_file retried = true retry else raise Gem::Exception.new("Invalid spec cache file in #{local_file}") end end end
#pretty_print(q)
# File 'lib/rubygems/source.rb', line 218
def pretty_print q # :nodoc: q.group 2, '[Remote:', ']' do q.breakable q.text @uri.to_s if api = api_uri q.breakable q.text 'API URI: ' q.text api.to_s end end end