Question

Supposons que j'ai un langage ambigu exprimé dans l'analyseur Combinator. Y at-il un moyen de rendre certaines expressions gourmandes au niveau local? Voici un exemple de ce que je veux dire.

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) ))
  }
}

Après la compilation, je peux courir comme suit:

$ scala Example 001111
[1.7] parsed: ((0~0)~List(1, 1, 1, 1))

Je voudrais demander en quelque sorte la première partie de obj être localement avide et correspondre avec longchain. Si je passe l'ordre autour, elle correspond à la longchain, mais ce n'est pas à cause de l'avidité.

def obj: Parser[Any] = (longchain | shortchain) ~ anyrep
Était-ce utile?

La solution

Utilisation |||:

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.main(Array("001111"))
[1.7] parsed: ((((0~0)~1)~1)~List(1, 1))
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top