#asynchronous-programming #future #stream #zero-allocation #composability #control-flow

no-std futures

An implementation of futures and streams featuring zero allocations, composability, and iterator-like interfaces

49 releases

0.3.31 Oct 5, 2024
0.3.30 Dec 24, 2023
0.3.29 Oct 26, 2023
0.3.28 Mar 30, 2023
0.1.0 Jul 31, 2016

#8 in Asynchronous

Download history 1837149/week @ 2024-07-15 1938783/week @ 2024-07-22 1924321/week @ 2024-07-29 1882395/week @ 2024-08-05 1936416/week @ 2024-08-12 1939579/week @ 2024-08-19 1939678/week @ 2024-08-26 1870674/week @ 2024-09-02 1940609/week @ 2024-09-09 1892152/week @ 2024-09-16 2012436/week @ 2024-09-23 2351588/week @ 2024-09-30 2814241/week @ 2024-10-07 2663215/week @ 2024-10-14 2345672/week @ 2024-10-21 2158166/week @ 2024-10-28

10,211,629 downloads per month
Used in 22,053 crates (11,675 directly)

MIT/Apache

1MB
15K SLoC

futures-rs

Zero-cost asynchronous programming in Rust

Build Status crates.io

Documentation | Website

futures-rs is a library providing the foundations for asynchronous programming in Rust. It includes key trait definitions like Stream, as well as utilities like join!, select!, and various futures combinator methods which enable expressive asynchronous control flow.

Usage

Add this to your Cargo.toml:

[dependencies]
futures = "0.3"

The current futures requires Rust 1.56 or later.

Feature std

Futures-rs works without the standard library, such as in bare metal environments. However, it has a significantly reduced API surface. To use futures-rs in a #[no_std] environment, use:

[dependencies]
futures = { version = "0.3", default-features = false }

License

Licensed under either of Apache License, Version 2.0 or MIT license at your option.

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

Dependencies