Class: Resolv::DNS::Name
| Relationships & Source Files | |
| Inherits: | Object | 
| Defined in: | lib/resolv.rb | 
Overview
A representation of a ::Resolv::DNS name.
Class Method Summary
- 
    
      .create(arg)  
    
    Creates a new ::Resolv::DNSname fromarg.
- .new(labels, absolute = true) ⇒ Name constructor Internal use only
Instance Attribute Summary
- 
    
      #absolute?  ⇒ Boolean 
    
    readonly
    True if this name is absolute. 
Instance Method Summary
- 
    
      #subdomain_of?(other)  ⇒ Boolean 
    
    Returns true if otheris a subdomain.
- 
    
      #to_s  
    
    returns the domain name as a string. 
- #==(other) (also: #eql?) Internal use only
- #[](i) Internal use only
- 
    
      #eql?(other)  
    
    Internal use only
    Alias for #==. 
- #hash Internal use only
- #inspect Internal use only
- #length Internal use only
- #to_a Internal use only
Constructor Details
    .new(labels, absolute = true)  ⇒ Name 
  
  
    This method is for internal use only.
  
Class Method Details
.create(arg)
Creates a new ::Resolv::DNS name from arg.  arg can be:
- Name
- 
returns arg.
- String
- 
Creates a new Name.
Instance Attribute Details
    #absolute?  ⇒ Boolean  (readonly)
  
True if this name is absolute.
# File 'lib/resolv.rb', line 1271
def absolute? return @absolute end
Instance Method Details
#==(other) Also known as: #eql?
    This method is for internal use only.
  
  [ GitHub ]
#[](i)
    This method is for internal use only.
  
  [ GitHub ]
# File 'lib/resolv.rb', line 1317
def [](i) # :nodoc: return @labels[i] end
#eql?(other)
    This method is for internal use only.
  
Alias for #==.
# File 'lib/resolv.rb', line 1281
alias eql? == # :nodoc:
#hash
    This method is for internal use only.
  
  [ GitHub ]
# File 'lib/resolv.rb', line 1305
def hash # :nodoc: return @labels.hash ^ @absolute.hash end
#inspect
    This method is for internal use only.
  
  [ GitHub ]
# File 'lib/resolv.rb', line 1264
def inspect # :nodoc: "#<#{self.class}: #{self}#{@absolute ? '.' : ''}>" end
#length
    This method is for internal use only.
  
  [ GitHub ]
# File 'lib/resolv.rb', line 1313
def length # :nodoc: return @labels.length end
    #subdomain_of?(other)  ⇒ Boolean 
  
Returns true if other is a subdomain.
Example:
domain = Resolv::DNS::Name.create("y.z")
p Resolv::DNS::Name.create("w.x.y.z").subdomain_of?(domain) #=> true
p Resolv::DNS::Name.create("x.y.z").subdomain_of?(domain) #=> true
p Resolv::DNS::Name.create("y.z").subdomain_of?(domain) #=> false
p Resolv::DNS::Name.create("z").subdomain_of?(domain) #=> false
p Resolv::DNS::Name.create("x.y.z.").subdomain_of?(domain) #=> false
p Resolv::DNS::Name.create("w.z").subdomain_of?(domain) #=> false# File 'lib/resolv.rb', line 1297
def subdomain_of?(other) raise ArgumentError, "not a domain name: #{other.inspect}" unless Name === other return false if @absolute != other.absolute? other_len = other.length return false if @labels.length <= other_len return @labels[-other_len, other_len] == other.to_a end
#to_a
    This method is for internal use only.
  
  [ GitHub ]
# File 'lib/resolv.rb', line 1309
def to_a # :nodoc: return @labels end
#to_s
# File 'lib/resolv.rb', line 1332
def to_s return @labels.join('.') end