Go to file
Ewan Mellor 167a3b8808
[Swift] Remove Recognizer.tokenTypeMapCache and .ruleIndexMapCache.
Remove Recognizer.tokenTypeMapCache and .ruleIndexMapCache.  These
were easily replaced in Swift with lazy vars.  The input to these
two caches are fixed fields on the Recognizer (the Vocabulary and
rule names respectively) so a lazy var suffices.

Note that these differed compared with the Java runtime -- they are
declared as static in Java and therefore the caches are shared across
all recognizer instances, but the Swift runtime had them as Recognizer
instance variables, which meant that at most we had a cache with one
entry which got destroyed along with the parser.  Regardless, using
lazy vars is still simpler.

This removes the only usage of ArrayWrapper in the Swift runtime, so
delete that too.
2017-11-10 16:45:24 -08:00
.github tweak issue template 2017-03-14 10:14:56 -07:00
.travis Run the Swift runtime unit tests during the Travis run. 2017-11-04 11:41:20 -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 Merge pull request #2086 from ewanmellor/message-output 2017-11-04 10:49:37 -07:00
runtime [Swift] Remove Recognizer.tokenTypeMapCache and .ruleIndexMapCache. 2017-11-10 16:45:24 -08: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 Merge branch 'master' of github.com:antlr/antlr4 2017-11-05 08:49:04 -08: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 Merge pull request #2091 from ewanmellor/travis-cache-dotnet-osx 2017-11-04 10:50:00 -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 Add cache entries to appveyor.yml. 2017-10-29 11:50:14 -07:00
contributors.txt Sign contributors.txt 2017-11-02 17:28:42 -04: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...