Actorlib

Project license Pull Requests welcome Rust crate

Indeed, an actor library, not a framework, written in Rust

Features

Usage

Cargo.toml

toml [dependencies] actorlib = "1.2.1"

echo.rs

```rust

[derive(Debug)]

pub struct Echo;

[derive(Debug)]

pub enum Message { Ping, }

[derive(Debug)]

pub enum Response { Pong {counter: u32}, }

[derive(Debug,Clone)]

pub struct State { pub counter: u32, }

[derive(Debug, Error)]

pub enum EchoError { #[error("unknown error")] Unknown, #[error("std::io::Error")] StdErr(#[from] std::io::Error), }

[async_trait]

impl Handler for Echo { async fn receive(&self, ctx: Arc>) -> Result { match ctx.mgs { Message::Ping => { println!("Received Ping"); let mut statelock = ctx.state.lock().await; statelock.counter += 1; if statelock.counter > 10 { Err(EchoError::Unknown) } else { Ok(Response::Pong{counter: statelock.counter}) } } } } } ```

main.rs

```rust

[tokio::main]

async fn main() -> Result<(), EchoError> { let state = State { counter: 0, };

let echo_ref = ActorRef::new("echo".to_string(), Echo{},  state, 100000).await;

println!("Sent Ping");
echo_ref.send(Message::Ping).await?;

println!("Sent Ping and ask response");
let pong = echo_ref.ask(Message::Ping).await?;
println!("Got {:?}", pong);

_ = echo_ref.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 }

Example sources: https://github.com/evgenyigumnov/actor-lib/tree/main/test