Go to file
Ewan Mellor 0e0ad04f01
Include the Swift runtime in "mvn clean".
Add an entry to pom.xml so that the runtime/Swift subdirectories that contain
build output are removed when "mvn clean" is used.
2017-11-01 15:03:27 -07:00
.github tweak issue template 2017-03-14 10:14:56 -07:00
.travis Switch the Linux Swift tests to Trusty and Swift 4.0. 2017-10-20 10:12:47 -07:00
antlr4-maven-plugin Always refresh grammars with changed dependencies 2017-07-19 18:03:36 -07:00
build update version so 4.5.1 tests/builds 2015-05-18 12:27:28 -07:00
doc Update getting-started.md 2017-10-23 18:15:47 +03:30
runtime Fix destructor 2017-10-30 22:56:57 +03:00
runtime-testsuite Remove tokenNames / getTokenNames from the Recognizer interface. 2017-10-25 13:28:40 -07:00
scripts/parse-extended-pictographic Extended Pictographic 2017-03-13 15:40:51 -06:00
tool Tidy up the exception handling around RecognitionException. 2017-10-25 13:30:08 -07:00
tool-testsuite Distinct error codes, added unit-test. fixes #1865. 2017-05-14 13:23:53 +03:00
.editorconfig Set the tab width in .editorconfig so GitHub shows source properly 2017-08-07 18:04:32 -05:00
.gitattributes Add default .gitattributes 2016-10-13 05:49:38 -05:00
.gitignore pull in pr1229 into branch: dotnetcore 2016-12-09 23:59:20 +00:00
.travis.yml Switch the Linux Swift tests to Trusty and Swift 4.0. 2017-10-20 10:12:47 -07:00
CHANGES.txt Update CHANGES.txt 2014-03-25 09:20:41 -07:00
CONTRIBUTING.md Fix doc-relative paths 2017-01-24 10:44:13 -08:00
LICENSE.txt tweak documentation about various targets 2017-03-30 10:44:28 -07:00
README.md add Ben to readme 2017-03-30 09:47:06 -07:00
appveyor.yml Fix the AppVeyor tests. 2017-10-25 12:03:32 -07:00
contributors.txt Updating contributors file. 2017-10-29 12:33:36 +03:00
pom.xml Include the Swift runtime in "mvn clean". 2017-11-01 15:03:27 -07:00

README.md

ANTLR v4

Build Travis-CI Status Build AppVeyor  Status Java 7+ License

ANTLR (ANother Tool for Language Recognition) is a powerful parser generator for reading, processing, executing, or translating structured text or binary files. It's widely used to build languages, tools, and frameworks. From a grammar, ANTLR generates a parser that can build parse trees and also generates a listener interface (or visitor) that makes it easy to respond to the recognition of phrases of interest.

Given day-job constraints, my time working on this project is limited so I'll have to focus first on fixing bugs rather than changing/improving the feature set. Likely I'll do it in bursts every few months. Please do not be offended if your bug or pull request does not yield a response! --parrt

Donate

Authors and major contributors

Useful information

You might also find the following pages useful, particularly if you want to mess around with the various target languages.

The Definitive ANTLR 4 Reference

Programmers run into parsing problems all the time. Whether its a data format like JSON, a network protocol like SMTP, a server configuration file for Apache, a PostScript/PDF file, or a simple spreadsheet macro language—ANTLR v4 and this book will demystify the process. ANTLR v4 has been rewritten from scratch to make it easier than ever to build parsers and the language applications built on top. This completely rewritten new edition of the bestselling Definitive ANTLR Reference shows you how to take advantage of these new features.

You can buy the book The Definitive ANTLR 4 Reference at amazon or an electronic version at the publisher's site.

You will find the Book source code useful.

Additional grammars

This repository is a collection of grammars without actions where the root directory name is the all-lowercase name of the language parsed by the grammar. For example, java, cpp, csharp, c, etc...