futures-intrusive 0.5.0

Futures based on intrusive data structures - for std and no-std environments.
Documentation
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](https://docs.rs/futures-intrusive) 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`:

```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:

```toml
[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

 * Apache License, Version 2.0, ([LICENSE-APACHE]LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
 * MIT license ([LICENSE-MIT]LICENSE-MIT or http://opensource.org/licenses/MIT)

at your option.