1

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

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]

有没有办法解决它?

4

1 回答 1

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
  }
  ...
}
于 2013-06-18T11:45:09.853 回答