//! Definition of the `PollFn` combinator use super::assert_stream; use core::fmt; use core::pin::Pin; use futures_core::stream::Stream; use futures_core::task::{Context, Poll}; /// Stream for the [`poll_fn`] function. #[must_use = "streams do nothing unless polled"] pub struct PollFn { f: F, } impl Unpin for PollFn {} impl fmt::Debug for PollFn { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { f.debug_struct("PollFn").finish() } } /// Creates a new stream wrapping a function returning `Poll>`. /// /// Polling the returned stream calls the wrapped function. /// /// # Examples /// /// ``` /// use futures::stream::poll_fn; /// use futures::task::Poll; /// /// let mut counter = 1usize; /// /// let read_stream = poll_fn(move |_| -> Poll> { /// if counter == 0 { return Poll::Ready(None); } /// counter -= 1; /// Poll::Ready(Some("Hello, World!".to_owned())) /// }); /// ``` pub fn poll_fn(f: F) -> PollFn where F: FnMut(&mut Context<'_>) -> Poll>, { assert_stream::(PollFn { f }) } impl Stream for PollFn where F: FnMut(&mut Context<'_>) -> Poll>, { type Item = T; fn poll_next(mut self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll> { (&mut self.f)(cx) } }