Indeed, an actor library, not a framework, written in Rust
Cargo.toml
toml
[dependencies]
actorlib = "0.1.2"
echo.rs
```rust pub struct Echo;
pub enum Message { Ping, }
pub enum Response { Pong {counter: u32}, }
pub struct State { pub counter: u32, }
impl Echo {
pub async fn new() -> Arc
let state = State {
counter: 0,
};
Actor::new("echo".to_string(), move |ctx| {
Box::pin(async move {
match ctx.mgs {
Message::Ping => {
println!("Received Ping");
let mut state_lock = ctx.state.lock().await;
state_lock.counter += 1;
Ok(Response::Pong{counter: state_lock.counter})
}
}
})
}, state, 100000).await
}
} ```
main.rs
```rust
async fn main() -> Result<(), BoxDynError> { let echo = Echo::new().await;
println!("Sent Ping");
echo.send(Message::Ping).await?;
println!("Sent Ping and ask response");
let pong = echo.ask(Message::Ping).await?;
println!("Got {:?}", pong);
println!("Sent Ping and wait response in callback");
echo.callback(Message::Ping, move |result| {
Box::pin(async move {
let response = result?;
println!("Got {:?}", response);
Ok(())
})
}).await?;
_ = echo.stop();
thread::sleep(std::time::Duration::from_secs(1));
Ok(())
} ```
Example output:
text
Sent Ping
Sent Ping and ask response
Received Ping
Received Ping
Got Pong { counter: 2 }
Sent Ping and wait response in callback
Received Ping
Got Pong { counter: 3 }
Example sources: https://github.com/evgenyigumnov/actor-lib/tree/main/examples/ping_pong