antlr4-Can't load Hello as lexer or parser

I recently have to use parser to do a project. I download ANTLR4 and follow the steps described in the book The Definitive ANTLR4 Reference. The following are the steps I type in command line:

 1. export CLASSPATH=".:/<Mydirectory>/antlr-4.2.2-complete.jar:$CLASSPATH"
 2. alias antlr4='java -jar /<My directory>/antlr-4.2.2-complete.jar'
 3. alias grun='java org.antlr.v4.runtime.misc.TestRig'
 4. antlr4 Hello.g4

All the things work fine, it generates java files that I need. However, after I enter

 5. grun Hello r -tokens

It reports

Can't load Hello as lexer or parser.

I google some info, but still cannot figure out what happened.


Solution 1:

You generated Java source files by running ANTLR on the grammar, but TestRig is looking for compiled .class files. You need to run the Java compiler on the source files before using TestRig.

Solution 2:

I had exactly the same error on Windows. My batch is set like this at first:

java -cp "C:\ANTLR\antlr-4.4-complete.jar" org.antlr.v4.runtime.misc.TestRig %*

It turns out all my compiled Hello*.class files are located in current folder and I forget to include the current folder in the -cp. After I change to below. It works. Note the leading dot in the -cp.

java -cp ".;C:\ANTLR\antlr-4.4-complete.jar" org.antlr.v4.runtime.misc.TestRig %*

Solution 3:

After all of your *.java files have been generated, and your *.class files have been generated, and your %CLASSPATH% is set correctly, based on the "Hello World" example grammar, you should not see this error.

If you don't have the "antlr-runtime-4.4.jar" in your %CLASSPATH% environment variable and run "grun" code from the book, you will receive this error when you run your generated parser based on the grammar you supplied.

%CLASSPATH% should be:

C:\libraries\antlr-4.4-complete.jar;C:\libraries\antlr-runtime-4.4.jar;

Enter the input after this command is entered. Like "hello parrt" in the book example. Then enter CTRL+Z (in Windows) to end the input, or CTRL+D (on Unix).

Solution 4:

In order to do this correctly, I'm going to assume that you've got a JDK installed and added to your system PATH variable.

In this case you will need two batch files to help you out.

antlr4.bat:

java -cp antlr-4.2-complete.jar org.antlr.v4.Tool %*

grun.bat:

java -cp .;antlr-4.2-complete.jar org.antlr.v4.runtime.misc.TestRig %*

This also assumes that you have the antlr-4.2-complete.jar in the current directory. Beyond that simply follow the instructions in the getting started guide.

Note that I used the -cp flag because, on Windows 7, I'm not seeing a CLASSPATH variable.

Solution 5:

On macOS, the correct incantations appear to be (assuming you've downloaded ANTLR 4.8, and created a file Hello.g4):

java -jar antlr-4.8-complete.jar Hello.g4
javac -cp antlr-4.8-complete.jar Hello*.java
java --class-path ".:antlr-4.8-complete.jar" org.antlr.v4.gui.TestRig Hello r -gui

These commands will generate the Java source files, compile them, and then start TestRig, waiting for you to enter an expression.