An open API service indexing awesome lists of open source software.

https://github.com/sunli829/xactor

Xactor is a rust actors framework based on async-std
https://github.com/sunli829/xactor

actor actor-model async async-std rust rust-lang

Last synced: 10 months ago
JSON representation

Xactor is a rust actors framework based on async-std

Awesome Lists containing this project

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)