我创建了antlr4语法文件Jay.g4,并生成了JayLexer.java和JayParser.java。我编译了这些代码来创建JayLexer.class和JayParser.class。
我的问题是:如何在Java中使用这些生成的源代码?我使用的是NetBeans集成开发环境,但我不知道如何将词法分析器和解析器集成到我的项目中,并使它们正常工作。
发布于 2014-10-19 23:02:35
如果你想进一步尝试,我推荐The Definitive Antlr 4 Reference。您可以从Antlr documentation下载/查看一些示例代码,其中包括:
final LexerGrammar lg = (LexerGrammar) Grammar.load(lexerGrammarFileName);
final Grammar pg = Grammar.load(parserGrammarFileName, lg);
ANTLRFileStream input = new ANTLRFileStream(fileNameToParse);
LexerInterpreter lexEngine = lg.createLexerInterpreter(input);
CommonTokenStream tokens = new CommonTokenStream(lexEngine);
ParserInterpreter parser = pg.createParserInterpreter(tokens);
ParseTree t = parser.parse(pg.getRule(startRule).index);
System.out.println("parse tree: " + t.toStringTree(parser));但是,如果您有JayLexer和JayParser类,则更愿意编写如下内容:
ANTLRFileStream input = new ANTLRFileStream(fileName); // a character stream
JayLexer lex = new JayLexer(input); // transforms characters into tokens
CommonTokenStream tokens = new CommonTokenStream(lex); // a token stream
JayParser parser = new JayParser(tokens); // transforms tokens into parse trees
ParseTree t = parser.your_first_rule_name(); // creates the parse tree from the called rule然后根据需要使用解析树,例如实现JayBaseListener或JayBaseVisitor的类。有关更多信息,请查看其中一个给定的链接。
https://stackoverflow.com/questions/26451636
复制相似问题