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:
parent
8e868cc886
commit
b3d85f8832
@ -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
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user