idea antlr4 使用

目录

1、安装ANTLR v4 grammar plugin插件

2、建立maven工程

3、新建CustomSql.g4文件

4、CustomSql.g4测试

5、编译CustomSql.g4,生成相关文件

6、代码测试


1、安装ANTLR v4 grammar plugin插件

 

2、建立maven工程

pom文件引入

 <dependencies> 
     <dependency>
            <groupId>org.antlr</groupId>
            <artifactId>antlr4-runtime</artifactId>
            <version>4.8-1</version>
        </dependency>
 </dependencies>  
  
 <plugins> 
         <plugin>
                <groupId>org.antlr</groupId>
                <artifactId>antlr4-maven-plugin</artifactId>
                <version>4.8-1</version>
                <executions>
                    <execution>
                        <goals>
                            <goal>antlr4</goal>
                        </goals>
                        <phase>none</phase>
                    </execution>
                </executions>
                <configuration>
                    <outputDirectory>src/main/java</outputDirectory>
                    <!--<listener>true</listener>-->
                    <visitor>true</visitor>
                    <!--<treatWarningsAsErrors>true</treatWarningsAsErrors>-->
                </configuration>
          </plugin>
</plugins>

 

3、新建CustomSql.g4文件

内容如下(以下内容就是一个简单的测试demo,一个数组的语法)

grammar CustomSql;

init : '{' value (',' value)* '}' ;
value : init
        |INT
        ;
INT : [0-9]+ ;
WS  : [\t\n\r]+ -> skip ;

 

4、CustomSql.g4测试

 

 

5、编译CustomSql.g4,生成相关文件

(1)设置路径

(2)生成文件

(3)生成的文件

 

6、代码测试

import org.antlr.v4.runtime.ANTLRInputStream;
import org.antlr.v4.runtime.CommonTokenStream;
import org.antlr.v4.runtime.tree.ParseTree;

import java.io.IOException;


public class Test {
    public static void main(String[] args) throws IOException {
        ANTLRInputStream input = new ANTLRInputStream("{2,{3},4}");
        //词法解析器,处理input
        CustomSqlLexer lexer = new CustomSqlLexer(input);
        //词法符号的缓冲器,存储词法分析器生成的词法符号
        CommonTokenStream tokens = new CommonTokenStream(lexer);
        //语法分析器,处理词法符号缓冲区的内容
        CustomSqlParser parser = new CustomSqlParser(tokens);
        
        ParseTree tree = parser.init();
        System.out.println(tree.toStringTree(parser));
    }
}