{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE TypeOperators #-}
module Control.Effect.Optics.Indexed
(
iview,
iviews,
ilocally,
iuse,
iuses,
)
where
import Control.Effect.Reader as Reader
import Control.Effect.State as State
import Optics.Core hiding (iview, iviews)
import qualified Optics.Core as Optics
iview :: (Is k A_Getter, is `HasSingleIndex` i, Has (Reader.Reader r) sig m) => Optic' k is r a -> m (i, a)
iview :: Optic' k is r a -> m (i, a)
iview Optic' k is r a
l = (r -> (i, a)) -> m (i, a)
forall r (sig :: (* -> *) -> * -> *) (m :: * -> *) a.
Has (Reader r) sig m =>
(r -> a) -> m a
Reader.asks (Optic' k is r a -> r -> (i, a)
forall k (is :: IxList) i s a.
(Is k A_Getter, HasSingleIndex is i) =>
Optic' k is s a -> s -> (i, a)
Optics.iview Optic' k is r a
l)
iviews :: (Is k A_Getter, is `HasSingleIndex` i, Has (Reader.Reader r) sig m) => Optic' k is r a -> (i -> a -> m b) -> m b
iviews :: Optic' k is r a -> (i -> a -> m b) -> m b
iviews Optic' k is r a
l i -> a -> m b
f = m r
forall r (sig :: (* -> *) -> * -> *) (m :: * -> *).
Has (Reader r) sig m =>
m r
Reader.ask m r -> (r -> m b) -> m b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Optic' k is r a -> (i -> a -> m b) -> r -> m b
forall k (is :: IxList) i s a r.
(Is k A_Getter, HasSingleIndex is i) =>
Optic' k is s a -> (i -> a -> r) -> s -> r
Optics.iviews Optic' k is r a
l i -> a -> m b
f
ilocally :: (Has (Reader s) sig m, is `HasSingleIndex` i, Is k A_Setter) => Optic k is s s a1 b -> (i -> a1 -> b) -> m a2 -> m a2
ilocally :: Optic k is s s a1 b -> (i -> a1 -> b) -> m a2 -> m a2
ilocally Optic k is s s a1 b
l i -> a1 -> b
f = (s -> s) -> m a2 -> m a2
forall r (sig :: (* -> *) -> * -> *) (m :: * -> *) a.
Has (Reader r) sig m =>
(r -> r) -> m a -> m a
Reader.local (Optic k is s s a1 b -> (i -> a1 -> b) -> s -> s
forall k (is :: IxList) i s t a b.
(Is k A_Setter, HasSingleIndex is i) =>
Optic k is s t a b -> (i -> a -> b) -> s -> t
iover Optic k is s s a1 b
l i -> a1 -> b
f)
iuse :: (Is k A_Getter, is `HasSingleIndex` i, Has (State s) sig m) => Optic' k is s a -> m (i, a)
iuse :: Optic' k is s a -> m (i, a)
iuse Optic' k is s a
l = (s -> (i, a)) -> m (i, a)
forall s (sig :: (* -> *) -> * -> *) (m :: * -> *) a.
Has (State s) sig m =>
(s -> a) -> m a
State.gets (Optic' k is s a -> s -> (i, a)
forall k (is :: IxList) i s a.
(Is k A_Getter, HasSingleIndex is i) =>
Optic' k is s a -> s -> (i, a)
Optics.iview Optic' k is s a
l)
iuses :: (Is k A_Getter, is `HasSingleIndex` i, Has (State s) sig m) => Optic' k is s a -> (i -> a -> m b) -> m b
iuses :: Optic' k is s a -> (i -> a -> m b) -> m b
iuses Optic' k is s a
l i -> a -> m b
r = m s
forall s (sig :: (* -> *) -> * -> *) (m :: * -> *).
Has (State s) sig m =>
m s
State.get m s -> (s -> m b) -> m b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Optic' k is s a -> (i -> a -> m b) -> s -> m b
forall k (is :: IxList) i s a r.
(Is k A_Getter, HasSingleIndex is i) =>
Optic' k is s a -> (i -> a -> r) -> s -> r
Optics.iviews Optic' k is s a
l i -> a -> m b
r