无法在非组合语法中为字符串文字创建隐式标记

Fel*_*RPI 6 grammar implicit token antlr4

所以找到了一个很好的语法计算器,并从这里复制了一些lil变化:https: //dexvis.wordpress.com/2012/11/22/a-tale-of-two-grammars/

我有两个文件:Parser和Lexer.看起来像这样:

    parser grammar Parser;

options{
    language = Java;
    tokenVocab = Lexer;
}

// PARSER
program : ((assignment|expression) ';')+;

assignment : ID '=' expression;

expression
    : '(' expression ')'                # parenExpression
    | expression ('*'|'/') expression   # multOrDiv
    | expression ('+'|'-') expression   # addOrSubtract
    | 'print' arg (',' arg)*            # print
    | STRING                            # string
    | ID                                # identifier
    | INT                               # integer;

arg : ID|STRING;    
Run Code Online (Sandbox Code Playgroud)

和Lexer:

    lexer grammar WRBLexer;

STRING : '"' (' '..'~')* '"';
ID     : ('a'..'z'|'A'..'Z')+;
INT    : '0'..'9'+;
WS     : [ \t\n\r]+ -> skip ;
Run Code Online (Sandbox Code Playgroud)

基本上只是将Lexer和Parser分成两个文件.但是当我试图保存时,我得到一些错误:

error(126): Parser.g4:9:35: cannot create implicit token for string literal in non-combined grammar: ';'
error(126): Parser.g4:11:16: cannot create implicit token for string literal in non-combined grammar: '='
error(126): Parser.g4:2:13: cannot create implicit token for string literal in non-combined grammar: '('
error(126): Parser.g4:2:28: cannot create implicit token for string literal in non-combined grammar: ')'
error(126): Parser.g4:3:10: cannot create implicit token for string literal in non-combined grammar: 'print'
error(126): Parser.g4:3:23: cannot create implicit token for string literal in non-combined grammar: ','
error(126): Parser.g4:9:37: cannot create implicit token for string literal in non-combined grammar: '*'
error(126): Parser.g4:9:41: cannot create implicit token for string literal in non-combined grammar: '/'
error(126): Parser.g4:10:47: cannot create implicit token for string literal in non-combined grammar: '+'
error(126): Parser.g4:10:51: cannot create implicit token for string literal in non-combined grammar: '-'
10 error(s)
Run Code Online (Sandbox Code Playgroud)

希望有人可以帮助我.

最好的祝福

Bar*_*ers 6

解析器语法中的所有文字标记:'*','/'等等都需要在词法分析器语法中定义:

lexer grammar WRBLexer;

ADD : '+';
MUL : '*';
...
Run Code Online (Sandbox Code Playgroud)

然后在你的解析器语法中,你会做:

expression
    : ...
    | expression (MUL|DIV) expression   # multOrDiv
    | expression (ADD|SUB) expression   # addOrSubtract
    | ...
    ;
Run Code Online (Sandbox Code Playgroud)

  • 我相信你*可以*在解析器中使用一个文字,如果它匹配你在词法分析器中声明的规则(如果没有歧义).我花了一段时间来弄清楚这个语法https://github.com/antlr/grammars-v4/blob/master/csharp/CSharpParser.g4如何能够使用文字...... (2认同)