helloworldparser.java
来自「java 词法分析器,用于一般的C,C++,VB,PS/SQL 语句的翻译」· Java 代码 · 共 40 行
JAVA
40 行
package fri.patterns.interpreter.parsergenerator.examples;import fri.patterns.interpreter.parsergenerator.Token;import fri.patterns.interpreter.parsergenerator.Lexer;import fri.patterns.interpreter.parsergenerator.Parser;import fri.patterns.interpreter.parsergenerator.ParserTables;import fri.patterns.interpreter.parsergenerator.syntax.Syntax;import fri.patterns.interpreter.parsergenerator.syntax.builder.SyntaxSeparation;import fri.patterns.interpreter.parsergenerator.lexer.LexerBuilder;import fri.patterns.interpreter.parsergenerator.parsertables.SLRParserTables;import fri.patterns.interpreter.parsergenerator.semantics.PrintSemantic;/** "Hello World" example. Checks if "Hello" is followed by "World", arbitrary whitespaces. This example shows how to build parser and lexer from scratch. @author Fritz Ritzberger*/public class HelloWorldParser{ private static final String [][] syntax = { { "Start", "\"Hello\"", "\"World\"" }, { Token.IGNORED, "`whitespaces`" }, }; public static void main(String [] args) throws Exception { SyntaxSeparation separation = new SyntaxSeparation(new Syntax(syntax)); // separate lexer and parser syntax LexerBuilder builder = new LexerBuilder(separation.getLexerSyntax(), separation.getIgnoredSymbols()); // build a Lexer Lexer lexer = builder.getLexer(); lexer.setInput("\tHello \r\n\tWorld\n"); // give the lexer some very complex input :-) ParserTables parserTables = new SLRParserTables(separation.getParserSyntax()); Parser parser = new Parser(parserTables); parser.parse(lexer, new PrintSemantic()); // start parsing with a print-semantic }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?