#actor #run-time #async #erlang #pony

stakker

A lightweight low-level single-threaded actor runtime

20 releases

0.2.11 May 28, 2024
0.2.10 Aug 6, 2023
0.2.9 Jul 24, 2023
0.2.6 Mar 29, 2023
0.0.2 Mar 4, 2020

#118 in Asynchronous

Download history 1/week @ 2024-09-08 12/week @ 2024-09-15 15/week @ 2024-09-22 20/week @ 2024-09-29 7/week @ 2024-10-06 4/week @ 2024-10-13 13/week @ 2024-10-20 9/week @ 2024-10-27 15/week @ 2024-11-03 7/week @ 2024-11-10 22/week @ 2024-11-17 24/week @ 2024-11-24 43/week @ 2024-12-01 72/week @ 2024-12-08 42/week @ 2024-12-15 7/week @ 2024-12-22

168 downloads per month
Used in 4 crates

MIT/Apache

395KB
6.5K SLoC

A lightweight low-level single-threaded actor runtime

license:MIT/Apache-2.0 github:uazu/stakker crates.io:stakker docs.rs:stakker uazu.github.io:stakker

Stakker is designed to be layered on top of whatever event loop the user prefers to use. It aims to take maximum advantage of Rust's compile-time checks and optimisations.

Documentation

See the crate documentation and the Stakker Guide and Design Notes

License

This project is licensed under either the Apache License version 2 or the MIT license, at your option. (See LICENSE-APACHE and LICENSE-MIT).

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Maintenance approach

You're very welcome to try to break this code! I intend to conform to Rust safety conventions, including on internal interfaces. Any unsound behaviour that can be shown to exist will be treated as a serious bug, and I will endeavour to find a solution as soon as reasonably possible.

I reserve the right to (metaphorically) go off to a mountain-top cave to consider issues in depth, to make the right decision without being rushed.

Most of the design decisions in this software have had a lot of consideration, with many different approaches tried and discarded before arriving at the current solution. The current implementations have been rewritten and refactored and minimised to get to the current state. So I'd ask that any requests for changes to how things are done be accompanied by some reasonably in-depth justification, such as example use-cases that require the change, or some other discussion of why that change would be a good one. I prefer to keep the code tight, so I might need to refactor PRs, or reimplement them a different way.

Dependencies

~260KB