summaryrefslogtreecommitdiff
path: root/test/files/run/macro-subpatterns
diff options
context:
space:
mode:
authorDen Shabalin <den.shabalin@gmail.com>2013-12-09 17:30:30 +0100
committerDen Shabalin <den.shabalin@gmail.com>2013-12-11 00:15:02 +0100
commitb9a900e5d2f32b87149f7bd4cc7531f327abf5be (patch)
treeb0a3df822a5ed98fd7947d5d1e993df398f8e5e8 /test/files/run/macro-subpatterns
parent13aa2975bb8437ccdd597020073ee2e52d079f2d (diff)
downloadscala-b9a900e5d2f32b87149f7bd4cc7531f327abf5be.tar.gz
scala-b9a900e5d2f32b87149f7bd4cc7531f327abf5be.tar.bz2
scala-b9a900e5d2f32b87149f7bd4cc7531f327abf5be.zip
Test usage of SubpatternsAttachment from a macro
Diffstat (limited to 'test/files/run/macro-subpatterns')
-rw-r--r--test/files/run/macro-subpatterns/Macro_1.scala18
-rw-r--r--test/files/run/macro-subpatterns/Test_2.scala5
2 files changed, 23 insertions, 0 deletions
diff --git a/test/files/run/macro-subpatterns/Macro_1.scala b/test/files/run/macro-subpatterns/Macro_1.scala
new file mode 100644
index 0000000000..d8e86e27c6
--- /dev/null
+++ b/test/files/run/macro-subpatterns/Macro_1.scala
@@ -0,0 +1,18 @@
+import scala.reflect.macros.WhiteboxContext
+import language.experimental.macros
+
+object Extractor {
+ def unapply(x: Any): Any = macro unapplyImpl
+ def unapplyImpl(c: WhiteboxContext)(x: c.Tree) = {
+ val st = c.universe.asInstanceOf[reflect.internal.SymbolTable]
+ import st._
+ val subpatterns = x.attachments.get[SubpatternsAttachment].get.patterns
+ q"""
+ new {
+ def isEmpty = false
+ def get = ${subpatterns.toString}
+ def unapply(x: Any) = this
+ }.unapply(${x.asInstanceOf[st.Tree]})
+ """.asInstanceOf[c.Tree]
+ }
+}
diff --git a/test/files/run/macro-subpatterns/Test_2.scala b/test/files/run/macro-subpatterns/Test_2.scala
new file mode 100644
index 0000000000..dc6e668877
--- /dev/null
+++ b/test/files/run/macro-subpatterns/Test_2.scala
@@ -0,0 +1,5 @@
+object Test extends App {
+ 42 match {
+ case Extractor(a @ Extractor(b @ Extractor(c))) => println(a); println(b); println(c)
+ }
+}