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.
      9 10 11 12 13 14 15 16 17 18  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 9 def initialize(name, version, platform="ruby") @name = name @version = version unless platform.is_a? Gem::Platform platform = "ruby" if !platform || platform.empty? end @platform = platform end  | 
  
Instance Attribute Details
#name ⇒ Object (readonly)
Returns the value of attribute name.
      20 21 22  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 20 def name @name end  | 
  
#platform ⇒ Object (readonly)
Returns the value of attribute platform.
      20 21 22  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 20 def platform @platform end  | 
  
#version ⇒ Object (readonly)
Returns the value of attribute version.
      20 21 22  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 20 def version @version end  | 
  
Class Method Details
.from_list(list) ⇒ Object
Turn an array of [name, version, platform] into an array of NameTuple objects.
      26 27 28  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 26 def self.from_list(list) list.map {|t| new(*t) } end  | 
  
.null ⇒ Object
A null NameTuple, ie name=nil, version=0
      41 42 43  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 41 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.
 
      34 35 36  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 34 def self.to_basic(list) list.map {|t| t.to_a } end  | 
  
Instance Method Details
#<=>(other) ⇒ Object
      92 93 94 95  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 92 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.
      103 104 105 106 107 108 109 110 111 112 113 114  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 103 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.
      50 51 52 53 54 55 56 57  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 50 def full_name case @platform when nil, "ruby", "" "#{@name}-#{@version}" else "#{@name}-#{@version}-#{@platform}" end.dup.tap(&Gem::UNTAINT) end  | 
  
#hash ⇒ Object
      118 119 120  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 118 def hash to_a.hash end  | 
  
#inspect ⇒ Object Also known as: to_s
:nodoc:
      86 87 88  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 86 def inspect # :nodoc: "#<Gem::NameTuple #{@name}, #{@version}, #{@platform}>" end  | 
  
#match_platform? ⇒ Boolean
Indicate if this NameTuple matches the current platform.
      62 63 64  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 62 def match_platform? Gem::Platform.match_gem? @platform, @name end  | 
  
#prerelease? ⇒ Boolean
Indicate if this NameTuple is for a prerelease version.
      68 69 70  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 68 def prerelease? @version.prerelease? end  | 
  
#spec_name ⇒ Object
Return the name that the gemspec file would be
      75 76 77  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 75 def spec_name "#{full_name}.gemspec" end  | 
  
#to_a ⇒ Object
Convert back to the [name, version, platform] tuple
      82 83 84  | 
    
      # File 'lib/rubygems/name_tuple.rb', line 82 def to_a [@name, @version, @platform] end  |