module Control.Effect.Interpreter.Heftia.Provider where
import Control.Effect (type (~>))
import Control.Effect.Hefty (Elab)
import Control.Monad.Trans (MonadTrans, lift)
import Data.Effect.Provider (Provider' (Provide))
runProvider ::
(c g, e g) =>
(f ~> g) ->
(i -> forall x. g x -> f (ctx x)) ->
Elab (Provider' c i ctx e) f
runProvider :: forall (c :: (* -> *) -> Constraint) (g :: * -> *)
(e :: (* -> *) -> Constraint) (f :: * -> *) i (ctx :: * -> *).
(c g, e g) =>
(f ~> g)
-> (i -> forall x. g x -> f (ctx x))
-> Elab (Provider' c i ctx e) f
runProvider f ~> g
iLower i -> forall x. g x -> f (ctx x)
run (Provide i
i forall (g :: * -> *). (c g, e g) => (forall x. f x -> g x) -> g a1
f) = i -> forall x. g x -> f (ctx x)
run i
i forall a b. (a -> b) -> a -> b
$ forall (g :: * -> *). (c g, e g) => (forall x. f x -> g x) -> g a1
f f ~> g
iLower
{-# INLINE runProvider #-}
runProviderT ::
(Monad m, MonadTrans t, c (t m), e (t m)) =>
(i -> forall x. t m x -> m (ctx x)) ->
Elab (Provider' c i ctx e) m
runProviderT :: forall (m :: * -> *) (t :: (* -> *) -> * -> *)
(c :: (* -> *) -> Constraint) (e :: (* -> *) -> Constraint) i
(ctx :: * -> *).
(Monad m, MonadTrans t, c (t m), e (t m)) =>
(i -> forall x. t m x -> m (ctx x)) -> Elab (Provider' c i ctx e) m
runProviderT = forall (c :: (* -> *) -> Constraint) (g :: * -> *)
(e :: (* -> *) -> Constraint) (f :: * -> *) i (ctx :: * -> *).
(c g, e g) =>
(f ~> g)
-> (i -> forall x. g x -> f (ctx x))
-> Elab (Provider' c i ctx e) f
runProvider forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift
{-# INLINE runProviderT #-}