Class: Gem::NameTuple
- Inherits:
 - 
      Object
      
        
- Object
 - Gem::NameTuple
 
 
- Includes:
 - Comparable
 
- Defined in:
 - lib/rubygems/name_tuple.rb
 
Overview
Represents a gem of name name at version of platform. These wrap the data returned from the indexes.
Instance Attribute Summary collapse
- 
  
    
      #name  ⇒ Object 
    
    
  
  
  
  
    
      readonly
    
    
  
  
  
  
  
  
    
Returns the value of attribute name.
 - 
  
    
      #platform  ⇒ Object 
    
    
  
  
  
  
    
      readonly
    
    
  
  
  
  
  
  
    
Returns the value of attribute platform.
 - 
  
    
      #version  ⇒ Object 
    
    
  
  
  
  
    
      readonly
    
    
  
  
  
  
  
  
    
Returns the value of attribute version.
 
Class Method Summary collapse
- 
  
    
      .from_list(list)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Turn an array of [name, version, platform] into an array of NameTuple objects.
 - 
  
    
      .null  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
A null NameTuple, ie name=nil, version=0.
 - 
  
    
      .to_basic(list)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Turn an array of NameTuple objects back into an array of [name, version, platform] tuples.
 
Instance Method Summary collapse
- #<=>(other) ⇒ Object
 - 
  
    
      #==(other)  ⇒ Object 
    
    
      (also: #eql?)
    
  
  
  
  
  
  
  
  
  
    
Compare with
other. - 
  
    
      #full_name  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Returns the full name (name-version) of this Gem.
 - #hash ⇒ Object
 - 
  
    
      #initialize(name, version, platform = "ruby")  ⇒ NameTuple 
    
    
  
  
  
    constructor
  
  
  
  
  
  
  
    
A new instance of NameTuple.
 - 
  
    
      #inspect  ⇒ Object 
    
    
      (also: #to_s)
    
  
  
  
  
  
  
  
  
  
    
:nodoc:.
 - 
  
    
      #match_platform?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    
Indicate if this NameTuple matches the current platform.
 - 
  
    
      #prerelease?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    
Indicate if this NameTuple is for a prerelease version.
 - 
  
    
      #spec_name  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Return the name that the gemspec file would be.
 - 
  
    
      #to_a  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Convert back to the [name, version, platform] tuple.
 
Constructor Details
#initialize(name, version, platform = "ruby") ⇒ NameTuple
Returns a new instance of NameTuple.
      8 9 10 11 12 13 14 15 16 17  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 8 def initialize(name, version, platform="ruby") @name = name @version = version unless platform.kind_of? Gem::Platform platform = "ruby" if !platform || platform.empty? end @platform = platform end  | 
  
Instance Attribute Details
#name ⇒ Object (readonly)
Returns the value of attribute name.
      19 20 21  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 19 def name @name end  | 
  
#platform ⇒ Object (readonly)
Returns the value of attribute platform.
      19 20 21  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 19 def platform @platform end  | 
  
#version ⇒ Object (readonly)
Returns the value of attribute version.
      19 20 21  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 19 def version @version end  | 
  
Class Method Details
.from_list(list) ⇒ Object
Turn an array of [name, version, platform] into an array of NameTuple objects.
      25 26 27  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 25 def self.from_list(list) list.map {|t| new(*t) } end  | 
  
.null ⇒ Object
A null NameTuple, ie name=nil, version=0
      40 41 42  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 40 def self.null new nil, Gem::Version.new(0), nil end  | 
  
.to_basic(list) ⇒ Object
Turn an array of NameTuple objects back into an array of
- name, version, platform
 - 
tuples.
 
      33 34 35  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 33 def self.to_basic(list) list.map {|t| t.to_a } end  | 
  
Instance Method Details
#<=>(other) ⇒ Object
      91 92 93 94  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 91 def <=>(other) [@name, @version, Gem::Platform.sort_priority(@platform)] <=> [other.name, other.version, Gem::Platform.sort_priority(other.platform)] end  | 
  
#==(other) ⇒ Object Also known as: eql?
Compare with other. Supports another NameTuple or an Array in the [name, version, platform] format.
      102 103 104 105 106 107 108 109 110 111 112 113  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 102 def ==(other) case other when self.class @name == other.name && @version == other.version && @platform == other.platform when Array to_a == other else false end end  | 
  
#full_name ⇒ Object
Returns the full name (name-version) of this Gem. Platform information is included if it is not the default Ruby platform. This mimics the behavior of Gem::Specification#full_name.
      49 50 51 52 53 54 55 56  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 49 def full_name case @platform when nil, "ruby", "" "#{@name}-#{@version}" else "#{@name}-#{@version}-#{@platform}" end.dup.tap(&Gem::UNTAINT) end  | 
  
#hash ⇒ Object
      117 118 119  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 117 def hash to_a.hash end  | 
  
#inspect ⇒ Object Also known as: to_s
:nodoc:
      85 86 87  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 85 def inspect # :nodoc: "#<Gem::NameTuple #{@name}, #{@version}, #{@platform}>" end  | 
  
#match_platform? ⇒ Boolean
Indicate if this NameTuple matches the current platform.
      61 62 63  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 61 def match_platform? Gem::Platform.match_gem? @platform, @name end  | 
  
#prerelease? ⇒ Boolean
Indicate if this NameTuple is for a prerelease version.
      67 68 69  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 67 def prerelease? @version.prerelease? end  | 
  
#spec_name ⇒ Object
Return the name that the gemspec file would be
      74 75 76  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 74 def spec_name "#{full_name}.gemspec" end  | 
  
#to_a ⇒ Object
Convert back to the [name, version, platform] tuple
      81 82 83  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 81 def to_a [@name, @version, @platform] end  |