我试图匹配一个非常基本的ANTLR语法。但是ANTLR一直在告诉我他得到了输入。并期望“.”。
完全错误是:
line 1:0 extraneous input '.' expecting '.'
line 1:2 missing '*' at '<EOF>'有语法:
grammar regex;
@parser::header
{
package antlr;
}
@lexer::header
{
package antlr;
}
WHITESPACE : (' ' | '\t' | '\n' | '\r') -> channel(HIDDEN);
COMP : '.';
KLEENE : '*';
start : COMP KLEENE;和投入:
.*这两个文件具有相同的字符集:
regex.g: text/plain; charset=us-ascii
test.grammar: text/plain; charset=us-ascii不应该混淆莱克星规则。为什么这不像预期的那样起作用?
发布于 2018-03-26 08:12:34
给定您的示例语法和这个测试类:
import org.antlr.v4.runtime.*;
public class Main {
public static void main(String[] args) {
String source = ".*";
regexLexer lexer = new regexLexer(CharStreams.fromString(source));
regexParser parser = new regexParser(new CommonTokenStream(lexer));
System.out.println(parser.start().toStringTree(parser));
}
}以下内容已打印到我的控制台:
(start . *)我的猜测是,您要么把语法搞得太差,导致原来语法中的错误消失了,要么您没有生成新的lexer/解析器类。
https://stackoverflow.com/questions/49486486
复制相似问题