# xactor **Repository Path**: rustup/xactor ## Basic Information - **Project Name**: xactor - **Description**: Xactor is a rust actors framework based on async-std. Actor communication in a local context Using Futures for asynchronous message handling Typed messages (No Any type). Generic messages are allowed - **Primary Language**: Rust - **License**: MIT - **Default Branch**: master - **Homepage**: https://github.com/sunli829/xactor - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2023-02-08 - **Last Updated**: 2023-02-08 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # Xactor is a rust actors framework based on async-std
Crates.io version Download docs.rs docs
## Documentation * [GitHub repository](https://github.com/sunli829/xactor) * [Cargo package](https://crates.io/crates/xactor) * Minimum supported Rust version: 1.39 or later ## Features * Async actors. * Actor communication in a local context. * Using Futures for asynchronous message handling. * Typed messages (No `Any` type). Generic messages are allowed. ## Examples ```rust use xactor::*; #[message(result = "String")] struct ToUppercase(String); struct MyActor; impl Actor for MyActor {} #[async_trait::async_trait] impl Handler for MyActor { async fn handle(&mut self, _ctx: &mut Context, msg: ToUppercase) -> String { msg.0.to_uppercase() } } #[xactor::main] async fn main() -> Result<()> { // Start actor and get its address let mut addr = MyActor.start().await?; // Send message `ToUppercase` to actor via addr let res = addr.call(ToUppercase("lowercase".to_string())).await?; assert_eq!(res, "LOWERCASE"); Ok(()) } ``` ## Performance https://github.com/sunli829/xactor-benchmarks ## Installation Xactor requires [async-trait](https://github.com/dtolnay/async-trait) on userland. With [cargo add][cargo-add] installed, run: ```sh $ cargo add xactor $ cargo add async-trait ``` We also provide the [tokio](https://tokio.rs/) runtime instead of [async-std](https://async.rs/). To use it, you need to activate `runtime-tokio` and disable default features. You can edit your `Cargo.toml` as follows: ```toml xactor = { version = "x.x.x", features = ["runtime-tokio"], default-features = false } ``` [cargo-add]: https://github.com/killercup/cargo-edit ## References * [Actix](https://github.com/actix/actix) * [Async-std](https://github.com/async-rs/async-std) * [Tokio](https://github.com/tokio-rs/tokio)