aboutsummaryrefslogtreecommitdiff
path: root/tests/disabled/macro/run/macro-subpatterns
diff options
context:
space:
mode:
Diffstat (limited to 'tests/disabled/macro/run/macro-subpatterns')
-rw-r--r--tests/disabled/macro/run/macro-subpatterns/Macro_1.scala17
-rw-r--r--tests/disabled/macro/run/macro-subpatterns/Test_2.scala5
2 files changed, 22 insertions, 0 deletions
diff --git a/tests/disabled/macro/run/macro-subpatterns/Macro_1.scala b/tests/disabled/macro/run/macro-subpatterns/Macro_1.scala
new file mode 100644
index 000000000..e009e411a
--- /dev/null
+++ b/tests/disabled/macro/run/macro-subpatterns/Macro_1.scala
@@ -0,0 +1,17 @@
+import scala.reflect.macros.whitebox.Context
+import language.experimental.macros
+
+object Extractor {
+ def unapply(x: Any): Any = macro unapplyImpl
+ def unapplyImpl(c: Context)(x: c.Tree) = {
+ import c.universe._
+ import internal._
+ q"""
+ new {
+ def isEmpty = false
+ def get = ${subpatterns(x).toString}
+ def unapply(x: Any) = this
+ }.unapply($x)
+ """
+ }
+}
diff --git a/tests/disabled/macro/run/macro-subpatterns/Test_2.scala b/tests/disabled/macro/run/macro-subpatterns/Test_2.scala
new file mode 100644
index 000000000..b19bd9b9b
--- /dev/null
+++ b/tests/disabled/macro/run/macro-subpatterns/Test_2.scala
@@ -0,0 +1,5 @@
+object Test extends dotty.runtime.LegacyApp {
+ 42 match {
+ case Extractor(a @ Extractor(b @ Extractor(c))) => println(a); println(b); println(c)
+ }
+}