БНФ для обработки escape-последовательности - PullRequest
4 голосов
/ 04 июня 2010

Я использую этот BNF для синтаксического анализа моего сценария:

{identset} = {ASCII} - {"\{\}};     //<--all ascii charset except '\"' '{' and '}'
{strset}   = {ASCII} - {"};
ident      = {identset}*;
str        = {strset}*;
node     ::= ident "{" nodes "}" |  //<--entry point
             "\"" str "\"" | 
             ident;
nodes    ::= node nodes |
             node;

Он может правильно разобрать следующий текст в древовидную структуру

doc {
    title { "some title goes here" }
    refcode { "SDS-1" }
    rev { "1.0" }
    revdate { "04062010" }
    body {  
        "this is the body of the document
         all text should go here"
        chapter { "some inline section" }
        "text again"
    }
}

мой вопрос, как мне обработать escape-последовательность внутри строки "some text of \"quotation\" should escape"

1 Ответ

1 голос
/ 04 июня 2010

Определить ул. Как:

str =  ( strset strescape ) *;

с

strescape = { \\ } {\" } ;
...