aboutsummaryrefslogtreecommitdiff
path: root/src/test/scala/scala/async/run/anf/AnfTransformSpec.scala
diff options
context:
space:
mode:
authorJason Zaugg <jzaugg@gmail.com>2012-11-26 18:20:00 +0100
committerJason Zaugg <jzaugg@gmail.com>2012-11-27 08:36:30 +0100
commitfe9a0023e685a2924cba10ec738e8babe9e7bd7b (patch)
treec337362ca36e9ee8fdd768653202cbc3ad8dab85 /src/test/scala/scala/async/run/anf/AnfTransformSpec.scala
parent456fd6e561a52f34040d9af041cc2b74880e5579 (diff)
downloadscala-async-fe9a0023e685a2924cba10ec738e8babe9e7bd7b.tar.gz
scala-async-fe9a0023e685a2924cba10ec738e8babe9e7bd7b.tar.bz2
scala-async-fe9a0023e685a2924cba10ec738e8babe9e7bd7b.zip
Fix semantics of by-name application
- If we lift one arg, we must lift them all. This preserves evaluation order. - But, never lift an by-name arg Addresses the first half of #33.
Diffstat (limited to 'src/test/scala/scala/async/run/anf/AnfTransformSpec.scala')
-rw-r--r--src/test/scala/scala/async/run/anf/AnfTransformSpec.scala22
1 files changed, 22 insertions, 0 deletions
diff --git a/src/test/scala/scala/async/run/anf/AnfTransformSpec.scala b/src/test/scala/scala/async/run/anf/AnfTransformSpec.scala
index 6dd4db7..595fa6c 100644
--- a/src/test/scala/scala/async/run/anf/AnfTransformSpec.scala
+++ b/src/test/scala/scala/async/run/anf/AnfTransformSpec.scala
@@ -205,4 +205,26 @@ class AnfTransformSpec {
}
result mustBe (true)
}
+
+ @Test
+ def byNameExpressionsArentLifted() {
+ import _root_.scala.async.AsyncId.{async, await}
+ def foo(ignored: => Any, b: Int) = b
+ val result = async {
+ foo(???, await(1))
+ }
+ result mustBe (1)
+ }
+
+ @Test
+ def evaluationOrderRespected() {
+ import scala.async.AsyncId.{async, await}
+ def foo(a: Int, b: Int) = (a, b)
+ val result = async {
+ var i = 0
+ def next() = {i += 1; i}
+ foo(next(), await(next()))
+ }
+ result mustBe ((1, 2))
+ }
}