Class: Resolv::LOC::Coord

Inherits:
Object
  • Object
show all
Defined in:
lib/rubysl/resolv/resolv.rb

Overview

A Resolv::LOC::Coord

Constant Summary collapse

Regex =
/^(\d+)\s(\d+)\s(\d+\.\d+)\s([NESW])$/

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(coordinates, orientation) ⇒ Coord

Returns a new instance of Coord.



2706
2707
2708
2709
2710
2711
2712
2713
2714
2715
# File 'lib/rubysl/resolv/resolv.rb', line 2706

def initialize(coordinates,orientation)
  unless coordinates.kind_of?(String)
    raise ArgumentError.new("Coord must be a 32bit unsigned integer in hex format: #{coordinates.inspect}")
  end
  unless orientation.kind_of?(String) && orientation[/^lon$|^lat$/]
    raise ArgumentError.new('Coord expects orientation to be a String argument of "lat" or "lon"')
  end
  @coordinates = coordinates
  @orientation = orientation
end

Instance Attribute Details

#coordinatesObject (readonly)

The raw coordinates



2720
2721
2722
# File 'lib/rubysl/resolv/resolv.rb', line 2720

def coordinates
  @coordinates
end

#orientationObject (readonly)

The orientation of the hemisphere as ‘lat’ or ‘lon’



2724
2725
2726
# File 'lib/rubysl/resolv/resolv.rb', line 2724

def orientation
  @orientation
end

Class Method Details

.create(arg) ⇒ Object

Creates a new LOC::Coord from arg which may be:

LOC::Coord

returns arg.

String

arg must match the LOC::Coord::Regex constant



2687
2688
2689
2690
2691
2692
2693
2694
2695
2696
2697
2698
2699
2700
2701
2702
2703
2704
# File 'lib/rubysl/resolv/resolv.rb', line 2687

def self.create(arg)
  case arg
  when Coord
    return arg
  when String
    coordinates = ''
    if Regex =~ arg &&  $1<180
      hemi = ($4[/([NE])/,1]) || ($4[/([SW])/,1]) ? 1 : -1
      coordinates = [(($1.to_i*(36e5))+($2.to_i*(6e4))+($3.to_f*(1e3)))*hemi+(2**31)].pack("N")
      (orientation ||= '') << $4[[/NS/],1] ? 'lat' : 'lon'
    else
      raise ArgumentError.new("not a properly formed Coord string: " + arg)
    end
    return Coord.new(coordinates,orientation)
  else
    raise ArgumentError.new("cannot interpret as Coord: #{arg.inspect}")
  end
end

Instance Method Details

#==(other) ⇒ Object

:nodoc:



2749
2750
2751
# File 'lib/rubysl/resolv/resolv.rb', line 2749

def ==(other) # :nodoc:
  return @coordinates == other.coordinates
end

#eql?(other) ⇒ Boolean

:nodoc:

Returns:

  • (Boolean)


2753
2754
2755
# File 'lib/rubysl/resolv/resolv.rb', line 2753

def eql?(other) # :nodoc:
  return self == other
end

#hashObject

:nodoc:



2757
2758
2759
# File 'lib/rubysl/resolv/resolv.rb', line 2757

def hash # :nodoc:
  return @coordinates.hash
end

#inspectObject

:nodoc:



2745
2746
2747
# File 'lib/rubysl/resolv/resolv.rb', line 2745

def inspect # :nodoc:
  return "#<#{self.class} #{self}>"
end

#to_sObject

:nodoc:



2726
2727
2728
2729
2730
2731
2732
2733
2734
2735
2736
2737
2738
2739
2740
2741
2742
2743
# File 'lib/rubysl/resolv/resolv.rb', line 2726

def to_s # :nodoc:
    c = @coordinates.unpack("N").join.to_i
    val      = (c - (2**31)).abs
    fracsecs = (val % 1e3).to_i.to_s
    val      = val / 1e3
    secs     = (val % 60).to_i.to_s
    val      = val / 60
    mins     = (val % 60).to_i.to_s
    degs     = (val / 60).to_i.to_s
    posi = (c >= 2**31)
    case posi
    when true
      hemi = @orientation[/^lat$/] ? "N" : "E"
    else
      hemi = @orientation[/^lon$/] ? "W" : "S"
    end
    return degs << " " << mins << " " << secs << "." << fracsecs << " " << hemi
end