34 releases (stable)
12.1.0 | Mar 12, 2024 |
---|---|
11.0.0 | Feb 20, 2024 |
10.0.1 | Feb 14, 2024 |
9.1.2 | Feb 13, 2024 |
0.3.1 | Mar 30, 2022 |
#201 in Text processing
1,191 downloads per month
125KB
3K
SLoC
jayce
jayce is a tokenizer 🌌
Example
use jayce::{Duo, Tokenizer};
use std::sync::OnceLock;
const SOURCE: &str = "Excalibur = 5000$; // Your own language!";
fn duos() -> &'static Vec<Duo<&'static str>> {
static DUOS: OnceLock<Vec<Duo<&'static str>>> = OnceLock::new();
DUOS.get_or_init(|| {
vec![
Duo::new("whitespace", r"^[^\S\n]+", false),
Duo::new("commentLine", r"^//(.*)", false),
Duo::new("commentBlock", r"^/\*(.|\n)*?\*/", false),
Duo::new("newline", r"^\n", false),
Duo::new("price", r"^[0-9]+\$", true),
Duo::new("semicolon", r"^;", true),
Duo::new("operator", r"^=", true),
Duo::new("name", r"^[a-zA-Z_]+", true),
]
})
}
fn main() -> Result<(), Box<dyn std::error::Error>> {
let mut tokenizer = Tokenizer::new(SOURCE, duos());
while let Some(token) = tokenizer.consume()? {
println!("{:?}", token);
}
Ok(())
}
Result
Token { kind: "name", value: "Excalibur", pos: (1, 1) }
Token { kind: "operator", value: "=", pos: (1, 11) }
Token { kind: "price", value: "5000$", pos: (1, 13) }
Token { kind: "semicolon", value: ";", pos: (1, 18) }
Info
Tokenizer::consume
returns Result Option Token
Ok Some
match foundOk None
end of sourceErr
an error occurs
Tokenizer::consume_all
returns Result Vec Token
Ok Vec Token
tokens matchedErr
an error occurs
Performances
initialization in ~3 nanoseconds
tokenization of Yuumi in ~4 milliseconds
Features
generic-simd
runtime-dispatch-simd
default enabled, to disable modifyCargo.toml
as follows
jayce = { version = "X.X.X", default-features = false }
Dependencies
~2.2–3MB
~55K SLoC