1
1
mirror of https://github.com/github/semantic.git synced 2025-01-05 05:58:34 +03:00

Define an interpose effect.

This commit is contained in:
Rob Rix 2018-10-18 08:21:05 -04:00
parent 8e868cc886
commit b3d85f8832

View File

@ -144,10 +144,10 @@ instance ( Carrier sig m
-- loop, otherwise under concrete semantics we run the risk of the -- loop, otherwise under concrete semantics we run the risk of the
-- conditional always being true and getting stuck in an infinite loop. -- conditional always being true and getting stuck in an infinite loop.
let body' = interpose @(Resumable (BaseError (UnspecializedError (Value term address)))) let body' = interpose @(Resumable (BaseError (UnspecializedError (Value term address))))
(\(Resumable (BaseError _ _ (UnspecializedError _))) -> throwAbort) $ (\(Resumable (BaseError _ _ (UnspecializedError _)) k) -> throwAbort) $
runWhile (raiseEff body) *> continue runEvaluator (runWhileC body *> continue)
ifthenelse cond' body' (pure unit) ifthenelse cond' body' (runWhileC (k unit))
where where
loop x = catchLoopControl (fix x) (\ control -> case control of loop x = catchLoopControl (fix x) (\ control -> case control of
Break value -> deref value Break value -> deref value
@ -158,6 +158,24 @@ instance ( Carrier sig m
Continue _ -> loop x) Continue _ -> loop x)
interpose :: (Member eff sig, HFunctor eff, Carrier sig m)
=> (forall v. eff m (m v) -> m v)
-> Eff (InterposeC eff m) a
-> m a
interpose handler = runInterposeC handler . interpret
newtype InterposeC eff m a = InterposeC ((forall x . eff m (m x) -> m x) -> m a)
runInterposeC :: (forall x . eff m (m x) -> m x) -> InterposeC eff m a -> m a
runInterposeC f (InterposeC m) = m f
instance (Member eff sig, HFunctor eff, Carrier sig m) => Carrier sig (InterposeC eff m) where
gen a = InterposeC (const (gen a))
alg op
| Just e <- prj op = InterposeC (\ handler -> handler (handlePure (runInterposeC handler) e))
| otherwise = InterposeC (\ handler -> alg (handlePure (runInterposeC handler) op))
instance AbstractHole (Value term address) where instance AbstractHole (Value term address) where
hole = Hole hole = Hole