aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/scala/async/internal/AnfTransform.scala
diff options
context:
space:
mode:
authorJason Zaugg <jzaugg@gmail.com>2015-07-27 14:38:24 +1000
committerJason Zaugg <jzaugg@gmail.com>2015-07-27 14:38:24 +1000
commitc770346316de26cd36f69510a0220b6d3927456e (patch)
treec4409678573dcc8188247df4fcac91366507c5f2 /src/main/scala/scala/async/internal/AnfTransform.scala
parentad6c3c0a758c50ce32656e64714a0bd90a28d0be (diff)
parentd74a615334de70c13bd9be00b03b4010de980b0b (diff)
downloadscala-async-c770346316de26cd36f69510a0220b6d3927456e.tar.gz
scala-async-c770346316de26cd36f69510a0220b6d3927456e.tar.bz2
scala-async-c770346316de26cd36f69510a0220b6d3927456e.zip
Merge pull request #127 from retronym/backport/20150727v0.9.5_2.10
Backports for two recently fixed bugs.
Diffstat (limited to 'src/main/scala/scala/async/internal/AnfTransform.scala')
-rw-r--r--src/main/scala/scala/async/internal/AnfTransform.scala12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/main/scala/scala/async/internal/AnfTransform.scala b/src/main/scala/scala/async/internal/AnfTransform.scala
index 3c8c837..e41c64e 100644
--- a/src/main/scala/scala/async/internal/AnfTransform.scala
+++ b/src/main/scala/scala/async/internal/AnfTransform.scala
@@ -70,6 +70,9 @@ private[async] trait AnfTransform {
val stats :+ expr = anf.transformToList(tree)
def statsExprUnit =
stats :+ expr :+ localTyper.typedPos(expr.pos)(Literal(Constant(())))
+ def statsExprThrow =
+ stats :+ expr :+ localTyper.typedPos(expr.pos)(Throw(Apply(Select(New(gen.mkAttributedRef(defn.IllegalStateExceptionClass)), nme.CONSTRUCTOR), Nil)))
+
expr match {
case Apply(fun, args) if isAwait(fun) =>
val valDef = defineVal(name.await, expr, tree.pos)
@@ -81,7 +84,7 @@ private[async] trait AnfTransform {
// TODO avoid creating a ValDef for the result of this await to avoid this tree shape altogether.
// This will require some deeper changes to the later parts of the macro which currently assume regular
// tree structure around `await` calls.
- gen.mkCast(ref, definitions.UnitTpe)
+ localTyper.typedPos(tree.pos)(gen.mkCast(ref, definitions.UnitTpe))
else ref
stats :+ valDef :+ atPos(tree.pos)(ref1)
@@ -90,6 +93,8 @@ private[async] trait AnfTransform {
// but add Unit value to bring it into form expected by async transform
if (expr.tpe =:= definitions.UnitTpe) {
statsExprUnit
+ } else if (expr.tpe =:= definitions.NothingTpe) {
+ statsExprThrow
} else {
val varDef = defineVar(name.ifRes, expr.tpe, tree.pos)
def branchWithAssign(orig: Tree) = localTyper.typedPos(orig.pos) {
@@ -110,8 +115,9 @@ private[async] trait AnfTransform {
// but add Unit value to bring it into form expected by async transform
if (expr.tpe =:= definitions.UnitTpe) {
statsExprUnit
- }
- else {
+ } else if (expr.tpe =:= definitions.NothingTpe) {
+ statsExprThrow
+ } else {
val varDef = defineVar(name.matchRes, expr.tpe, tree.pos)
def typedAssign(lhs: Tree) =
localTyper.typedPos(lhs.pos)(Assign(Ident(varDef.symbol), mkAttributedCastPreservingAnnotations(lhs, varDef.symbol.tpe)))