Kim*_*bel 6 macros scala pattern-matching scala-2.10 scala-macros
有没有办法在模式匹配中使用宏的参数?我想这样做:
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))
}
Run Code Online (Sandbox Code Playgroud)
但不幸的是编译器说"需要稳定的标识符,但X.splice发现了".通常,人们可以通过首先分配val来解决这个问题,例如:
val XX = X.splice
Run Code Online (Sandbox Code Playgroud)
但当然,这也不适用于拼接.
| 归档时间: |
|
| 查看次数: |
754 次 |
| 最近记录: |