如何从猫状态创建猫 IO monad
How to create cats IO monad from cats State
我正在和猫一起工作,我想将我的 val x: State[A, B]
转换为 StateT[IO, A, B]
。注意:IO 来自 cats-effects。
如何优雅地做到这一点?
尝试
def liftState[A, B](state: State[A, B]): StateT[IO, A, B] =
StateT[IO, A, B] { s => IO.eval(state.run(s)) }
例如
val x: State[Int, String] = State(int => (int, "foo"))
liftState(x)
尝试将 mapK
与 cats.arrow.FunctionK.lift
结合使用:
x.mapK(lift(IO.eval))
完整的可编译代码片段:
import cats.effect.IO
import cats.data.{State, StateT}
import cats.arrow.FunctionK.lift
object InjectIdIO {
def i[S, V](x: State[S, V]): StateT[IO, S, V] = x.mapK(lift(IO.eval))
}
这是可行的,因为 State[S, A]
实际上是 StateT[Eval, S, A]
,而您想用 IO
替换 Eval
- 这通常是 mapK
对于.
kind-projector
的另一种选择:
x.mapK(Lambda[Eval ~> IO](IO.eval(_)))
我正在和猫一起工作,我想将我的 val x: State[A, B]
转换为 StateT[IO, A, B]
。注意:IO 来自 cats-effects。
如何优雅地做到这一点?
尝试
def liftState[A, B](state: State[A, B]): StateT[IO, A, B] =
StateT[IO, A, B] { s => IO.eval(state.run(s)) }
例如
val x: State[Int, String] = State(int => (int, "foo"))
liftState(x)
尝试将 mapK
与 cats.arrow.FunctionK.lift
结合使用:
x.mapK(lift(IO.eval))
完整的可编译代码片段:
import cats.effect.IO
import cats.data.{State, StateT}
import cats.arrow.FunctionK.lift
object InjectIdIO {
def i[S, V](x: State[S, V]): StateT[IO, S, V] = x.mapK(lift(IO.eval))
}
这是可行的,因为 State[S, A]
实际上是 StateT[Eval, S, A]
,而您想用 IO
替换 Eval
- 这通常是 mapK
对于.
kind-projector
的另一种选择:
x.mapK(Lambda[Eval ~> IO](IO.eval(_)))