Crates.io | pomelo |
lib.rs | pomelo |
version | 0.1.5 |
source | src |
created_at | 2019-06-12 16:38:36.179011 |
updated_at | 2021-01-08 21:05:11.961413 |
description | Implementation of the Lemon parser generator as a Rust procedural macro |
homepage | |
repository | https://github.com/rodrigorc/pomelo |
max_upload_size | |
id | 140627 |
size | 185,927 |
A procedural macro to create Lemon-like parsers.
Pomelo is a port to Rust of the Lemon Parser Generator (from now on, Lemon_C) originally written by D. Richard Hipp for his SQLite parser. It is based on a previous attempt to port Lemon to Rust (Lemon_Rust), but now it is written as a Rust procedural macro, so it does not contain any of the original C code (although it uses the same algorithms). Thus the change in name to a different citrus fruit.
It is recommended to go to crates.io for the newest released version, as well as links to the newest builds of the docs.
Just add the following dependency to your Cargo manifest:
[dependencies]
pomelo = "*"
use pomelo::pomelo;
pomelo! {
%type input Vec<i32>;
%type numbers Vec<i32>;
%type Number i32;
input ::= numbers?(A) { A.unwrap_or_else(Vec::new) };
numbers ::= Number(N) { vec![N] }
numbers ::= numbers(mut L) Comma Number(N) { L.push(N); L }
}
fn main() -> Result<(), ()> {
use parser::{Parser, Token};
//Real world code would use a tokenizer
let tokens = vec![
Token::Number(1),
Token::Comma,
Token::Number(2),
Token::Comma,
Token::Number(3),
];
let mut p = Parser::new();
for tok in tokens.into_iter() {
p.parse(tok)?;
}
let data = p.end_of_input()?;
assert_eq!(data, vec![1, 2, 3]);
Ok(())
}
See more examples in the github repo folder.
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.