使用Scalaz stream,如何转换A=>;任务[B]到进程1[A,B]

使用Scalaz stream,如何转换A=>;任务[B]到进程1[A,B],scala,scalaz,scalaz-stream,Scala,Scalaz,Scalaz Stream,我将一个发送到远程服务器的http请求编码为一个函数,该函数接受一个id并生成一个任务[JValue] 我想将这个函数转换成一个进程1,以简化我的程序(所谓简化,我的意思是尽可能多地使用进程作为构建块) 我想转换函数 reqDoc(id:A):Task[B] (其中A是Id的类型,B是响应的类型) 进入 我不认为你想要一个Process1,我认为如果你用它创建一个Process1,你会创建一个Process1[a,Task[B]],这不是你想要的 我认为您需要创建一个频道,您可以将进程

我将一个发送到远程服务器的http请求编码为一个函数,该函数接受一个id并生成一个任务[JValue]

我想将这个函数转换成一个进程1,以简化我的程序(所谓简化,我的意思是尽可能多地使用进程作为构建块)

我想转换函数

    reqDoc(id:A):Task[B]
(其中A是Id的类型,B是响应的类型) 进入


我不认为你想要一个
Process1
,我认为如果你用它创建一个
Process1
,你会创建一个
Process1[a,Task[B]]
,这不是你想要的

我认为您需要创建一个
频道
,您可以将
进程
附加到该频道上,这将为您提供一个新的
进程
频道
只是产生有效功能的
进程的别名

type Channel[+F[_],-I,O] = Process[F, I => F[O]]
因为您只有一个函数,所以您只需要创建一个进程,该进程将生成相同函数的无限流,该函数是
常量

// a String => Task[Int] that we'll make a channel from
val length: String => Task[Int] = (x => Task.delay(x.length))
// a channel is just a source of functions:
val lengthChannel = Process.constant(length)
现在给出一个生成字符串的进程(这里我们只生成一个):

我们可以通过通道运行源代码来创建流程

val lengths = source through lengthChannel
我们可以运行我们的流程,得到“asdf”的长度

val source: Process[Task,String] = Process.emit("asdf")
val lengths = source through lengthChannel
scala> lengths.runLog.run
res5: scala.collection.immutable.IndexedSeq[Int] = Vector(4)