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.
This is a fork
This is the "optimized" fork of ANTLR 4, which contains many features and optimizations not present in the reference release. For information about these features, see doc/optimized-fork.md.
Authors and major contributors
- Terence Parr, email@example.com ANTLR project lead and supreme dictator for life University of San Francisco
- Sam Harwell (Tool co-author, lead developer for the optimized fork along with the optimized Java, C#, and TypeScript targets)
- Burt Harris (Co-author of the optimized TypeScript target)
- Release notes
- Getting started with v4
- Official site
- Reference (non-optimized) release
- ANTLR optimized code generation targets
- Java API
- ANTLR v3
- v3 to v4 Migration, differences
The Definitive ANTLR 4 Reference
Programmers run into parsing problems all the time. Whether it’s 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 will find the Book source code useful.
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...