Go to file
WalterCouto 27c8eb5c6a C++: fix bug in PredictionContext::mergeArrays
In the orignal PredictionContext::mergeArrays there was a bug on Line 281 where the logic differs from java: It currently is:
bool both$ = payload == EMPTY_RETURN_STATE && a_parent && b_parent;
and should instead match java as:
bool both$ = payload == EMPTY_RETURN_STATE && !a_parent && !b_parent;
2018-12-20 10:07:59 -05:00
.github tweak issue template 2017-03-14 10:14:56 -07:00
.travis Make all the Travis test scripts exit in the event of error. 2018-11-15 15:33:10 -08:00
antlr4-maven-plugin [maven-release-plugin] prepare for next development iteration 2018-12-18 10:35:34 -08:00
build update version so 4.5.1 tests/builds 2015-05-18 12:27:28 -07:00
doc fix https link issue; fixes #2422 2018-11-22 14:17:51 -08:00
runtime C++: fix bug in PredictionContext::mergeArrays 2018-12-20 10:07:59 -05:00
runtime-testsuite [maven-release-plugin] prepare for next development iteration 2018-12-18 10:35:34 -08:00
scripts tweak script 2018-12-17 14:43:23 -08:00
tool [maven-release-plugin] prepare for next development iteration 2018-12-18 10:35:34 -08:00
tool-testsuite [maven-release-plugin] prepare for next development iteration 2018-12-18 10:35:34 -08: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 C++: fix bug in PredictionContext::mergeArrays 2018-12-20 10:07:59 -05:00
pom.xml [maven-release-plugin] prepare for next development iteration 2018-12-18 10:35:34 -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...