Class: Gem::Resolv::Hosts
| Relationships & Source Files | |
| Inherits: | Object | 
| Defined in: | lib/rubygems/vendor/resolv/lib/resolv.rb | 
Overview
Hosts is a hostname resolver that uses the system hosts file.
Class Method Summary
- 
    
      .new(filename = DefaultFileName)  ⇒ Hosts 
    
    constructor
    Creates a new Hosts, usingfilenamefor its data source.
Instance Method Summary
- 
    
      #each_address(name, &proc)  
    
    Iterates over all IP addresses for nameretrieved from the hosts file.
- 
    
      #each_name(address, &proc)  
    
    Iterates over all hostnames for addressretrieved from the hosts file.
- 
    
      #getaddress(name)  
    
    Gets the IP address of namefrom the hosts file.
- 
    
      #getaddresses(name)  
    
    Gets all IP addresses for namefrom the hosts file.
- 
    
      #getname(address)  
    
    Gets the hostname of addressfrom the hosts file.
- 
    
      #getnames(address)  
    
    Gets all hostnames for addressfrom the hosts file.
- #lazy_initialize Internal use only
Constructor Details
    .new(filename = DefaultFileName)  ⇒ Hosts 
  
Creates a new Hosts, using filename for its data source.
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 192
def initialize(filename = DefaultFileName) @filename = filename @mutex = Thread::Mutex.new @initialized = nil end
Instance Method Details
#each_address(name, &proc)
Iterates over all IP addresses for name retrieved from the hosts file.
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 239
def each_address(name, &proc) lazy_initialize @name2addr[name]&.each(&proc) end
#each_name(address, &proc)
Iterates over all hostnames for address retrieved from the hosts file.
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 264
def each_name(address, &proc) lazy_initialize @addr2name[address]&.each(&proc) end
#getaddress(name)
Gets the IP address of name from the hosts file.
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 222
def getaddress(name) each_address(name) {|address| return address} raise ResolvError.new("#{@filename} has no name: #{name}") end
#getaddresses(name)
Gets all IP addresses for name from the hosts file.
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 230
def getaddresses(name) ret = [] each_address(name) {|address| ret << address} return ret end
#getname(address)
Gets the hostname of address from the hosts file.
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 247
def getname(address) each_name(address) {|name| return name} raise ResolvError.new("#{@filename} has no address: #{address}") end
#getnames(address)
Gets all hostnames for address from the hosts file.
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 255
def getnames(address) ret = [] each_name(address) {|name| ret << name} return ret end
#lazy_initialize
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 198
def lazy_initialize # :nodoc: @mutex.synchronize { unless @initialized @name2addr = {} @addr2name = {} File.open(@filename, 'rb') {|f| f.each {|line| line.sub!(/#.*/, '') addr, *hostnames = line.split(/\s+/) next unless addr (@addr2name[addr] ||= []).concat(hostnames) hostnames.each {|hostname| (@name2addr[hostname] ||= []) << addr} } } @name2addr.each {|name, arr| arr.reverse!} @initialized = true end } self end