Go to file
Ewan Mellor 3699ea5412
Exclude intermediate build products from the runtime-testsuite jar.
This means that if you build in an unclean source tree, you don't end up with
intermediate classes in the jar.  (This hasn't broken anything that I noticed,
but it bloats the jar and I wanted to make sure it wasn't messing anything up.)

This excludes .build (the Swift runtime's build directory), target (the Java
runtime's build directory) and Swift/*.xcodeproj (which is not in the source tree
but can be created by devs who are using Xcode).
2018-11-15 15:33:10 -08:00
.github tweak issue template 2017-03-14 10:14:56 -07:00
.travis Move Travis tests to Swift 4.2 and Xcode 10.1. 2018-11-15 11:25:37 -08:00
antlr4-maven-plugin [maven-release-plugin] prepare for next development iteration 2017-12-09 12:04:26 -08:00
build update version so 4.5.1 tests/builds 2015-05-18 12:27:28 -07:00
doc [Swift] Add version info to the documentation. 2018-11-15 11:26:09 -08:00
runtime [Swift] Make ParserATNSimulator.precedenceTransition return a nullable value. 2018-11-15 15:28:47 -08:00
runtime-testsuite Exclude intermediate build products from the runtime-testsuite jar. 2018-11-15 15:33:10 -08:00
scripts update release notes auto generator 2017-12-08 13:07:59 -08:00
tool Use STGroupFile filename constructor 2018-11-13 14:59:12 -06:00
tool-testsuite Fix ST4 Snapshot dependency 2018-11-15 00:13:02 +01: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 Write any dumpstream files into the Travis logs. 2018-11-15 15:33:10 -08: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 Changed travis repo badge to svg 2018-01-23 15:47:05 -08:00
appveyor.yml #2021 nuget artifact in appveyor 2017-11-13 08:47:15 +03:00
contributors.txt Fix ST4 Snapshot dependency 2018-11-15 00:13:02 +01:00
pom.xml Fix mvn clean's deleting of the Swift .build directory. 2018-11-15 15:33:10 -08: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...