我正在使用ANTLR和C#为类C结构创建一个简单的解析器。运行时版本为 4.7。语法如下所示:
structDef : STRUCT ID OPENBLOCK (fieldDef)+ CLOSEBLOCK ;
fieldDef : (namespaceQualifier)+ ID ID SEMICOLON ;
namespaceQualifier : ID DOT ;
/*
* Lexer Rules
*/
ID : [a-zA-Z_] [a-zA-Z0-9_]* ;
STRUCT : 'struct' ;
NAMESPACE : 'namespace' ;
OPENBLOCK : '{' ;
CLOSEBLOCK : '}' ;
DOT : '.' ;
SEMICOLON : ';' ;
WHITESPACE : (' '|'t')+ -> skip;
现在,当我像这样运行解析器时:
test = "struct Stest { type name; }"
var lexer = new OdefGrammarLexer(new AntlrInputStream(test));
var tokenStream = new CommonTokenStream(lexer);
var parser = new OdefGrammarParser(tokenStream);
var ctx = parser.structDef();
Console.Out.WriteLine(ctx.ToString());
我得到一个错误输出:
line 1:0 missing 'struct' at 'struct'
line 1:7 extraneous input 'Stest' expecting '{'
line 1:20 missing '.' at 'name'
line 1:24 mismatched input ';' expecting '.'
输出中的第一个错误特别有趣,似乎解析器无法在应有的位置找到匹配项。我怀疑字符串区域设置/编码存在问题,但我不确定如何为 ANTLR 解决这个问题。
任何帮助都非常感谢。
-
ID
规则必须在STRUCT
和NAMESPACE
规则(任何可能与之冲突的规则)之后,因为如果输入可以匹配多个令牌,则首先定义的令牌优先 -
ID
规则可能应该是(但也许您的符号受支持?ID : ('a'..'z' | 'A'..'Z' | '_') ('a'..'z' | 'A' .. 'Z' | '0'..'9' | '_')* ;