Support an Open Source Developer!
Read the documentation.
State
trait that is simple to implement.- Generic stack-based state machine, for all your needs.
- State update functions.
- State pause and unpause.
Add the following to you Cargo.toml file:
game_state_machine = "*"
Use it like so:
use game_state_machine::*;
type StateData = (isize, isize);
pub struct Test;
impl State<StateData> for Test {
fn on_start(&mut self, data: &mut StateData) {
data.0 += data.1;
}
fn on_resume(&mut self, data: &mut StateData) {
self.on_start(data);
}
fn update(&mut self, _data: &mut StateData) -> StateTransition<StateData> {
StateTransition::Push(Box::new(Test))
}
}
fn main() {
let mut sm = StateMachine::<StateData>::default();
let mut state_data = (0, 10);
sm.push(Box::new(Test), &mut state_data);
assert!(state_data.0 == 10);
sm.update(&mut state_data);
assert!(state_data.0 == 20);
sm.stop(&mut state_data);
assert!(state_data.0 == 20);
assert!(!sm.is_running())
}
- Maintainer: Jojolepro
- Contact: jojolepro [at] jojolepro [dot] com
- Website: jojolepro.com
- Patreon: patreon