我正在使用DSL,我遇到了使用方法作为链中的中缀运算符的问题。我将尝试用一些代码来解释它。我有一个特征Term
和案例类Literal
和Variable
扩展它。我想使用一些运算符构造一个术语实例列表。
case class Expr(val terms: List[Term]) {
def +(v: String) = Expr(Literal(v) :: terms)
def -->(func: List[String] => List[String]) = terms match {
case Literal(v) :: ts => Expr(Variable(v, func) :: ts)
case _ => throw new Exception("Can only apply function on literal")
}
}
object foo {
def bar(name: String) = Expr(Literal(name) :: Nil)
}
// some functions
val one = ...
val all = ...
// works
foo bar "x"
// res1: Expr = Expr(List(Literal(x)))
// works not
foo bar "x" --> all
// error: value --> is not a member of java.lang.String
// works
(foo bar "x") --> all
// res1: Expr = Expr(List(Variable(x,<function1>)))
我希望这相当于foo.bar("x").-->(all)
,但解释器似乎将其视为foo.bar("x".-->(all))
。
答案 0 :(得分:16)
您可以在此处找到运算符优先级:
根据第一个答案-
与字母相比具有更高的优先级。所以编译器组表达式如下:
foo bar ("x" --> all)
如果你用较低优先级的东西(例如字母)替换-->
,那么它应该编译。例如:
foo bar "x" to all
您也可以选择优先级较高的运算符而不是bar
。像~~>
之类的东西会这样做,因为~
是特殊字符,它具有最高优先级:
foo ~~> "x" --> all