Ошибка генерации файлов в ANTLR - PullRequest
1 голос
/ 09 февраля 2012

Итак, я пытаюсь написать синтаксический анализатор в ANTLR, я впервые использую его и столкнулся с проблемой, для которой не могу найти решение, извиняюсь, если это очень простая проблема. В любом случае, я получаю ошибку:

"(100): Expr.g:1:13:syntax error: antlr: MismatchedTokenException(74!=52)"

Код, который я сейчас использую:

grammar Expr.g;

options{
output=AST;
}


tokens{
    MAIN = 'main';
    OPENBRACKET = '(';
    CLOSEBRACKET = ')';
    OPENCURLYBRACKET = '{';
    CLOSECURLYBRACKET = '}';
    COMMA = ',';
    SEMICOLON = ';';
    GREATERTHAN = '>';
    LESSTHAN = '<';
    GREATEROREQUALTHAN = '>=';
        LESSTHANOREQUALTHAN = '<=';
    NOTEQUAL = '!=';
    ISEQUALTO = '==';
    WHILE = 'while';
    IF = 'if';
    ELSE = 'else';
    READ = 'read';
    OUTPUT = 'output';
    PRINT = 'print';
    RETURN = 'return';
    READC = 'readc';
    OUTPUTC = 'outputc';
    PLUS = '+';
    MINUS = '-';
    DIVIDE = '/';
    MULTIPLY = '*';
    PERCENTAGE = '%';
}


@header {
//package test;
import java.util.HashMap;
}

@lexer::header {
//package test;
}

@members {
/** Map variable name to Integer object holding value */
HashMap memory = new HashMap();
}

prog:   stat+ ;

stat:   expr NEWLINE {System.out.println($expr.value);}
    |   ID '=' expr NEWLINE
        {memory.put($ID.text, new Integer($expr.value));}
    |   NEWLINE
    ;

expr returns [int value]
    :   e=multExpr {$value = $e.value;}
        (   '+' e=multExpr {$value += $e.value;}
        |   '-' e=multExpr {$value -= $e.value;}
        )*
    ;

multExpr returns [int value]
    :   e=atom {$value = $e.value;} ('*' e=atom {$value *= $e.value;})*
    ; 

atom returns [int value]
    :   INT {$value = Integer.parseInt($INT.text);}
    |   ID
        {
        Integer v = (Integer)memory.get($ID.text);
        if ( v!=null ) $value = v.intValue();
        else System.err.println("undefined variable "+$ID.text);
        }
    |   '(' e=expr ')' {$value = $e.value;}
    ;

IDENT  :   ('a'..'z'^|'A'..'Z'^)+ ; :   .;
INT :   '0'..'9'+ ;
NEWLINE:'\r'? '\n' ;
WS  :   (' '|'\t')+ {skip();} ;

Спасибо за любую помощь.

РЕДАКТИРОВАТЬ: Ну, я идиот, это просто ошибка форматирования. Спасибо за ответы тех, кто помог.

1 Ответ

1 голос
/ 09 февраля 2012

У вас есть недопустимые символы после вашего IDENT токена:

IDENT  :   ('a'..'z'^|'A'..'Z'^)+ ; :   .;

: .; там недопустимы.Также вы пытаетесь смешать оператор перезаписи дерева ^ внутри правила лексера, что недопустимо: удалите их.Наконец, вы назвали его IDENT, в то время как в ваших правилах парсера вы используете ID.

Это должно быть:

ID : ('a'..'z' | 'A'..'Z')+ ;
...