diff options
author | Jason Zaugg <jzaugg@gmail.com> | 2013-07-25 00:14:04 +1000 |
---|---|---|
committer | Jason Zaugg <jzaugg@gmail.com> | 2013-07-25 00:14:04 +1000 |
commit | 3b9d72928738f34449b1e67a18623458bdcd16d5 (patch) | |
tree | 56cd3e782632b11a8bc4921b91f937be6c98f192 /src/test/scala/scala | |
parent | 6721d1825e3bedac7585b1b7a35059ef6adb07c0 (diff) | |
download | scala-async-3b9d72928738f34449b1e67a18623458bdcd16d5.tar.gz scala-async-3b9d72928738f34449b1e67a18623458bdcd16d5.tar.bz2 scala-async-3b9d72928738f34449b1e67a18623458bdcd16d5.zip |
Preserve ApplyImplicitView / ApplyImplicitArgs in AnfTransform.
Diffstat (limited to 'src/test/scala/scala')
-rw-r--r-- | src/test/scala/scala/async/TreeInterrogation.scala | 10 | ||||
-rw-r--r-- | src/test/scala/scala/async/run/anf/AnfTransformSpec.scala | 17 |
2 files changed, 21 insertions, 6 deletions
diff --git a/src/test/scala/scala/async/TreeInterrogation.scala b/src/test/scala/scala/async/TreeInterrogation.scala index f1cb251..770c0f9 100644 --- a/src/test/scala/scala/async/TreeInterrogation.scala +++ b/src/test/scala/scala/async/TreeInterrogation.scala @@ -72,13 +72,11 @@ object TreeInterrogation extends App { import scala.async.Async._ val tree = tb.parse( """ import _root_.scala.async.internal.AsyncId.{async, await} - | def foo[T](a0: Int)(b0: Int*) = s"a0 = $a0, b0 = ${b0.head}" - | val res = async { - | var i = 0 - | def get = async {i += 1; i} - | foo[Int](await(get))(await(get) :: Nil : _*) + | import reflect.runtime.universe._ + | async { + | implicit def view(a: Int): String = "" + | await(0).length | } - | res | """.stripMargin) println(tree) val tree1 = tb.typeCheck(tree.duplicate) diff --git a/src/test/scala/scala/async/run/anf/AnfTransformSpec.scala b/src/test/scala/scala/async/run/anf/AnfTransformSpec.scala index bd2aa97..595ed63 100644 --- a/src/test/scala/scala/async/run/anf/AnfTransformSpec.scala +++ b/src/test/scala/scala/async/run/anf/AnfTransformSpec.scala @@ -377,4 +377,21 @@ class AnfTransformSpec { x } mustBe 1 } + + @Test + def awaitInImplicitApply() { + val tb = mkToolbox(s"-cp ${toolboxClasspath}") + val tree = tb.typeCheck(tb.parse { + """ + | import language.implicitConversions + | import _root_.scala.async.internal.AsyncId.{async, await} + | implicit def view(a: Int): String = "" + | async { + | await(0).length + | } + """.stripMargin + }) + val applyImplicitView = tree.collect { case x if x.getClass.getName.endsWith("ApplyImplicitView") => x } + applyImplicitView.map(_.toString) mustBe List("view(a$1)") + } } |