futures-rs

This library is an implementation of zero-cost futures in Rust.

Build Status Build status

Documentation

Tutorial

Usage

First, add this to your Cargo.toml:

toml [dependencies] futures = "0.1"

Next, add this to your crate:

```rust extern crate futures;

use futures::Future; ```

And then, use futures! If this is your first time with futures in Rust, or at all, check out the [tutorial].

What's using futures?

Why Futures?

A major missing piece of the Rust ecosystem has been how to work with Asynchronous I/O and in general composing many I/O tasks together in a lightweight way across libraries. Futures have worked out fantastically in other languages to solve this problem in frameworks like [finagle] and [wangle], and they also turn out to be a great way to solve this problem in Rust as well!

The purpose of the futures library in this repository is to provide the foundational layer to build an ecosystem of futures-generating computations so they can all compose with one another.

The Future trait

At the heart of this crate is the Future trait, which in true Rust style, is an interface for zero-allocation futures. Like iterators in Rust, there are a wide variety of helpful combinators associated with this trait which are also zero-allocation and serve as a succinct and powerful way to compose computations on futures.

The Future trait is driven by one method, poll, which allows pulling values out of a future and also getting notified when a future is complete. More documentation can be found on the associated method.

More information can be found in the tutorial

I/O with futures

With the power of zero-allocation futures we can take futures all the way down the stack to the I/O layer. The [Tokio] project is a one-stop shop for async I/O in Rust, starting with the tokio-core crate at the very bottom layer all the way up to the tokio-proto crate to enable easily building new protocols.

License

futures-rs is primarily distributed under the terms of both the MIT license and the Apache License (Version 2.0), with portions covered by various BSD-like licenses.

See LICENSE-APACHE, and LICENSE-MIT for details.