Struct futures_util::future::Fuse [−][src]
#[must_use = "futures do nothing unless you `.await` or poll them"]pub struct Fuse<Fut> { /* fields omitted */ }
Future for the fuse
method.
Implementations
impl<Fut: Future> Fuse<Fut>
[src]
impl<Fut: Future> Fuse<Fut>
[src]pub fn terminated() -> Self
[src]
Creates a new Fuse
-wrapped future which is already terminated.
This can be useful in combination with looping and the select!
macro, which bypasses terminated futures.
Examples
use futures::channel::mpsc; use futures::future::{Fuse, FusedFuture, FutureExt}; use futures::select; use futures::stream::StreamExt; use futures::pin_mut; let (sender, mut stream) = mpsc::unbounded(); // Send a few messages into the stream sender.unbounded_send(()).unwrap(); sender.unbounded_send(()).unwrap(); drop(sender); // Use `Fuse::terminated()` to create an already-terminated future // which may be instantiated later. let foo_printer = Fuse::terminated(); pin_mut!(foo_printer); loop { select! { _ = foo_printer => {}, () = stream.select_next_some() => { if !foo_printer.is_terminated() { println!("Foo is already being printed!"); } else { foo_printer.set(async { // do some other async operations println!("Printing foo from `foo_printer` future"); }.fuse()); } }, complete => break, // `foo_printer` is terminated and the stream is done } }
Trait Implementations
impl<Fut: Future> FusedFuture for Fuse<Fut>
[src]
impl<Fut: Future> FusedFuture for Fuse<Fut>
[src]fn is_terminated(&self) -> bool
[src]
impl<'__pin, Fut> Unpin for Fuse<Fut> where
__Origin<'__pin, Fut>: Unpin,
[src]
__Origin<'__pin, Fut>: Unpin,
Auto Trait Implementations
impl<Fut> RefUnwindSafe for Fuse<Fut> where
Fut: RefUnwindSafe,
Fut: RefUnwindSafe,
impl<Fut> Send for Fuse<Fut> where
Fut: Send,
Fut: Send,
impl<Fut> Sync for Fuse<Fut> where
Fut: Sync,
Fut: Sync,
impl<Fut> UnwindSafe for Fuse<Fut> where
Fut: UnwindSafe,
Fut: UnwindSafe,
Blanket Implementations
impl<F> IntoFuture for F where
F: Future,
[src]
impl<F> IntoFuture for F where
F: Future,
[src]type Output = <F as Future>::Output
🔬 This is a nightly-only experimental API. (
into_future
)The output that the future will produce on completion.
type Future = F
🔬 This is a nightly-only experimental API. (
into_future
)Which kind of future are we turning this into?