diff options
author | Jason Zaugg <jzaugg@gmail.com> | 2013-11-11 23:17:11 +0100 |
---|---|---|
committer | Jason Zaugg <jzaugg@gmail.com> | 2013-11-12 08:37:32 +0100 |
commit | 302a07c64e4cd3db91a654dcbc893ade0837ba8c (patch) | |
tree | 8eb296957c0d2bbf7e30600aab7a92bb25e26459 /src/test/scala/scala/async/TreeInterrogation.scala | |
parent | 490238d54d3476d681bfb0b7a04ac090e4e52d9f (diff) | |
download | scala-async-302a07c64e4cd3db91a654dcbc893ade0837ba8c.tar.gz scala-async-302a07c64e4cd3db91a654dcbc893ade0837ba8c.tar.bz2 scala-async-302a07c64e4cd3db91a654dcbc893ade0837ba8c.zip |
Don't aggressively null out captured vars
Once they escape, we leave the references in the state
machines fields untouched.
Diffstat (limited to 'src/test/scala/scala/async/TreeInterrogation.scala')
-rw-r--r-- | src/test/scala/scala/async/TreeInterrogation.scala | 38 |
1 files changed, 34 insertions, 4 deletions
diff --git a/src/test/scala/scala/async/TreeInterrogation.scala b/src/test/scala/scala/async/TreeInterrogation.scala index 524e1a2..c8fe2d6 100644 --- a/src/test/scala/scala/async/TreeInterrogation.scala +++ b/src/test/scala/scala/async/TreeInterrogation.scala @@ -66,13 +66,43 @@ object TreeInterrogation extends App { withDebug { val cm = reflect.runtime.currentMirror val tb = mkToolbox("-cp ${toolboxClasspath} -Xprint:typer -uniqid") - import scala.async.Async._ + import scala.async.internal.AsyncTestLV._ val tree = tb.parse( - """ import _root_.scala.async.internal.AsyncId.{async, await} + """ + | import scala.async.internal.AsyncTestLV._ + | import scala.async.internal.AsyncTestLV + | + | case class MCell[T](var v: T) + | val f = async { MCell(1) } + | + | def m1(x: MCell[Int], y: Int): Int = + | async { x.v + y } + | case class Cell[T](v: T) + | | async { - | implicit def view(a: Int): String = "" - | await(0).length + | // state #1 + | val a: MCell[Int] = await(f) // await$13$1 + | // state #2 + | var y = MCell(0) + | + | while (a.v < 10) { + | // state #4 + | a.v = a.v + 1 + | y = MCell(await(a).v + 1) // await$14$1 + | // state #7 + | } + | + | // state #3 + | assert(AsyncTestLV.log.exists(entry => entry._1 == "await$14$1")) + | + | val b = await(m1(a, y.v)) // await$15$1 + | // state #8 + | assert(AsyncTestLV.log.exists(_ == ("a$1" -> MCell(10)))) + | assert(AsyncTestLV.log.exists(_ == ("y$1" -> MCell(11)))) + | b | } + | + | | """.stripMargin) println(tree) val tree1 = tb.typeCheck(tree.duplicate) |