analyseur Combinator: comment mettre fin à la répétition sur mot-clé
-
20-09-2019 - |
Question
Je suis en train de comprendre comment mettre fin à une répétition de mots en utilisant un mot-clé. Un exemple:
class CAQueryLanguage extends JavaTokenParsers {
def expression = ("START" ~ words ~ "END") ^^ { x =>
println("expression: " + x);
x
}
def words = rep(word) ^^ { x =>
println("words: " + x)
x
}
def word = """\w+""".r
}
Quand j'exécute
val caql = new CAQueryLanguage
caql.parseAll(caql.expression, "START one two END")
Il imprime words: List(one, two, END)
, ce qui indique que l'analyseur de words
a consommé le mot-clé END
dans mon entrée, laissant l'analyseur d'expression incapable de faire correspondre. Je voudrais END
de ne pas être égalé par words
, qui permettra expression
à analyser avec succès.
La solution
Est-ce que vous cherchez?
import scala.util.parsing.combinator.syntactical._
object CAQuery extends StandardTokenParsers {
lexical.reserved += ("START", "END")
lexical.delimiters += (" ")
def query:Parser[Any]= "START" ~> rep1(ident) <~ "END"
def parse(s:String) = {
val tokens = new lexical.Scanner(s)
phrase(query)(tokens)
}
}
println(CAQuery.parse("""START a END""")) //List(a)
println(CAQuery.parse("""START a b c END""")) //List(a, b, c)
Si vous désirez plus de détails, vous pouvez consulter ce billet de blog
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow