需要帮助Continuations-Error“在非cps位置找到cps表达式”

时间:2010-04-15 14:21:56

标签: scala scala-2.8 continuations

我尝试使用Scala 2.8 Continuations-PlugIn构建以下简单的Generator。 以下错误来自哪里?

None/None/Some((Unit,Unit))
GenTest.scala:8: error: found cps expression in non-cps position
        yieldValue(1)

None/None/Some((Unit,Unit))
GenTest.scala:9: error: found cps expression in non-cps position
        yieldValue(2)

None/None/Some((Unit,Unit))
GenTest.scala:10: error: found cps expression in non-cps position
        yieldValue(3)

代码:

import scala.util.continuations._

object GenTest {

    val gen = new Generator1[Int] {
        yieldValue(1)
        yieldValue(2)
        yieldValue(3)
    }

    def main(args: Array[String]): Unit = {
        for (v <- gen) {
            println(v)
        }
    }
}



class Generator1[E](gen: => Unit @cps[Unit]) {

  var loop: (E => Unit) = null

  def foreach(f: => (E => Unit)): Unit = {
        loop = f
        reset[Unit,Unit]( gen )
  }

  def yieldValue(value: E): Unit @cps[Unit] =
    shift { genK: (Unit => Unit) =>
      loop( value )
      genK( () )
      ()
    }
}

1 个答案:

答案 0 :(得分:1)

那些yieldValue调用发生在gen的构造函数中,这是不允许的(我假设)。啊,我刚刚注意到你打算将它们作为构造函数参数。好吧,不幸的是,该语法仅适用于方法。我不确定你在这里也没有得到另一个错误。