这一行:
"foo".assertNonFatal( _ equals "foo", "error message");
此错误:
Error:(120, 47) not found: value assertion
这个钩子:
final implicit class ImplicitAssert[MyType](val me: MyType) {
final def assertNonFatal(assertion: (MyType) => Boolean, message: String)
: MyType = macro ImplicitAssertMacros.assertNonFatal[MyType]
}
这个宏:
object ImplicitAssertMacros {
def assertNonFatal[MyType](c: scala.reflect.macros.blackbox.Context)
(assertion: c.Tree, message: c.Tree): c.Tree = {
import c.universe._
val me = q"${c.prefix}.me" // "me" from ImplicitAssert class.
val numLines = q"Int.MaxValue"
val useStdOut = q"false"
val assertionTrue = q"assertion($me)"
val isFatal = q"false"
val toReturn = q"""
_root_.info.collaboration_station.debug.internal.Printer.traceInternalAssert($message, $numLines, $useStdOut, $assertionTrue, $isFatal);
$me;
"""
toReturn
}
}
^我无法弄清楚这个编译器错误的原因是什么或如何修复它。
请注意,它仅在我编译源文件时发生,而不是宏。
答案 0 :(得分:1)
通过改变:
val assertionTrue = q"$assertion($me)"
def宏在调用站点扩展,其中不再有任何断言参数。