jsinger67 / lalry

CFGs to LALR(1) parse tables

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Rust Docs.rs Crates.io

lalry - a library for creating LALR(1) parsers from context-free grammars

This is a fork of the great lalr crate, a library for creating LALR(1) parsers from context-free grammars.

Additions to lalr

To make the generation of parse tables more flexible lalry adds a way to control this process. The trait Config is used for this and a custom implementation can be provided to deviate from the default. To keep the default behavior as in previous versions the user can use the DefaultConfig structure that provides the implementation of the standard behavior.

Properties of lalry

lalry, although not the main goal, is functionally fully compatible with it's ancestor lalr. It can be used as drop-in replacement with only minor adaptions.

All you need to do is to create a DefaultConfig and hand it over to the call to lalr1:

let config = DefaultConfig::new();
let parse_table = grammar.lalr1(&config).unwrap();

By using a default configuration you get the exact same functionality as if you had called

let parse_table = grammar.lalr1(|_, _| true, |_, _| 0).unwrap();

with lalr style API.

About

CFGs to LALR(1) parse tables

License:Other


Languages

Language:Rust 100.0%