mirror of
https://github.com/tokio-rs/tokio.git
synced 2025-09-28 12:10:37 +00:00
stream: StreamExt::try_next (#2005)
This commit is contained in:
parent
3b9c7b1715
commit
3dcd76a38f
@ -19,6 +19,9 @@ use map::Map;
|
||||
mod next;
|
||||
use next::Next;
|
||||
|
||||
mod try_next;
|
||||
use try_next::TryNext;
|
||||
|
||||
pub use futures_core::Stream;
|
||||
|
||||
/// An extension trait for `Stream`s that provides a variety of convenient
|
||||
@ -61,6 +64,35 @@ pub trait StreamExt: Stream {
|
||||
Next::new(self)
|
||||
}
|
||||
|
||||
/// Creates a future that attempts to resolve the next item in the stream.
|
||||
/// If an error is encountered before the next item, the error is returned instead.
|
||||
///
|
||||
/// This is similar to the [`next`](StreamExt::next) combinator,
|
||||
/// but returns a [`Result<Option<T>, E>`](Result) rather than
|
||||
/// an [`Option<Result<T, E>>`](Option), making for easy use
|
||||
/// with the [`?`](std::ops::Try) operator.
|
||||
///
|
||||
/// # Examples
|
||||
///
|
||||
/// ```
|
||||
/// # #[tokio::main]
|
||||
/// # async fn main() {
|
||||
/// use tokio::stream::{self, StreamExt};
|
||||
///
|
||||
/// let mut stream = stream::iter(vec![Ok(1), Ok(2), Err("nope")]);
|
||||
///
|
||||
/// assert_eq!(stream.try_next().await, Ok(Some(1)));
|
||||
/// assert_eq!(stream.try_next().await, Ok(Some(2)));
|
||||
/// assert_eq!(stream.try_next().await, Err("nope"));
|
||||
/// # }
|
||||
/// ```
|
||||
fn try_next<T, E>(&mut self) -> TryNext<'_, Self>
|
||||
where
|
||||
Self: Stream<Item = Result<T, E>> + Unpin,
|
||||
{
|
||||
TryNext::new(self)
|
||||
}
|
||||
|
||||
/// Maps this stream's items to a different type, returning a new stream of
|
||||
/// the resulting type.
|
||||
///
|
||||
|
30
tokio/src/stream/try_next.rs
Normal file
30
tokio/src/stream/try_next.rs
Normal file
@ -0,0 +1,30 @@
|
||||
use crate::stream::{Next, Stream};
|
||||
|
||||
use core::future::Future;
|
||||
use core::pin::Pin;
|
||||
use core::task::{Context, Poll};
|
||||
|
||||
/// Future for the [`try_next`](super::StreamExt::try_next) method.
|
||||
#[derive(Debug)]
|
||||
#[must_use = "futures do nothing unless you `.await` or poll them"]
|
||||
pub struct TryNext<'a, St: ?Sized> {
|
||||
inner: Next<'a, St>,
|
||||
}
|
||||
|
||||
impl<St: ?Sized + Unpin> Unpin for TryNext<'_, St> {}
|
||||
|
||||
impl<'a, St: ?Sized + Stream + Unpin> TryNext<'a, St> {
|
||||
pub(super) fn new(stream: &'a mut St) -> Self {
|
||||
Self {
|
||||
inner: Next::new(stream),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl<T, E, St: ?Sized + Stream<Item = Result<T, E>> + Unpin> Future for TryNext<'_, St> {
|
||||
type Output = Result<Option<T>, E>;
|
||||
|
||||
fn poll(mut self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output> {
|
||||
Pin::new(&mut self.inner).poll(cx).map(Option::transpose)
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user