aboutsummaryrefslogtreecommitdiff
path: root/tests/run/liftedTry.scala
diff options
context:
space:
mode:
authorMartin Odersky <odersky@gmail.com>2015-08-05 12:35:34 -0700
committerMartin Odersky <odersky@gmail.com>2015-08-05 13:31:58 -0700
commit3f46a7506454f01f1b3d79b60d1b48845bde8d4a (patch)
tree9bb820d191a57ec1a7aca9ff9ab50638ac217d61 /tests/run/liftedTry.scala
parent2a306ddcfe78589310d462bbf67fb893ce8702aa (diff)
downloaddotty-3f46a7506454f01f1b3d79b60d1b48845bde8d4a.tar.gz
dotty-3f46a7506454f01f1b3d79b60d1b48845bde8d4a.tar.bz2
dotty-3f46a7506454f01f1b3d79b60d1b48845bde8d4a.zip
Add LiftTry phase
Phase lifts tries that would be illegal because they execute on non-empty expression stacks.
Diffstat (limited to 'tests/run/liftedTry.scala')
-rw-r--r--tests/run/liftedTry.scala21
1 files changed, 21 insertions, 0 deletions
diff --git a/tests/run/liftedTry.scala b/tests/run/liftedTry.scala
new file mode 100644
index 000000000..2e4c25c2b
--- /dev/null
+++ b/tests/run/liftedTry.scala
@@ -0,0 +1,21 @@
+object Test {
+
+ def raise(x: Int) = { throw new Exception(s"$x"); 0 }
+ def handle: Throwable => Int = { case ex: Exception => ex.getMessage().toInt }
+
+ val x = try raise(1) catch handle
+
+ def foo(x: Int) = {
+ val y = try raise(x) catch handle
+ y
+ }
+
+ foo(try 3 catch handle)
+
+ def main(args: Array[String]) = {
+ assert(x == 1)
+ assert(foo(2) == 2)
+ assert(foo(try raise(3) catch handle) == 3)
+ }
+}
+