Go to file
Ewan Mellor 8cd798431d
[Swift] Change getStateToAltMap to use Int as the dictionary key, not ATNState.
The ATNState hashValue and == override are just using the stateNumber field, so
using the Int directly is equivalent, and saves bouncing through those methods.

This also seems to be a correctness issue with the new Hashable protocol changes in
Swift 4.2 (though I admit that I don't know why).

Remove PredictionMode.getStateToAltMap, which was just a stub onto
ATNConfigSet.getStateToAltMap and didn't seem to be doing anything useful.
2018-11-15 11:26:09 -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 Merge branch 'master' of github.com:antlr/antlr4 2018-11-08 13:36:02 -08:00
runtime [Swift] Change getStateToAltMap to use Int as the dictionary key, not ATNState. 2018-11-15 11:26:09 -08:00
runtime-testsuite [Swift] Suppress "Optional" in the output when printing a value. 2018-11-15 11:26:09 -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 Move Travis tests to Swift 4.2 and Xcode 10.1. 2018-11-15 11:25:37 -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 revert groupId change 2018-04-24 07:27:26 -05: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...