8
假设我在combinator分析器中表达了一个不明确的语言。有没有办法让某些表达式在本地贪婪?这是我的意思的一个例子。Scala:我可以推动combinator解析器在本地贪婪吗?
import scala.util.parsing.combinator._
object Example extends JavaTokenParsers {
def obj: Parser[Any] = (shortchain | longchain) ~ anyrep
def longchain: Parser[Any] = zero~zero~one~one
def shortchain: Parser[Any] = zero~zero
def anyrep: Parser[Any] = rep(any)
def any: Parser[Any] = zero | one
def zero: Parser[Any] = "0"
def one: Parser[Any] = "1"
def main(args: Array[String]) {
println(parseAll(obj, args(0)))
}
}
编译后,如下我可以运行它:
$ scala Example 001111
[1.7] parsed: ((0~0)~List(1, 1, 1, 1))
我想以某种方式指示的obj
第一部分是本地贪婪和匹配longchain
。如果我切换订单,它会匹配longchain
,但那不是因为贪婪。
def obj: Parser[Any] = (longchain | shortchain) ~ anyrep
“贪婪”的概念只适用于封闭('rep'或postifx'*'运营商),并在你的语法是唯一适用于部分以下(longchain | shortchain)'或'(shortchain | longchain)'。 – 2010-04-05 03:56:29