Thanks to visit codestin.com
Credit goes to github.com

Skip to content
/ xactor Public
forked from sunli829/xactor

Xactor is a rust actors framework based on async-std

License

alborq/xactor

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

63 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Xactor is a rust actors framework based on async-std

Documentation

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

use xactor::*;

#[message(result = "String")]
struct ToUppercase(String);

struct MyActor;

impl Actor for MyActor {}

#[async_trait::async_trait]
impl Handler<ToUppercase> for MyActor {
    async fn handle(&mut self, _ctx: &Context<Self>, 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

Wait for response Send only
Actix 1548 ms 14 ms
Xactor 930 ms 18 ms

GitHub repository

Installation

Xactor require async-trait on useland

With cargo add installed run:

$ cargo add xactor
$ cargo add async-trait

We also provide a set of "tokio-runtime" features instead of async-std. to use it you need activate feautre: runtime-tokio and desable default.

You can edit your Cargo.toml has following:

xactor = { version = "x.x.x", features = ["runtime-tokio"], default-features = false }

References

About

Xactor is a rust actors framework based on async-std

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 100.0%