使用 quasiquotes 创建语法树
使用 quasiquotes 在宏中创建 Tree
。
object macro {
def addCreationDate(): java.util.Date = macro impl.addCreationDate
}
object impl {
def addCreationDate(c: Context)(): c.Expr[java.util.Date] = {
import c.universe._
val date = q"new java.util.Date()" // this is the quasiquote
c.Expr[java.util.Date](date)
}
}
它可以是任意复杂的,但它将被验证为正确的 scala 语法。