#async-executor #product-os #tokio #async-io #compile-time #async-std #smol

product-os-async-executor

Product OS : Async Executor provides a set of tools to handle async execution generically so that the desired async library (e.g. tokio, smol) to be used can be chosen at compile time.

16 releases

new 0.0.17 Jan 12, 2025
0.0.16 Jun 17, 2024
0.0.15 Apr 14, 2024
0.0.12 Dec 25, 2023

#541 in Asynchronous

Download history 69/week @ 2024-09-21 40/week @ 2024-09-28 6/week @ 2024-10-05 23/week @ 2024-10-12 25/week @ 2024-10-19 44/week @ 2024-10-26 34/week @ 2024-11-02 13/week @ 2024-11-09 20/week @ 2024-11-16 40/week @ 2024-11-23 52/week @ 2024-11-30 61/week @ 2024-12-07 35/week @ 2024-12-14 3/week @ 2024-12-21 6/week @ 2024-12-28 14/week @ 2025-01-04

58 downloads per month
Used in 20 crates (5 directly)

AGPL-3.0-only

53KB
1.5K SLoC

Product OS : Async Executor

Product OS : Async Executor provides a set of tools to handle async execution generically so that the desired async library (e.g. tokio, smol) to be used can be chosen at compile time.

What is Product OS?

Product OS is a collection of packages that provide different tools and features that can work together to build products more easily for the Rust ecosystem.

Installation

Use the Rust crate package manager cargo to install Product OS : Async Executor.

cargo add product-os-async-executor

or add Product OS : Async Executor to your cargo.toml [packages] section.

product-os-async-executor = { version = "0.0.16", features = [], default-features = true, optional = false }

Features

Product OS Async Executor supports a number of features leveraging existing Rust libraries to help manage an executor generically including:

  • Traits for handling implementations of additional async libraries
  • Out of the box support for tokio and smol with partial support for async_std
  • Support for one time and interval timers
  • Provides some traits for AsyncRead and AsyncWrite to be used across async runtimes
  • Supports no_std with alloc only environments
// Feature samples TODO

Usage

// Examples TODO

Contributing

Contributions are not currently available but will be available on a public repository soon.

License

GNU AGPLv3

Dependencies

~2–14MB
~177K SLoC