The State monad transformer using CPS style.
@[always_inline]
Equations
@[always_inline]
instance
StateCpsT.instMonadStateOf
{σ : Type u}
{m : Type u → Type v}
:
MonadStateOf σ (StateCpsT σ m)
Equations
- One or more equations did not get rendered due to their size.
Equations
- StateCpsT.instMonadLiftOfMonad = { monadLift := fun {α : Type ?u.24} => StateCpsT.lift }
@[simp]
theorem
StateCpsT.runK_set
{σ : Type u}
{m : Type u → Type v}
{β : Type u}
(s s' : σ)
(k : PUnit → σ → m β)
:
(set s').runK s k = k PUnit.unit s'
@[simp]
theorem
StateCpsT.runK_modify
{σ : Type u}
{m : Type u → Type v}
{β : Type u}
(f : σ → σ)
(s : σ)
(k : PUnit → σ → m β)
:
(modify f).runK s k = k PUnit.unit (f s)
@[simp]
theorem
StateCpsT.runK_lift
{α σ : Type u}
{m : Type u → Type v}
{β : Type u}
[Monad m]
(x : m α)
(s : σ)
(k : α → σ → m β)
:
(StateCpsT.lift x).runK s k = do
let x ← x
k x s