Trait futures::future::Future
[−]
[src]
pub trait Future { type Item; type Error; fn poll(&mut self) -> Poll<Self::Item, Self::Error>; fn wait(self) -> Result<Self::Item, Self::Error> where Self: Sized { ... } fn boxed(self) -> BoxFuture<Self::Item, Self::Error> where Self: Sized + Send + 'static { ... } fn map<F, U>(self, f: F) -> Map<Self, F> where F: FnOnce(Self::Item) -> U, Self: Sized { ... } fn map_err<F, E>(self, f: F) -> MapErr<Self, F> where F: FnOnce(Self::Error) -> E, Self: Sized { ... } fn from_err<F, E: From<Self::Error>>(self) -> FromErr<Self, E> where Self: Sized { ... } fn then<F, B>(self, f: F) -> Then<Self, B, F> where F: FnOnce(Result<Self::Item, Self::Error>) -> B, B: IntoFuture, Self: Sized { ... } fn and_then<F, B>(self, f: F) -> AndThen<Self, B, F> where F: FnOnce(Self::Item) -> B, B: IntoFuture<Error=Self::Error>, Self: Sized { ... } fn or_else<F, B>(self, f: F) -> OrElse<Self, B, F> where F: FnOnce(Self::Error) -> B, B: IntoFuture<Item=Self::Item>, Self: Sized { ... } fn select<B>(self, other: B) -> Select<Self, B::Future> where B: IntoFuture<Item=Self::Item, Error=Self::Error>, Self: Sized { ... } fn join<B>(self, other: B) -> Join<Self, B::Future> where B: IntoFuture<Error=Self::Error>, Self: Sized { ... } fn join3<B, C>(self, b: B, c: C) -> Join3<Self, B::Future, C::Future> where B: IntoFuture<Error=Self::Error>, C: IntoFuture<Error=Self::Error>, Self: Sized { ... } fn join4<B, C, D>(self,
b: B,
c: C,
d: D)
-> Join4<Self, B::Future, C::Future, D::Future> where B: IntoFuture<Error=Self::Error>, C: IntoFuture<Error=Self::Error>, D: IntoFuture<Error=Self::Error>, Self: Sized { ... } fn join5<B, C, D, E>(self,
b: B,
c: C,
d: D,
e: E)
-> Join5<Self, B::Future, C::Future, D::Future, E::Future> where B: IntoFuture<Error=Self::Error>, C: IntoFuture<Error=Self::Error>, D: IntoFuture<Error=Self::Error>, E: IntoFuture<Error=Self::Error>, Self: Sized { ... } fn into_stream(self) -> IntoStream<Self> where Self: Sized { ... } fn flatten(self) -> Flatten<Self> where Self::Item: IntoFuture, Self::Item::Error: From<Self::Error>, Self: Sized { ... } fn flatten_stream(self) -> FlattenStream<Self> where Self::Item: Stream<Error=Self::Error>, Self: Sized { ... } fn fuse(self) -> Fuse<Self> where Self: Sized { ... } fn catch_unwind(self) -> CatchUnwind<Self> where Self: Sized + UnwindSafe { ... } fn shared(self) -> Shared<Self> where Self: Sized { ... } }
Trait for types which are a placeholder of a value that will become available at possible some later point in time.
Futures are used to provide a sentinel through which a value can be referenced. They crucially allow chaining and composing operations through consumption which allows expressing entire trees of computation as one sentinel value.
The ergonomics and implementation of the Future
trait are very similar to
the Iterator
trait in Rust which is where there is a small handful of
methods to implement and a load of default methods that consume a Future
,
producing a new value.
The poll
method
The core method of future, poll
, is used to attempt to generate the value
of a Future
. This method does not block but is allowed to inform the
caller that the value is not ready yet. Implementations of poll
may
themselves do work to generate the value, but it's guaranteed that this will
never block the calling thread.
A key aspect of this method is that if the value is not yet available the current task is scheduled to receive a notification when it's later ready to be made available. This follows what's typically known as a "readiness" or "pull" model where values are pulled out of futures on demand, and otherwise a task is notified when a value might be ready to get pulled out.
The poll
method is not intended to be called in general, but rather is
typically called in the context of a "task" which drives a future to
completion. For more information on this see the task
module.
Combinators
Like iterators, futures provide a large number of combinators to work with
futures to express computations in a much more natural method than
scheduling a number of callbacks. For example the map
method can change
a Future<Item=T>
to a Future<Item=U>
or an and_then
combinator could
create a future after the first one is done and only be resolved when the
second is done.
Combinators act very similarly to the methods on the Iterator
trait itself
or those on Option
and Result
. Like with iterators, the combinators are
zero-cost and don't impose any extra layers of indirection you wouldn't
otherwise have to write down.
Associated Types
type Item
The type of value that this future will resolved with if it is successful.
type Error
The type of error that this future will resolve with if it fails in a normal fashion.
Required Methods
fn poll(&mut self) -> Poll<Self::Item, Self::Error>
Query this future to see if its value has become available, registering interest if it is not.
This function will check the internal state of the future and assess whether the value is ready to be produced. Implementors of this function should ensure that a call to this never blocks as event loops may not work properly otherwise.
When a future is not ready yet, the Async::NotReady
value will be
returned. In this situation the future will also register interest of
the current task in the value being produced. That is, once the value is
ready it will notify the current task that progress can be made.
Runtime characteristics
This function, poll
, is the primary method for 'making progress'
within a tree of futures. For example this method will be called
repeatedly as the internal state machine makes its various transitions.
Executors are responsible for ensuring that this function is called in
the right location (e.g. always on an I/O thread or not). Unless it is
otherwise arranged to be so, it should be ensured that implementations
of this function finish very quickly.
Returning quickly prevents unnecessarily clogging up threads and/or
event loops while a poll
function call, for example, takes up compute
resources to perform some expensive computation. If it is known ahead
of time that a call to poll
may end up taking awhile, the work should
be offloaded to a thread pool (or something similar) to ensure that
poll
can return quickly.
Return value
This function returns Async::NotReady
if the future is not ready yet,
Err
if the future is finished but resolved to an error, or
Async::Ready
with the result of this future if it's finished
successfully. Once a future has finished it is considered a contract
error to continue polling the future.
If NotReady
is returned, then the future will internally register
interest in the value being produced for the current task. In other
words, the current task will receive a notification once the value is
ready to be produced or the future can make progress.
Panics
Once a future has completed (returned Ready
or Err
from poll
),
then any future calls to poll
may panic, block forever, or otherwise
cause wrong behavior. The Future
trait itself provides no guarantees
about the behavior of poll
after a future has completed.
Callers who may call poll
too many times may want to consider using
the fuse
adaptor which defines the behavior of poll
, but comes with
a little bit of extra cost.
Additionally, calls to poll
must always be made from within the
context of a task. If a current task is not set then this method will
likely panic.
Errors
This future may have failed to finish the computation, in which case
the Err
variant will be returned with an appropriate payload of an
error.
Provided Methods
fn wait(self) -> Result<Self::Item, Self::Error> where Self: Sized
Block the current thread until this future is resolved.
This method will consume ownership of this future, driving it to
completion via poll
and blocking the current thread while it's waiting
for the value to become available. Once the future is resolved the
result of this future is returned.
Note: This method is not appropriate to call on event loops or similar I/O situations because it will prevent the event loop from making progress (this blocks the thread). This method should only be called when it's guaranteed that the blocking work associated with this future will be completed by another thread.
Behavior
This function will pin this future to the current thread. The future will only be polled by this thread.
Panics
This function does not attempt to catch panics. If the poll
function
panics, panics will be propagated to the caller.
fn boxed(self) -> BoxFuture<Self::Item, Self::Error> where Self: Sized + Send + 'static
Convenience function for turning this future into a trait object.
This simply avoids the need to write Box::new
and can often help with
type inference as well by always returning a trait object. Note that
this method requires the Send
bound and returns a BoxFuture
, which
also encodes this. If you'd like to create a Box<Future>
without the
Send
bound, then the Box::new
function can be used instead.
Examples
use futures::future::*; let a: BoxFuture<i32, i32> = result(Ok(1)).boxed();
fn map<F, U>(self, f: F) -> Map<Self, F> where F: FnOnce(Self::Item) -> U, Self: Sized
Map this future's result to a different type, returning a new future of the resulting type.
This function is similar to the Option::map
or Iterator::map
where
it will change the type of the underlying future. This is useful to
chain along a computation once a future has been resolved.
The closure provided will only be called if this future is resolved successfully. If this future returns an error, panics, or is canceled, then the closure provided will never be invoked.
Note that this function consumes the receiving future and returns a
wrapped version of it, similar to the existing map
methods in the
standard library.
Examples
use futures::future::*; let future_of_1 = ok::<u32, u32>(1); let future_of_4 = future_of_1.map(|x| x + 3);
fn map_err<F, E>(self, f: F) -> MapErr<Self, F> where F: FnOnce(Self::Error) -> E, Self: Sized
Map this future's error to a different error, returning a new future.
This function is similar to the Result::map_err
where it will change
the error type of the underlying future. This is useful for example to
ensure that futures have the same error type when used with combinators
like select
and join
.
The closure provided will only be called if this future is resolved with an error. If this future returns a success, panics, or is canceled, then the closure provided will never be invoked.
Note that this function consumes the receiving future and returns a wrapped version of it.
Examples
use futures::future::*; let future_of_err_1 = err::<u32, u32>(1); let future_of_err_4 = future_of_err_1.map_err(|x| x + 3);
fn from_err<F, E: From<Self::Error>>(self) -> FromErr<Self, E> where Self: Sized
Map this future's error to any error implementing From
for
this future's Error
, returning a new future.
This function does for futures what try!
does for Result
,
by letting the compiler infer the type of the resulting error.
Just as map_err
above, this is useful for example to ensure
that futures have the same error type when used with
combinators like select
and join
.
Note that this function consumes the receiving future and returns a wrapped version of it.
Examples
use futures::future::*; let future_of_err_1 = err::<u32, u32>(1); let future_of_err_4 = future_of_err_1.from_err::<u32, u32>();
fn then<F, B>(self, f: F) -> Then<Self, B, F> where F: FnOnce(Result<Self::Item, Self::Error>) -> B, B: IntoFuture, Self: Sized
Chain on a computation for when a future finished, passing the result of
the future to the provided closure f
.
This function can be used to ensure a computation runs regardless of
the conclusion of the future. The closure provided will be yielded a
Result
once the future is complete.
The returned value of the closure must implement the IntoFuture
trait
and can represent some more work to be done before the composed future
is finished. Note that the Result
type implements the IntoFuture
trait so it is possible to simply alter the Result
yielded to the
closure and return it.
If this future is canceled or panics then the closure f
will not be
run.
Note that this function consumes the receiving future and returns a wrapped version of it.
Examples
use futures::future::*; let future_of_1 = ok::<u32, u32>(1); let future_of_4 = future_of_1.then(|x| { x.map(|y| y + 3) }); let future_of_err_1 = err::<u32, u32>(1); let future_of_4 = future_of_err_1.then(|x| { match x { Ok(_) => panic!("expected an error"), Err(y) => ok::<u32, u32>(y + 3), } });
fn and_then<F, B>(self, f: F) -> AndThen<Self, B, F> where F: FnOnce(Self::Item) -> B, B: IntoFuture<Error=Self::Error>, Self: Sized
Execute another future after this one has resolved successfully.
This function can be used to chain two futures together and ensure that the final future isn't resolved until both have finished. The closure provided is yielded the successful result of this future and returns another value which can be converted into a future.
Note that because Result
implements the IntoFuture
trait this method
can also be useful for chaining fallible and serial computations onto
the end of one future.
If this future is canceled, panics, or completes with an error then the
provided closure f
is never called.
Note that this function consumes the receiving future and returns a wrapped version of it.
Examples
use futures::future::*; let future_of_1 = ok::<u32, u32>(1); let future_of_4 = future_of_1.and_then(|x| { Ok(x + 3) }); let future_of_err_1 = err::<u32, u32>(1); future_of_err_1.and_then(|_| -> FutureResult<u32, u32> { panic!("should not be called in case of an error"); });
fn or_else<F, B>(self, f: F) -> OrElse<Self, B, F> where F: FnOnce(Self::Error) -> B, B: IntoFuture<Item=Self::Item>, Self: Sized
Execute another future if this one resolves with an error.
Return a future that passes along this future's value if it succeeds,
and otherwise passes the error to the closure f
and waits for the
future it returns. The closure may also simply return a value that can
be converted into a future.
Note that because Result
implements the IntoFuture
trait this method
can also be useful for chaining together fallback computations, where
when one fails, the next is attempted.
If this future is canceled, panics, or completes successfully then the
provided closure f
is never called.
Note that this function consumes the receiving future and returns a wrapped version of it.
Examples
use futures::future::*; let future_of_err_1 = err::<u32, u32>(1); let future_of_4 = future_of_err_1.or_else(|x| -> Result<u32, u32> { Ok(x + 3) }); let future_of_1 = ok::<u32, u32>(1); future_of_1.or_else(|_| -> FutureResult<u32, u32> { panic!("should not be called in case of success"); });
fn select<B>(self, other: B) -> Select<Self, B::Future> where B: IntoFuture<Item=Self::Item, Error=Self::Error>, Self: Sized
Waits for either one of two futures to complete.
This function will return a new future which awaits for either this or
the other
future to complete. The returned future will finish with
both the value resolved and a future representing the completion of the
other work. Both futures must have the same item and error type.
Note that this function consumes the receiving future and returns a wrapped version of it.
Examples
use futures::future::*; // A poor-man's join implemented on top of select fn join<A>(a: A, b: A) -> BoxFuture<(u32, u32), u32> where A: Future<Item = u32, Error = u32> + Send + 'static, { a.select(b).then(|res| { match res { Ok((a, b)) => b.map(move |b| (a, b)).boxed(), Err((a, _)) => err(a).boxed(), } }).boxed() }
fn join<B>(self, other: B) -> Join<Self, B::Future> where B: IntoFuture<Error=Self::Error>, Self: Sized
Joins the result of two futures, waiting for them both to complete.
This function will return a new future which awaits both this and the
other
future to complete. The returned future will finish with a tuple
of both results.
Both futures must have the same error type, and if either finishes with an error then the other will be canceled and that error will be returned.
If either future is canceled or panics, the other is canceled and the original error is propagated upwards.
Note that this function consumes the receiving future and returns a wrapped version of it.
Examples
use futures::future::*; let a = ok::<u32, u32>(1); let b = ok::<u32, u32>(2); let pair = a.join(b); pair.map(|(a, b)| { assert_eq!(a, 1); assert_eq!(b, 2); });
fn join3<B, C>(self, b: B, c: C) -> Join3<Self, B::Future, C::Future> where B: IntoFuture<Error=Self::Error>, C: IntoFuture<Error=Self::Error>, Self: Sized
Same as join
, but with more futures.
fn join4<B, C, D>(self,
b: B,
c: C,
d: D)
-> Join4<Self, B::Future, C::Future, D::Future> where B: IntoFuture<Error=Self::Error>, C: IntoFuture<Error=Self::Error>, D: IntoFuture<Error=Self::Error>, Self: Sized
b: B,
c: C,
d: D)
-> Join4<Self, B::Future, C::Future, D::Future> where B: IntoFuture<Error=Self::Error>, C: IntoFuture<Error=Self::Error>, D: IntoFuture<Error=Self::Error>, Self: Sized
Same as join
, but with more futures.
fn join5<B, C, D, E>(self,
b: B,
c: C,
d: D,
e: E)
-> Join5<Self, B::Future, C::Future, D::Future, E::Future> where B: IntoFuture<Error=Self::Error>, C: IntoFuture<Error=Self::Error>, D: IntoFuture<Error=Self::Error>, E: IntoFuture<Error=Self::Error>, Self: Sized
b: B,
c: C,
d: D,
e: E)
-> Join5<Self, B::Future, C::Future, D::Future, E::Future> where B: IntoFuture<Error=Self::Error>, C: IntoFuture<Error=Self::Error>, D: IntoFuture<Error=Self::Error>, E: IntoFuture<Error=Self::Error>, Self: Sized
Same as join
, but with more futures.
fn into_stream(self) -> IntoStream<Self> where Self: Sized
Convert this future into single element stream.
Resulting stream contains single success if this future resolves to success and single error if this future resolves into error.
Examples
use futures::Async; use futures::stream::Stream; use futures::future::*; let future = ok::<_, bool>(17); let mut stream = future.into_stream(); assert_eq!(Ok(Async::Ready(Some(17))), stream.poll()); assert_eq!(Ok(Async::Ready(None)), stream.poll()); let future = err::<bool, _>(19); let mut stream = future.into_stream(); assert_eq!(Err(19), stream.poll()); assert_eq!(Ok(Async::Ready(None)), stream.poll());
fn flatten(self) -> Flatten<Self> where Self::Item: IntoFuture, Self::Item::Error: From<Self::Error>, Self: Sized
Flatten the execution of this future when the successful result of this future is itself another future.
This can be useful when combining futures together to flatten the
computation out the the final result. This method can only be called
when the successful result of this future itself implements the
IntoFuture
trait and the error can be created from this future's error
type.
This method is equivalent to self.then(|x| x)
.
Note that this function consumes the receiving future and returns a wrapped version of it.
Examples
use futures::future::*; let future_of_a_future = ok::<_, u32>(ok::<u32, u32>(1)); let future_of_1 = future_of_a_future.flatten();
fn flatten_stream(self) -> FlattenStream<Self> where Self::Item: Stream<Error=Self::Error>, Self: Sized
Flatten the execution of this future when the successful result of this future is a stream.
This can be useful when stream initialization is deferred, and it is convenient to work with that stream as if stream was available at the call site.
Note that this function consumes this future and returns a wrapped version of it.
Examples
use futures::stream::{self, Stream}; use futures::future::*; let stream_items = vec![Ok(17), Err(true), Ok(19)]; let future_of_a_stream = ok::<_, bool>(stream::iter(stream_items)); let stream = future_of_a_stream.flatten_stream(); let mut iter = stream.wait(); assert_eq!(Ok(17), iter.next().unwrap()); assert_eq!(Err(true), iter.next().unwrap()); assert_eq!(Ok(19), iter.next().unwrap()); assert_eq!(None, iter.next());
fn fuse(self) -> Fuse<Self> where Self: Sized
Fuse a future such that poll
will never again be called once it has
completed.
Currently once a future has returned Ready
or Err
from
poll
any further calls could exhibit bad behavior such as blocking
forever, panicking, never returning, etc. If it is known that poll
may be called too often then this method can be used to ensure that it
has defined semantics.
Once a future has been fuse
d and it returns a completion from poll
,
then it will forever return NotReady
from poll
again (never
resolve). This, unlike the trait's poll
method, is guaranteed.
Additionally, once a future has completed, this Fuse
combinator will
ensure that all registered callbacks will not be registered with the
underlying future.
Examples
use futures::Async; use futures::future::*; let mut future = ok::<i32, u32>(2); assert_eq!(future.poll(), Ok(Async::Ready(2))); // Normally, a call such as this would panic: //future.poll(); // This, however, is guaranteed to not panic let mut future = ok::<i32, u32>(2).fuse(); assert_eq!(future.poll(), Ok(Async::Ready(2))); assert_eq!(future.poll(), Ok(Async::NotReady));
fn catch_unwind(self) -> CatchUnwind<Self> where Self: Sized + UnwindSafe
Catches unwinding panics while polling the future.
In general, panics within a future can propagate all the way out to the task level. This combinator makes it possible to halt unwinding within the future itself. It's most commonly used within task executors.
Note that this method requires the UnwindSafe
bound from the standard
library. This isn't always applied automatically, and the standard
library provides an AssertUnwindSafe
wrapper type to apply it
after-the fact. To assist using this method, the Future
trait is also
implemented for AssertUnwindSafe<F>
where F
implements Future
.
Examples
use futures::future::*; let mut future = ok::<i32, u32>(2); assert!(future.catch_unwind().wait().is_ok()); let mut future = lazy(|| { panic!(); ok::<i32, u32>(2) }); assert!(future.catch_unwind().wait().is_err());
Convert this future into Shared
future.
The shared() method provides a mean to convert any future into a cloneable future. It enables a future to be polled by multiple threads.
Shared
contains finishes with SharedItem<T>
where T is the original future item,
or with SharedError<E>
where E is the original future item.
Both SharedItem
and SharedError
implements Deref
,
so only a deref is required in order to access the item/error.
Examples
use futures::future::*; let future = ok::<_, bool>(6); let shared1 = future.shared(); let shared2 = shared1.clone(); assert_eq!(6, *shared1.wait().unwrap()); assert_eq!(6, *shared2.wait().unwrap());
use std::thread; use futures::future::*; let future = ok::<_, bool>(6); let shared1 = future.shared(); let shared2 = shared1.clone(); let join_handle = thread::spawn(move || { assert_eq!(6, *shared2.wait().unwrap()); }); assert_eq!(6, *shared1.wait().unwrap()); join_handle.join().unwrap();
Implementors
impl<T, E> Future for Empty<T, E>
impl<F, R> Future for Lazy<F, R> where F: FnOnce() -> R, R: IntoFuture
impl<T, E, F> Future for PollFn<F> where F: FnMut() -> Poll<T, E>
impl<T, E> Future for FutureResult<T, E>
impl<A, B, F> Future for AndThen<A, B, F> where A: Future, B: IntoFuture<Error=A::Error>, F: FnOnce(A::Item) -> B
impl<A> Future for Flatten<A> where A: Future, A::Item: IntoFuture, A::Item::Error: From<A::Error>
impl<A: Future> Future for Fuse<A>
impl<A, B> Future for Join<A, B> where A: Future, B: Future<Error=A::Error>
impl<A, B, C> Future for Join3<A, B, C> where A: Future, B: Future<Error=A::Error>, C: Future<Error=A::Error>
impl<A, B, C, D> Future for Join4<A, B, C, D> where A: Future, B: Future<Error=A::Error>, C: Future<Error=A::Error>, D: Future<Error=A::Error>
impl<A, B, C, D, E> Future for Join5<A, B, C, D, E> where A: Future, B: Future<Error=A::Error>, C: Future<Error=A::Error>, D: Future<Error=A::Error>, E: Future<Error=A::Error>
impl<U, A, F> Future for Map<A, F> where A: Future, F: FnOnce(A::Item) -> U
impl<U, A, F> Future for MapErr<A, F> where A: Future, F: FnOnce(A::Error) -> U
impl<A: Future, E: From<A::Error>> Future for FromErr<A, E>
impl<A, B, F> Future for OrElse<A, B, F> where A: Future, B: IntoFuture<Item=A::Item>, F: FnOnce(A::Error) -> B
impl<A, B> Future for Select<A, B> where A: Future, B: Future<Item=A::Item, Error=A::Error>
impl<A, B> Future for SelectNext<A, B> where A: Future, B: Future<Item=A::Item, Error=A::Error>
impl<A, B, F> Future for Then<A, B, F> where A: Future, B: IntoFuture, F: FnOnce(Result<A::Item, A::Error>) -> B
impl<A, B> Future for Either<A, B> where A: Future, B: Future<Item=A::Item, Error=A::Error>
impl<F> Future for CatchUnwind<F> where F: Future + UnwindSafe
impl<F: Future> Future for AssertUnwindSafe<F>
impl<I> Future for JoinAll<I> where I: IntoIterator, I::Item: IntoFuture
impl<A> Future for SelectAll<A> where A: Future
impl<A> Future for SelectOk<A> where A: Future
impl<F> Future for Shared<F> where F: Future
impl<F: ?Sized + Future> Future for Box<F>
impl<'a, F: ?Sized + Future> Future for &'a mut F
impl<S, F, Fut, T> Future for Fold<S, F, Fut, T> where S: Stream, F: FnMut(T, S::Item) -> Fut, Fut: IntoFuture<Item=T>, S::Error: From<Fut::Error>
impl<S, F> Future for ForEach<S, F> where S: Stream, F: FnMut(S::Item) -> Result<(), S::Error>
impl<S: Stream> Future for StreamFuture<S>
impl<T, U> Future for Forward<T, U> where U: Sink<SinkItem=T::Item>, T: Stream, T::Error: From<U::SinkError>
impl<S> Future for Collect<S> where S: Stream
impl<S: Sink> Future for Flush<S>
impl<S: Sink> Future for Send<S>
impl<T, U> Future for SendAll<T, U> where T: Sink, U: Stream<Item=T::SinkItem>, T::SinkError: From<U::Error>
impl<T> Future for Receiver<T>
impl<T> Future for BiLockAcquire<T>