A parser for ABNF based on nom 5.
```rust use abnf::rulelist;
match rulelist("a = b / c\nc = *(d e)\n") { Ok(rules) => println!("{:#?}", rules), Err(error) => eprintln!("{}", error), } ```
[
Rule {
name: "a",
node: Alternation(
[
Rulename(
"b",
),
Rulename(
"c",
),
],
),
kind: Basic,
},
Rule {
name: "c",
node: Repetition(
Repetition {
repeat: Repeat {
min: None,
max: None,
},
node: Group(
Concatenation(
[
Rulename(
"d",
),
Rulename(
"e",
),
],
),
),
},
),
kind: Basic,
},
]
This crate is dual-licensed under Apache 2.0 and MIT terms.