BNFC-meta

Deriving Parsers and Quasi-Quoters from BNF Grammars

LTS Haskell 19.25:0.6.1@rev:4
Stackage Nightly 2022-09-27:0.6.1@rev:4
Latest on Hackage:0.6.1@rev:4

See all snapshots BNFC-meta appears in

GPL-2.0-only licensed by Jonas DuregÄrd
Maintained by Artem Pelenitsyn
This version can be pinned in stack with:BNFC-meta-0.6.1@sha256:1a8cbb72fdecd4214334b0af08b8c1c469d24177c33761ef3756effb7f9d59fa,2609

Module documentation for 0.6.1

This package provides a very simple way of defining a compiler front-end for a language by embedding a BNF grammar directly into a Haskell source file. Specifically, given a quasi-quoted LBNF grammar (as used by the BNF Converter) it generates (using Template Haskell) a LALR parser and pretty pretty printer for the language. The parser is then used to automatically define a quasi-quoter for the defined language so it can also be seamlessly embedded in Haskell source code. With a simple addition to the gramwmar, the user can define a universal syntax for anti-quoting. This means that any grammar non-terminal can be replaced by a quoted Haskell expression of the appropriate type. A few example languages are included in the source tarball.

The LBNF grammar formalism is described thoroughly in the BNF Converter documentation: http://bnfc.digitalgrammars.com/

This library and the additions it makes to LBNF is described in a 2011 Haskell Symposium paper titled "Embedded Parser Generators": http://wiki.portal.chalmers.se/cse/pmwiki.php/FP/EmbeddedParserGenerators