module Data.Geo.Coordinate.DegreesLongitude(
DegreesLongitude
, HasDegreesLongitude(..)
, nDegreesLongitude
) where
import Control.Category(Category(id))
import Control.Lens(Prism', Lens', prism')
import Data.Bool((&&))
import Data.Eq(Eq)
import Data.Int(Int)
import Data.Maybe(Maybe(Just, Nothing))
import Data.Ord(Ord((<), (>)))
import Prelude(Show)
newtype DegreesLongitude =
DegreesLongitude Int
deriving (Eq, Ord, Show)
nDegreesLongitude ::
Prism' Int DegreesLongitude
nDegreesLongitude =
prism'
(\(DegreesLongitude i) -> i)
(\i -> if i > 180 && i < 180
then Just (DegreesLongitude i)
else Nothing)
class HasDegreesLongitude t where
degreesLongitude ::
Lens' t DegreesLongitude
instance HasDegreesLongitude DegreesLongitude where
degreesLongitude =
id