diff options
author | Philipp Haller <hallerp@gmail.com> | 2010-05-09 18:09:17 +0000 |
---|---|---|
committer | Philipp Haller <hallerp@gmail.com> | 2010-05-09 18:09:17 +0000 |
commit | 8fe7b531649dd5f82b6ac46720c751750e893500 (patch) | |
tree | 6386d1c0b8a2d07c3f1a6467ede4667cff2b261b /test/files/jvm/t3412.scala | |
parent | d1185713fa066528eac5f228aae943dd5ad3a142 (diff) | |
download | scala-8fe7b531649dd5f82b6ac46720c751750e893500.tar.gz scala-8fe7b531649dd5f82b6ac46720c751750e893500.tar.bz2 scala-8fe7b531649dd5f82b6ac46720c751750e893500.zip |
Closes #3407. Closes #3412. Review by plocinic.
Diffstat (limited to 'test/files/jvm/t3412.scala')
-rw-r--r-- | test/files/jvm/t3412.scala | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/test/files/jvm/t3412.scala b/test/files/jvm/t3412.scala new file mode 100644 index 0000000000..ced15ab5dc --- /dev/null +++ b/test/files/jvm/t3412.scala @@ -0,0 +1,32 @@ +import scala.actors._, scala.actors.Actor._, scala.actors.Futures._ + +object Test { + + def main(args: Array[String]) { + + val a = actor { + loop { react { + case i: Int => reply(i * 2) + case 'stop => exit() + } } + } + + val fts = for (_ <- 1 to 1000) + yield a !! (3, {case x: Int => x}) + + def respondAll(fts: List[Future[Int]], cnt: Int): Unit = + fts match { + case List() => a ! 'stop + case ft :: rest => + if (cnt % 100 == 0) + println(ft()) + respondAll(rest, cnt + 1) + } + + actor { + respondAll(fts.toList, 0) + } + + } + +} |