Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/shnewto/bnf
Parse BNF grammar definitions
https://github.com/shnewto/bnf
backus-naur-form bnf crates earley earley-parser grammar parse-forest parse-tree parser rust rust-crate rust-lang rustlang sentence-generator sppf
Last synced: 2 days ago
JSON representation
Parse BNF grammar definitions
- Host: GitHub
- URL: https://github.com/shnewto/bnf
- Owner: shnewto
- License: mit
- Created: 2017-10-23T03:25:02.000Z (about 7 years ago)
- Default Branch: main
- Last Pushed: 2025-01-05T01:41:16.000Z (14 days ago)
- Last Synced: 2025-01-11T00:22:09.685Z (8 days ago)
- Topics: backus-naur-form, bnf, crates, earley, earley-parser, grammar, parse-forest, parse-tree, parser, rust, rust-crate, rust-lang, rustlang, sentence-generator, sppf
- Language: Rust
- Homepage:
- Size: 319 KB
- Stars: 264
- Watchers: 8
- Forks: 24
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-rust-cn - shnewto/bnf - free grammars. [<img src="https://api.travis-ci.org/shnewto/bnf.svg?branch=master">](https://travis-ci.org/shnewto/bnf) (Libraries / Language specification)
- awesome-rust - shnewto/bnf - free grammars. [<img src="https://api.travis-ci.org/shnewto/bnf.svg?branch=master">](https://travis-ci.org/shnewto/bnf) (Libraries / Language specification)
- awesome-rust - shnewto/bnf - free grammars. (Libraries / Language specification)
- awesome-rust-cn - shnewto/bnf
- awesome-rust-zh - shnewto/bnf - 用于解析无关上下文, Backus-Naur 形式语法的库。[<img src="https://api.travis-ci.org/shnewto/bnf.svg?branch=master">](https://travis-ci.org/shnewto/bnf) (库 / 语言规范)
README
# bnf
[![.github/workflows/ci.yml](https://github.com/shnewto/bnf/actions/workflows/ci.yml/badge.svg?branch=main)](https://github.com/shnewto/bnf/actions)
[![coveralls](https://coveralls.io/repos/github/shnewto/bnf/badge.svg?branch=main)](https://coveralls.io/github/shnewto/bnf?branch=main)
[![Crates.io Version](https://img.shields.io/crates/v/bnf.svg)](https://crates.io/crates/bnf)
[![Crates.io](https://img.shields.io/crates/d/bnf.svg)](https://crates.io/crates/bnf)
[![LICENSE](https://img.shields.io/badge/license-MIT-blue.svg)](https://github.com/shnewto/bnf/blob/main/LICENSE)A library for parsing Backus–Naur form context-free grammars.
## What does a parsable BNF grammar look like?
The following grammar from the
[Wikipedia page on Backus-Naur form](https://en.wikipedia.org/wiki/Backus%E2%80%93Naur_form#Example)
exemplifies a compatible grammar. (*Note: parser allows for an optional ';'
to indicate the end of a production)```text
::=::=
|::= "." |
::=
::= ","
::= "Sr." | "Jr." | | ""
::= | ""
```## Output
Take the following grammar for DNA sequences to be input to this library's
`parse` function.
```text
::= |
::= "A" | "C" | "G" | "T"
```The output is a `Grammar` object representing a tree that looks like this:
```text
Grammar {
productions: [
Production {
lhs: Nonterminal(
"dna"
),
rhs: [
Expression {
terms: [
Nonterminal(
"base"
)
]
},
Expression {
terms: [
Nonterminal(
"base"
),
Nonterminal(
"dna"
)
]
}
]
},
Production {
lhs: Nonterminal(
"base"
),
rhs: [
Expression {
terms: [
Terminal(
"A"
)
]
},
Expression {
terms: [
Terminal(
"C"
)
]
},
Expression {
terms: [
Terminal(
"G"
)
]
},
Expression {
terms: [
Terminal(
"T"
)
]
}
]
}
]
}```
Once the `Grammar` object is populated, to generate a random sentence from it
call the object's generate function. `grammar.generate()`. For the above grammar
you could expect something like `TGGC` or `AG`.If the generate function can't find a production for a nonterminal it tries
to evaluate it will print the identifer as a nonterminal, i.e. ``.The generate function will return an error if it detects an infinite loop caused
by a production such as ` ::= `.## Parse Example
```rust
use bnf::Grammar;let input =
" ::=::=
|::= '.' |
::=
::= ','
::= 'Sr.' | 'Jr.' | | ''
::= | ''";let grammar: Result = input.parse();
match grammar {
Ok(g) => println!("{:#?}", g),
Err(e) => println!("Failed to make grammar from String: {}", e),
}
```
## Generate Example```rust
use bnf::Grammar;let input =
" ::= |
::= 'A' | 'C' | 'G' | 'T'";
let grammar: Grammar = input.parse().unwrap();
let sentence = grammar.generate();
match sentence {
Ok(s) => println!("random sentence: {}", s),
Err(e) => println!("something went wrong: {}!", e)
}
```## Parse Sentence via Grammar
```rust
use bnf::Grammar;let input =
" ::= |
::= 'A' | 'C' | 'G' | 'T'";
let grammar: Grammar = input.parse().unwrap();let sentence = "GATTACA";
let mut parse_trees = grammar.parse_input(sentence);
match parse_trees.next() {
Some(parse_tree) => println!("{}", parse_tree),
_ => println!("Grammar could not parse sentence"),
}
```