aboutsummaryrefslogtreecommitdiff
path: root/tests/disabled/macro/run/reify_closure7.scala
diff options
context:
space:
mode:
Diffstat (limited to 'tests/disabled/macro/run/reify_closure7.scala')
-rw-r--r--tests/disabled/macro/run/reify_closure7.scala33
1 files changed, 33 insertions, 0 deletions
diff --git a/tests/disabled/macro/run/reify_closure7.scala b/tests/disabled/macro/run/reify_closure7.scala
new file mode 100644
index 000000000..93f2f22a4
--- /dev/null
+++ b/tests/disabled/macro/run/reify_closure7.scala
@@ -0,0 +1,33 @@
+import scala.reflect.runtime.universe._
+import scala.reflect.runtime.{universe => ru}
+import scala.reflect.runtime.{currentMirror => cm}
+import scala.tools.reflect.ToolBox
+
+object Test extends dotty.runtime.LegacyApp {
+ var q = 0
+ var clo: Int => Int = null
+ def foo[T: TypeTag](ys: List[T]): Int => Int = {
+ val z = 1
+ var y = 0
+ val fun = reify{(x: Int) => {
+ y += 1
+ q += 1
+ println("q = " + q)
+ println("y = " + y)
+ x + ys.length * z + q + y
+ }}
+
+ if (clo == null) {
+ val toolbox = cm.mkToolBox()
+ val dyn = toolbox.eval(fun.tree)
+ clo = dyn.asInstanceOf[Int => Int]
+ }
+
+ clo
+ }
+
+ val fun1 = foo(List(1, 2, 3))
+ println("first invocation = " + fun1(10))
+ val fun2 = foo(List(1, 2, 3, 4))
+ println("second invocation = " + fun2(10))
+}