summaryrefslogblamecommitdiff
path: root/test/files/run/t7871/Macros_1.scala
blob: dca2508128cb09f4641103a14901987a3456a2d5 (plain) (tree)
1
2
3
4
5
6
7
8
9
                                            







                                                            
                                                                    
















                                                     
import scala.reflect.macros.whitebox.Context
import language.experimental.macros

trait Tree
case object SomeTree extends Tree

object NewQuasiquotes {
  implicit class QuasiquoteInterpolation(c: StringContext) {
    object nq {
      def unapply(t: Tree): Any = macro QuasiquoteMacros.unapplyImpl
    }
  }
}

object QuasiquoteMacros {
  def unapplyImpl(c: Context)(t: c.Tree) = {
    import c.universe._
    q"""
      new {
        def unapply(t: Tree) = t match {
          case SomeTree => Some((SomeTree, SomeTree))
          case _ => None
        }
      }.unapply($t)
    """
  }
}