有没有办法在模式匹配中使用宏的参数?我想这样做:
def extr(X:AnyRef) = macro extrImpl
def extrImpl(c:Context)(X:c.Expr[AnyRef]):c.Expr[AnyRef] = {
import c.universe._
val tree = reify {
new {
def unapply(x:String):Option[String] = x match {
case X.splice => Some(x) //error
case _ => None
}
}
}.tree
c.Expr(c.typeCheck(tree))
}
但不幸的是,编译器说“需要稳定的标识符,但找到了 X.splice”。通常,可以通过首先分配一个 val 来解决这个问题,例如:
val XX = X.splice
但当然,这也不适用于拼接。