使用Scalaz流,如何转换A =>任务[B]到Process1 [A,B]

时间:2014-08-20 07:48:58

标签: scala scalaz scalaz-stream

我正在将一个http请求编码为远程服务器作为一个函数,它接受一个id并产生一个Task [JValue]。

我想将该函数转换为Process1,以简化我的程序(通过简化,我的意思是尽可能使用Processes作为构建块)

我想转换功能

    reqDoc(id:A):Task[B]

(其中A是Id的类型,B是响应的类型) 成

    reqDoc:Process1[A,B]

1 个答案:

答案 0 :(得分:5)

我认为你不想要一个Process1,我认为如果你要创建一个Process1,你就会创建一个Process1[A, Task[B]],而不是Channel。你想要什么。

我认为你想创建一个Process,你可以附加一个Process,这会给你一个新的ChannelProcess只是产生有效函数的type Channel[+F[_],-I,O] = Process[F, I => F[O]] 的别名。

constant

由于你有一个函数,你只需要创建一个生成相同函数的无限流的过程,// 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 source: Process[Task,String] = Process.emit("asdf")

现在给出一个产生字符串的过程(这里我们只产生一个字符串):

val lengths = source through lengthChannel

我们可以通过渠道

运行我们的来源来创建流程
scala> lengths.runLog.run
res5: scala.collection.immutable.IndexedSeq[Int] = Vector(4)

我们可以运行我们的流程并获得" asdf"

的长度
{{1}}