1
1
mirror of https://github.com/github/semantic.git synced 2025-01-02 04:10:29 +03:00

Add a runLoopControl handler.

This commit is contained in:
Rob Rix 2018-05-06 14:09:05 -04:00
parent bef772e398
commit 8b679d0f80

View File

@ -61,6 +61,7 @@ module Control.Abstract.Evaluator
, throwBreak , throwBreak
, throwContinue , throwContinue
, catchLoopControl , catchLoopControl
, runLoopControl
, module Control.Effect , module Control.Effect
, module Control.Monad.Effect.Fail , module Control.Monad.Effect.Fail
, module Control.Monad.Effect.Fresh , module Control.Monad.Effect.Fresh
@ -339,3 +340,8 @@ throwContinue = raise . Eff.send . Continue
catchLoopControl :: Member (LoopControl value) effects => Evaluator location term value effects a -> (forall x . LoopControl value x -> Evaluator location term value effects a) -> Evaluator location term value effects a catchLoopControl :: Member (LoopControl value) effects => Evaluator location term value effects a -> (forall x . LoopControl value x -> Evaluator location term value effects a) -> Evaluator location term value effects a
catchLoopControl action handler = raiseHandler (Eff.interpose pure (\ control _ -> lower (handler control))) action catchLoopControl action handler = raiseHandler (Eff.interpose pure (\ control _ -> lower (handler control))) action
runLoopControl :: Evaluator location term value (LoopControl value ': effects) value -> Evaluator location term value effects value
runLoopControl = raiseHandler (Eff.relay pure (\ eff _ -> case eff of
Break value -> pure value
Continue value -> pure value))