#synchronization-primitive #channel #future #oneshot-channel #data-structures #intrusive #async-channel

no-std futures-intrusive

Futures based on intrusive data structures - for std and no-std environments

10 releases

0.5.0 Nov 4, 2022
0.4.1 Oct 23, 2022
0.4.0 Nov 20, 2020
0.3.1 Apr 30, 2020
0.1.1 May 26, 2019

#40 in Concurrency

Download history 367105/week @ 2024-09-10 343389/week @ 2024-09-17 390403/week @ 2024-09-24 386670/week @ 2024-10-01 393513/week @ 2024-10-08 421472/week @ 2024-10-15 450708/week @ 2024-10-22 435958/week @ 2024-10-29 432659/week @ 2024-11-05 448955/week @ 2024-11-12 441693/week @ 2024-11-19 339187/week @ 2024-11-26 388255/week @ 2024-12-03 460312/week @ 2024-12-10 371344/week @ 2024-12-17 156252/week @ 2024-12-24

1,444,364 downloads per month
Used in 1,446 crates (87 directly)

MIT/Apache

280KB
5K SLoC

futures-intrusive

This crate provides a variety of Futures-based and async/await compatible types that are based on the idea of intrusive collections:

  • Channels in a variety of flavors:
    • Oneshot
    • Multi-Producer Multi-Consumer (MPMC)
    • State Broadcast
  • Synchronization Primitives:
    • Manual Reset Event
    • Mutex
    • Semaphore
  • A timer

Please refer to the documentation for details.

In addition to the documentation the examples provide a quick overview on how the primitives can be used.

Usage

Add this to your Cargo.toml:

[dependencies]
futures-intrusive = "^0.5"

In order to use the crate in a no-std environment, it needs to be compiled without default features:

[dependencies]
futures-intrusive = { version = "^0.5", default-features = false }

The crate defines a feature alloc, which can be used in order to re-enable alloc features. Also defined is std, which can be used in order to re-enable std features.

Minimum Rust version

The minimum required Rust version is 1.36, due to reliance on stable Future, Context and Waker types.

License

Licensed under either of

at your option.

Dependencies

~0.1–4.5MB