{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TypeApplications #-}
module Control.Effect.Optics
(
eview,
eviews,
use,
uses,
preuse,
assign,
modifying,
(.=),
(?=),
(%=),
)
where
import Control.Effect.Reader as Reader
import Control.Effect.State as State
import Optics.Core
eview ::
forall r a m sig k is.
( Is k A_Getter,
Has (Reader.Reader r) sig m
) =>
Optic' k is r a ->
m a
eview :: Optic' k is r a -> m a
eview l :: Optic' k is r a
l = (r -> a) -> m a
forall r (sig :: (* -> *) -> * -> *) (m :: * -> *) a.
Has (Reader r) sig m =>
(r -> a) -> m a
Reader.asks (Optic' k is r a -> r -> a
forall k (is :: IxList) s a.
Is k A_Getter =>
Optic' k is s a -> s -> a
view Optic' k is r a
l)
{-# INLINE eview #-}
eviews ::
forall r a b m sig k is.
( Is k A_Getter,
Has (Reader.Reader r) sig m
) =>
Optic' k is r a ->
(a -> b) ->
m b
eviews :: Optic' k is r a -> (a -> b) -> m b
eviews l :: Optic' k is r a
l f :: a -> b
f = (r -> b) -> m b
forall r (sig :: (* -> *) -> * -> *) (m :: * -> *) a.
Has (Reader r) sig m =>
(r -> a) -> m a
Reader.asks (a -> b
f (a -> b) -> (r -> a) -> r -> b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Optic' k is r a -> r -> a
forall k (is :: IxList) s a.
Is k A_Getter =>
Optic' k is s a -> s -> a
view Optic' k is r a
l)
{-# INLINE eviews #-}
use ::
forall s a m sig k is.
( Is k A_Getter,
Has (State.State s) sig m
) =>
Optic' k is s a ->
m a
use :: Optic' k is s a -> m a
use l :: Optic' k is s a
l = (s -> a) -> m a
forall s (sig :: (* -> *) -> * -> *) (m :: * -> *) a.
Has (State s) sig m =>
(s -> a) -> m a
State.gets (Optic' k is s a -> s -> a
forall k (is :: IxList) s a.
Is k A_Getter =>
Optic' k is s a -> s -> a
view Optic' k is s a
l)
{-# INLINE use #-}
uses ::
forall s a b m sig k is.
( Is k A_Getter,
Has (State.State s) sig m
) =>
Optic' k is s a ->
(a -> b) ->
m b
uses :: Optic' k is s a -> (a -> b) -> m b
uses l :: Optic' k is s a
l f :: a -> b
f = (s -> b) -> m b
forall s (sig :: (* -> *) -> * -> *) (m :: * -> *) a.
Has (State s) sig m =>
(s -> a) -> m a
State.gets (a -> b
f (a -> b) -> (s -> a) -> s -> b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Optic' k is s a -> s -> a
forall k (is :: IxList) s a.
Is k A_Getter =>
Optic' k is s a -> s -> a
view Optic' k is s a
l)
{-# INLINE uses #-}
preuse ::
forall s a m sig k is.
( Is k An_AffineFold,
Has (State.State s) sig m
) =>
Optic' k is s a ->
m (Maybe a)
preuse :: Optic' k is s a -> m (Maybe a)
preuse l :: Optic' k is s a
l = (s -> Maybe a) -> m (Maybe a)
forall s (sig :: (* -> *) -> * -> *) (m :: * -> *) a.
Has (State s) sig m =>
(s -> a) -> m a
State.gets (Optic' k is s a -> s -> Maybe a
forall k (is :: IxList) s a.
Is k An_AffineFold =>
Optic' k is s a -> s -> Maybe a
preview Optic' k is s a
l)
{-# INLINE preuse #-}
assign ::
forall s a b m sig k is.
( Is k A_Setter,
Has (State.State s) sig m
) =>
Optic k is s s a b ->
b ->
m ()
assign :: Optic k is s s a b -> b -> m ()
assign l :: Optic k is s s a b
l x :: b
x = (s -> s) -> m ()
forall s (sig :: (* -> *) -> * -> *) (m :: * -> *).
Has (State s) sig m =>
(s -> s) -> m ()
State.modify (Optic k is s s a b -> b -> s -> s
forall k (is :: IxList) s t a b.
Is k A_Setter =>
Optic k is s t a b -> b -> s -> t
set' Optic k is s s a b
l b
x)
{-# INLINE assign #-}
modifying ::
( Is k A_Setter,
Has (State.State s) sig m
) =>
Optic k is s s a b ->
(a -> b) ->
m ()
modifying :: Optic k is s s a b -> (a -> b) -> m ()
modifying l :: Optic k is s s a b
l x :: a -> b
x = (s -> s) -> m ()
forall s (sig :: (* -> *) -> * -> *) (m :: * -> *).
Has (State s) sig m =>
(s -> s) -> m ()
State.modify (Optic k is s s a b -> (a -> b) -> s -> s
forall k (is :: IxList) s t a b.
Is k A_Setter =>
Optic k is s t a b -> (a -> b) -> s -> t
over' Optic k is s s a b
l a -> b
x)
{-# INLINE modifying #-}
infix 4 .=
infix 4 ?=
infix 4 %=
(.=) ::
forall s a b m sig k is.
( Is k A_Setter,
Has (State.State s) sig m
) =>
Optic k is s s a b ->
b ->
m ()
.= :: Optic k is s s a b -> b -> m ()
(.=) = Optic k is s s a b -> b -> m ()
forall s a b (m :: * -> *) (sig :: (* -> *) -> * -> *) k
(is :: IxList).
(Is k A_Setter, Has (State s) sig m) =>
Optic k is s s a b -> b -> m ()
assign
{-# INLINE (.=) #-}
(?=) ::
forall s a b m sig k is.
( Is k A_Setter,
Has (State.State s) sig m
) =>
Optic k is s s a (Maybe b) ->
b ->
m ()
l :: Optic k is s s a (Maybe b)
l ?= :: Optic k is s s a (Maybe b) -> b -> m ()
?= a :: b
a = (s -> s) -> m ()
forall s (sig :: (* -> *) -> * -> *) (m :: * -> *).
Has (State s) sig m =>
(s -> s) -> m ()
State.modify (Optic k is s s a (Maybe b) -> Maybe b -> s -> s
forall k (is :: IxList) s t a b.
Is k A_Setter =>
Optic k is s t a b -> b -> s -> t
set Optic k is s s a (Maybe b)
l (b -> Maybe b
forall a. a -> Maybe a
Just b
a))
{-# INLINE (?=) #-}
(%=) ::
( Is k A_Setter,
Has (State.State s) sig m
) =>
Optic k is s s a b ->
(a -> b) ->
m ()
%= :: Optic k is s s a b -> (a -> b) -> m ()
(%=) = Optic k is s s a b -> (a -> b) -> m ()
forall k s (sig :: (* -> *) -> * -> *) (m :: * -> *) (is :: IxList)
a b.
(Is k A_Setter, Has (State s) sig m) =>
Optic k is s s a b -> (a -> b) -> m ()
modifying
{-# INLINE (%=) #-}