class NSWTopo::Projection

def self.azimuthal_equidistant(lon_0, lat_0)

def self.azimuthal_equidistant(lon_0, lat_0)
  from proj: "aeqd", datum: "WGS84", lon_0: lon_0, lat_0: lat_0
end

def self.epsg(epsg)

def self.epsg(epsg)
  new("EPSG:#{epsg}")
end

def self.from(**params)

def self.from(**params)
  params.map do |key, value|
    "+#{key}=#{value}"
  end.then do |args|
    new args.join(?\s)
  end
end

def self.oblique_mercator(lonc, lat_0, alpha:, **params)

def self.oblique_mercator(lonc, lat_0, alpha:, **params)
  from proj: "omerc", datum: "WGS84", lonc: lonc, lat_0: lat_0, gamma: 0, alpha: alpha, **params
end

def self.transverse_mercator(lon_0, lat_0, **params)

def self.transverse_mercator(lon_0, lat_0, **params)
  from proj: "tmerc", datum: "WGS84", lon_0: lon_0, lat_0: lat_0, **params
end

def self.utm(zone, south: true)

def self.utm(zone, south: true)
  new("EPSG:32%1d%02d" % [south ? 7 : 6, zone])
end

def self.utm_geometry(zone)

def self.utm_geometry(zone)
  longitudes = [31, 30].map { |offset| (zone - offset) * 6.0 }
  latitudes = [-80.0, 84.0]
  ring = longitudes.product(latitudes).values_at(0,2,3,1,0)
  GeoJSON.polygon [ring], projection: Projection.wgs84
end

def self.utm_zones(collection)

def self.utm_zones(collection)
  collection.reproject_to_wgs84.bounds.first.map do |longitude|
    (longitude / 6).floor + 31
  end.then do |min, max|
    min..max
  end
end

def self.wgs84

def self.wgs84
  new("EPSG:4326")
end

def ==(other)

def ==(other)
  super || wkt2 == other.wkt2
end

def initialize(value)

def initialize(value)
  @wkt2 = Projection === value ? value.wkt2 : OS.gdalsrsinfo("-o", "wkt2", "--single-line", value).chomp.strip
  raise "no georeferencing found: %s" % value if @wkt2.empty?
end

def metres?

def metres?
  OS.gdalsrsinfo("-o", "proj4", "--single-line", @wkt2).chomp.split.any?("+units=m")
end