module Control.Effect.Interpreter.Heftia.Fail where
import Control.Effect (sendIns, type (~>))
import Control.Effect.Hefty (Eff, interpret)
import Control.Freer (Freer)
import Data.Effect.Fail (Fail (Fail), LFail)
import Data.Effect.HFunctor (HFunctor)
import Data.Hefty.Union (Member, Union)
runFailAsIO ::
forall r fr u c.
(Freer c fr, Union u, HFunctor (u '[]), Member u IO r) =>
Eff u fr '[] (LFail ': r) ~> Eff u fr '[] r
runFailAsIO :: forall (r :: [SigClass]) (fr :: SigClass)
(u :: [SigClass] -> SigClass) (c :: (* -> *) -> Constraint).
(Freer c fr, Union u, HFunctor (u '[]), Member u IO r) =>
Eff u fr '[] (LFail : r) ~> Eff u fr '[] r
runFailAsIO = forall (e :: SigClass) (r :: [SigClass]) (ehs :: [SigClass])
(fr :: SigClass) (u :: [SigClass] -> SigClass)
(c :: (* -> *) -> Constraint).
(Freer c fr, Union u, HeadIns e) =>
(UnliftIfSingle e ~> Eff u fr ehs r)
-> Eff u fr '[] (e : r) ~> Eff u fr ehs r
interpret \(Fail String
s) -> forall (ins :: * -> *) (f :: * -> *) a.
SendIns ins f =>
ins a -> f a
sendIns @IO forall a b. (a -> b) -> a -> b
$ forall (m :: * -> *) a. MonadFail m => String -> m a
fail String
s
{-# INLINE runFailAsIO #-}