有没有办法在模式匹配中使用宏的参数?我想这样做:
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
但当然,这也不适用于拼接。
答案 0 :(得分:2)
不幸的是,现在不可能(并且在2.10.0决赛中不可能),但是我们有一些可能有助于后续版本发布的作品:)