aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/scala/async/internal/AnfTransform.scala
diff options
context:
space:
mode:
authorPhilipp Haller <hallerp@gmail.com>2013-11-22 11:44:02 -0800
committerPhilipp Haller <hallerp@gmail.com>2013-11-22 11:44:02 -0800
commitadbe51ef1050ec78eafcce7e45f848c4de8adf83 (patch)
treeb96e3df9cf89d6af8603b6a2726e16ca6efc0b68 /src/main/scala/scala/async/internal/AnfTransform.scala
parent93ab62488f4b75c45578a620785656e1faf48bd7 (diff)
parent4fc54635380eca4beb13678f24ba0a8e4d592bec (diff)
downloadscala-async-adbe51ef1050ec78eafcce7e45f848c4de8adf83.tar.gz
scala-async-adbe51ef1050ec78eafcce7e45f848c4de8adf83.tar.bz2
scala-async-adbe51ef1050ec78eafcce7e45f848c4de8adf83.zip
Merge pull request #50 from retronym/ticket/48
Fix crashers in do/while and while(await(..))
Diffstat (limited to 'src/main/scala/scala/async/internal/AnfTransform.scala')
-rw-r--r--src/main/scala/scala/async/internal/AnfTransform.scala9
1 files changed, 8 insertions, 1 deletions
diff --git a/src/main/scala/scala/async/internal/AnfTransform.scala b/src/main/scala/scala/async/internal/AnfTransform.scala
index f19a87a..8518cf5 100644
--- a/src/main/scala/scala/async/internal/AnfTransform.scala
+++ b/src/main/scala/scala/async/internal/AnfTransform.scala
@@ -162,7 +162,14 @@ private[async] trait AnfTransform {
def _transformToList(tree: Tree): List[Tree] = trace(tree) {
val containsAwait = tree exists isAwait
if (!containsAwait) {
- List(tree)
+ tree match {
+ case Block(stats, expr) =>
+ // avoids nested block in `while(await(false)) ...`.
+ // TODO I think `containsAwait` really should return true if the code contains a label jump to an enclosing
+ // while/doWhile and there is an await *anywhere* inside that construct.
+ stats :+ expr
+ case _ => List(tree)
+ }
} else tree match {
case Select(qual, sel) =>
val stats :+ expr = linearize.transformToList(qual)