mirror of
https://github.com/sayo-hs/heftia.git
synced 2024-11-23 10:59:57 +03:00
[fix] Generalize runStateIORef
.
This commit is contained in:
parent
e2deb545fe
commit
1a2774adab
@ -17,7 +17,16 @@ module Control.Effect.Interpreter.Heftia.State where
|
||||
|
||||
import Control.Arrow ((>>>))
|
||||
import Control.Effect (type (~>))
|
||||
import Control.Effect.Hefty (Eff, injectF, interpose, interposeT, interpret, interpretFin, interpretK, raiseUnder)
|
||||
import Control.Effect.Hefty (
|
||||
Eff,
|
||||
injectF,
|
||||
interpose,
|
||||
interposeT,
|
||||
interpretFin,
|
||||
interpretK,
|
||||
interpretRec,
|
||||
raiseUnder,
|
||||
)
|
||||
import Control.Effect.Interpreter.Heftia.Reader (runAsk)
|
||||
import Control.Freer (Freer)
|
||||
import Control.Monad.Freer (MonadFreer)
|
||||
@ -91,15 +100,15 @@ runStateK initialState =
|
||||
>>> runAsk initialState
|
||||
|
||||
runStateIORef ::
|
||||
forall s r a fr u c.
|
||||
(Freer c fr, Union u, MonadIO (Eff u fr '[] r)) =>
|
||||
forall s r eh a fr u c.
|
||||
(Freer c fr, Union u, HFunctor (u eh), MonadIO (Eff u fr eh r)) =>
|
||||
s ->
|
||||
Eff u fr '[] (LState s ': r) a ->
|
||||
Eff u fr '[] r (s, a)
|
||||
Eff u fr eh (LState s ': r) a ->
|
||||
Eff u fr eh r (s, a)
|
||||
runStateIORef s m = do
|
||||
ref <- newIORef s
|
||||
a <-
|
||||
m & interpret \case
|
||||
m & interpretRec \case
|
||||
Get -> readIORef ref
|
||||
Put s' -> writeIORef ref s'
|
||||
readIORef ref <&> (,a)
|
||||
|
Loading…
Reference in New Issue
Block a user