在 ANTLR 中生成文件时出错

发布于 2025-01-04 06:53:03 字数 2059 浏览 1 评论 0原文

所以我试图在 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();} ;

感谢您的帮助。

编辑:嗯,我是个白痴,这只是一个格式错误。感谢那些提供帮助的人的回复。

So I'm trying to write a parser in ANTLR, this is my first time using it and I'm running into a problem that I can't find a solution for, apologies if this is a very simple problem. Anyway, the error I'm getting is:

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

The code I'm currently using is:

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();} ;

Thanks for any help.

EDIT: Well, I'm an idiot, it's just a formatting error. Thanks for the responses from those who helped out.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

勿忘初心 2025-01-11 06:53:03

您的 IDENT 令牌后有一些非法字符:

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

: .; 在那里无效。而且您还尝试在词法分析器规则中混合树重写运算符 ^ ,这是非法的:删除它们。最后,您将其命名为 IDENT,而在解析器规则中,您使用的是 ID

应该是:

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

You have some illegal characters after your IDENT token:

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

The : .; are invalid there. And you're also trying to mix the tree-rewrite operator ^ inside a lexer rule, which is illegal: remove them. Lastly, you've named it IDENT while in your parser rules, you're using ID.

It should be:

ID : ('a'..'z' | 'A'..'Z')+ ;
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文