{-# LANGUAGE UndecidableInstances #-}
{-# LANGUAGE CPP #-}
{-# OPTIONS_GHC -fno-warn-orphans #-}
module Bookkeeper.Lens where
import GHC.OverloadedLabels
import Bookkeeper.Internal
import GHC.TypeLits (Symbol)
rlens :: (Settable field val' old new, Gettable field old val, Functor f) =>
          Key field -> (val -> f val') -> (Book' old -> f (Book' new))
rlens f = lens (\r -> get f r) (\r v -> set f v r)
  where lens sa sbt afb s = sbt s <$> afb (sa s)
instance (Settable field valnew old new,
          Gettable field old val,
          Functor f,
          s2ft ~ (Book' old -> f (Book' new)))
         => IsLabel (field :: Symbol)
                    ((val -> f valnew) -> s2ft) where
#if MIN_VERSION_base(4,10,0)
    fromLabel = rlens (Key @field)
#else
    fromLabel _ = rlens (Key @field)
#endif