diff options
Diffstat (limited to 'tests/disabled/macro/run/macro-subpatterns')
-rw-r--r-- | tests/disabled/macro/run/macro-subpatterns/Macro_1.scala | 17 | ||||
-rw-r--r-- | tests/disabled/macro/run/macro-subpatterns/Test_2.scala | 5 |
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) + } +} |