ANTLR "Hello" Grammar File and Test


How to create a simple "Hello" grammar file and test it with ANTLR?

✍: FYIcenter


There 4 steps you need to follow to create "Hello" grammar file and test it:

1. Create grammar file, Hello.g4:

// Define a grammar called Hello
grammar Hello;
r  : 'hello' ID ;         // match keyword hello followed by an identifier
ID : [a-z]+ ;             // match lower-case identifiers
WS : [ \t\r\n]+ -> skip ; // skip spaces, tabs, newlines

2. Generate the lexer and parser in Java:

\fyicenter>java -cp antlr-4.7.1-complete.jar org.antlr.v4.Tool Hello.g4

     308 Hello.interp
      31 Hello.tokens
   1,055 HelloLexer.interp
      31 HelloLexer.tokens

3. Compile the lexer, parser and supporting Java classes

\fyicenter>javac -cp .;antlr-4.7.1-complete.jar Hello*.java

\fyicenter>dir *.class
   3,511 HelloLexer.class
     304 HelloListener.class
     869 HelloParser$RContext.class
   4,157 HelloParser.class

4. Testing the lexer and parser with ANTLR TestRig:

\fyicenter>java -cp .;antlr-4.7.1-complete.jar \
   org.antlr.v4.gui.TestRig Hello r -tree
hello you
(r hello you)

The above output shows that the Hello lexer and parser is working:

  • Argument "Hello" tells the TestRig to use the "Hello" lexer and parser.
  • Argument "r" tells the TestRig to start parsing source code the grammar rule "r".
  • Option "-tree" tells the TestRig to display parser output in text tree format.
  • No input file specified. So source code was entered from the console.
  • The source code is 1 line: "hello you".
  • "^Z" indicates that Ctrl-Z was pressed to end the source code.
  • "(r hello you)" is the output of the parser indicating source coded parsed correctly.


⇒ ANTLR "Hello" Lexer and Parser Error

⇐ ANTLR TestRig Command and Options

⇑ ANTLR Commands and Examples

⇑⇑ FAQ for ANTLR Parser Generator

2020-12-02, 6618👍, 0💬