This library allows you to ease the creation of a language lexer based on finite state machines.
I'd appreciate feedback if you use this library :-)
The source code is released under the MIT license.
```rust
use ram::Automaton;
enum TokenType { End, }
// Create the FSM (2 states, 0 or 1) that will parse the source code let mut am = Automaton::new(0, 1); // When the FSM hits the end of the source, go to state 1, the final state am.find_end(TokenType::End as i32, 0, 1);
// Run the FSM with an empty string as the source code let sourcecode = format!(""); let mut runner = am.newrunner(source_code); runner.run();
// Print the parsed tokens to the console println!("{:?}", runner.tokens); ```
There are multiple find_*
methods to your disposal, like find_regex
or find_whitespace
or
even find_automaton
, which allows you to combine various finite state machines together
to create more powerful tokenizers.