是否有可能在`reify`宏的`splice`部分内捕获一些值?

时间:2013-06-18 11:09:15

标签: scala macros scala-2.10

例如,我有一些列表并希望迭代它,并对每个值进行宏转换:

reify {
  someIntListExpr.splice.foreach { i =>
    // transform is a macro of the form 'transform(c: Context)(i: c.Expr[Int]): c.Expr[Unit]
    transform(i).splice
  }
}

但编译器会发出错误消息:

found: Int
required: c.universe.Expr[Int]

有没有办法解决它?

1 个答案:

答案 0 :(得分:1)

在简单的情况下,这将解决问题:

someIntListExpr.splice.foreach { i =>
  transformImpl(c)(c.Expr[Int](Ident(newTermName("i")))).splice
}

或者你可以创建像这样的方法

def trans(i: Int): Unit = macro transform

并应用它:

reify {
  someIntListExpr.splice.foreach { i =>
    trans(i)
  }
}

有时您实际上可以获得List[c.Expr[Unit]]

如果您的方法(def myMethod(l: List[Int]): unti = macro myMethodImpl)被调用为myMethod(List(1, 2, x)),那么您可以获得List[c.Expr[Unit]]

def myMethodImpl(c: Context)(l: c.Expr[List[Int]]): ... = {
  import c.universe.Apply
  val es = l match {
    case Apply(_, l: List[c.Expr[Int]]) => l
  }
  ...
}