Предположим, у меня есть неоднозначный язык, выраженный в синтаксическом анализаторе комбинатора. Есть ли способ сделать некоторые выражения локально жадными? Вот пример того, что я имею в виду.
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