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.

Était-ce utile?

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
scroll top