safina
A safe Rust async runtime.
Features
forbid(unsafe_code)
- Depends only on
std
- Good test coverage (>92%)
Limitations
- Requires Rust
nightly
, forOnceCell
and Wake trait - Allocates memory. You can avoid allocations by using advanced functions, like
safina_executor::spawn_unpin
. - Not optimized
Documentation
safina_async_test
has an #[async_test]
macro for running async fn
test functions.
Examples
let executor = default;
let = channel;
executor.spawn;
receiver.recv.unwrap;
let result = block_on?;
Alternatives
smol
- Popular
- Contains generous amounts of
unsafe
code
async-std
- Very popular
- Contains generous amounts of
unsafe
code
futures
- Very popular
- Contains generous amounts of
unsafe
code
tokio
- Very popular
- Fast
- Internally extremely complicated
- Full of
unsafe
bastion
- Generous amounts of
unsafe
code
- Generous amounts of
nostd_async
Changelog
- v0.1.6 - Use
safina-executor
v0.1.3 API - v0.1.5 - Add
safina_sync::Mutex
- v0.1.4 - Upgrade to new safina-executor version which removes need for
Box::pin
. - v0.1.3 - Update docs
- v0.1.2 - Renamed
safina
crate tosafina-executor
. Added newsafina
crate with re-exports, examples, and integration tests. - v0.1.1 - Add badges to readme
- v0.1.0 - First published version
TO DO
- Add an integration test
- Add
init
function that starts worker threads and the timer thread. - Make it work on Rust stable
- Add an
#[async_main]
macro
Release Process
- Edit
Cargo.toml
and bump version number. - Run
./release.sh
License: Apache-2.0