[−][src]Function futures_util::try_future::try_join_all
ⓘImportant traits for TryJoinAll<F>
pub fn try_join_all<I>(i: I) -> TryJoinAll<I::Item> where
I: IntoIterator,
I::Item: TryFuture,
Creates a future which represents either a collection of the results of the futures given or an error.
The returned future will drive execution for all of its underlying futures,
collecting the results into a destination Vec<T>
in the same order as they
were provided.
If any future returns an error then all other futures will be canceled and
an error will be returned immediately. If all futures complete successfully,
however, then the returned future will succeed with a Vec
of all the
successful results.
Examples
#![feature(async_await, await_macro, futures_api)] use futures::future::{self, try_join_all}; let futures = vec![ future::ok::<u32, u32>(1), future::ok::<u32, u32>(2), future::ok::<u32, u32>(3), ]; assert_eq!(await!(try_join_all(futures)), Ok(vec![1, 2, 3])); let futures = vec![ future::ok::<u32, u32>(1), future::err::<u32, u32>(2), future::ok::<u32, u32>(3), ]; assert_eq!(await!(try_join_all(futures)), Err(2));