Class: Resolv::DNS::Resource::LOC

Inherits:
Resolv::DNS::Resource show all
Defined in:
lib/resolv.rb

Overview

Location resource

Constant Summary collapse

TypeValue =

:nodoc:

29

Constants inherited from Resolv::DNS::Resource

ClassHash, ClassInsensitiveTypes, ClassValue

Instance Attribute Summary collapse

Attributes inherited from Resolv::DNS::Resource

#ttl

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from Resolv::DNS::Resource

#==, #eql?, get_class, #hash

Constructor Details

#initialize(version, ssize, hprecision, vprecision, latitude, longitude, altitude) ⇒ LOC

Returns a new instance of LOC.



2493
2494
2495
2496
2497
2498
2499
2500
2501
# File 'lib/resolv.rb', line 2493

def initialize(version, ssize, hprecision, vprecision, latitude, longitude, altitude)
  @version    = version
  @ssize      = Resolv::LOC::Size.create(ssize)
  @hprecision = Resolv::LOC::Size.create(hprecision)
  @vprecision = Resolv::LOC::Size.create(vprecision)
  @latitude   = Resolv::LOC::Coord.create(latitude)
  @longitude  = Resolv::LOC::Coord.create(longitude)
  @altitude   = Resolv::LOC::Alt.create(altitude)
end

Instance Attribute Details

#altitudeObject (readonly)

The altitude of the LOC above a reference sphere whose surface sits 100km below the WGS84 spheroid in centimeters as an unsigned 32bit integer



2544
2545
2546
# File 'lib/resolv.rb', line 2544

def altitude
  @altitude
end

#hprecisionObject (readonly)

The horizontal precision using ssize type values in meters using scientific notation as 2 integers of XeY for precision use value/2 e.g. 2m = +/-1m



2519
2520
2521
# File 'lib/resolv.rb', line 2519

def hprecision
  @hprecision
end

#latitudeObject (readonly)

The latitude for this LOC where 2**31 is the equator in thousandths of an arc second as an unsigned 32bit integer



2532
2533
2534
# File 'lib/resolv.rb', line 2532

def latitude
  @latitude
end

#longitudeObject (readonly)

The longitude for this LOC where 2**31 is the prime meridian in thousandths of an arc second as an unsigned 32bit integer



2538
2539
2540
# File 'lib/resolv.rb', line 2538

def longitude
  @longitude
end

#ssizeObject (readonly)

The spherical size of this LOC in meters using scientific notation as 2 integers of XeY



2512
2513
2514
# File 'lib/resolv.rb', line 2512

def ssize
  @ssize
end

#versionObject (readonly)

Returns the version value for this LOC record which should always be 00



2506
2507
2508
# File 'lib/resolv.rb', line 2506

def version
  @version
end

#vprecisionObject (readonly)

The vertical precision using ssize type values in meters using scientific notation as 2 integers of XeY for precision use value/2 e.g. 2m = +/-1m



2526
2527
2528
# File 'lib/resolv.rb', line 2526

def vprecision
  @vprecision
end

Class Method Details

.decode_rdata(msg) ⇒ Object

:nodoc:



2556
2557
2558
2559
2560
2561
2562
2563
2564
2565
2566
2567
2568
2569
2570
2571
2572
2573
# File 'lib/resolv.rb', line 2556

def self.decode_rdata(msg) # :nodoc:
  version    = msg.get_bytes(1)
  ssize      = msg.get_bytes(1)
  hprecision = msg.get_bytes(1)
  vprecision = msg.get_bytes(1)
  latitude   = msg.get_bytes(4)
  longitude  = msg.get_bytes(4)
  altitude   = msg.get_bytes(4)
  return self.new(
    version,
    Resolv::LOC::Size.new(ssize),
    Resolv::LOC::Size.new(hprecision),
    Resolv::LOC::Size.new(vprecision),
    Resolv::LOC::Coord.new(latitude,"lat"),
    Resolv::LOC::Coord.new(longitude,"lon"),
    Resolv::LOC::Alt.new(altitude)
  )
end

Instance Method Details

#encode_rdata(msg) ⇒ Object

:nodoc:



2546
2547
2548
2549
2550
2551
2552
2553
2554
# File 'lib/resolv.rb', line 2546

def encode_rdata(msg) # :nodoc:
  msg.put_bytes(@version)
  msg.put_bytes(@ssize.scalar)
  msg.put_bytes(@hprecision.scalar)
  msg.put_bytes(@vprecision.scalar)
  msg.put_bytes(@latitude.coordinates)
  msg.put_bytes(@longitude.coordinates)
  msg.put_bytes(@altitude.altitude)
end