summaryrefslogtreecommitdiffstats
path: root/tokio/src/stream/next.rs
diff options
context:
space:
mode:
Diffstat (limited to 'tokio/src/stream/next.rs')
-rw-r--r--tokio/src/stream/next.rs29
1 files changed, 19 insertions, 10 deletions
diff --git a/tokio/src/stream/next.rs b/tokio/src/stream/next.rs
index 3909c0c2..d9b1f920 100644
--- a/tokio/src/stream/next.rs
+++ b/tokio/src/stream/next.rs
@@ -1,28 +1,37 @@
use crate::stream::Stream;
use core::future::Future;
+use core::marker::PhantomPinned;
use core::pin::Pin;
use core::task::{Context, Poll};
+use pin_project_lite::pin_project;
-/// Future for the [`next`](super::StreamExt::next) method.
-#[derive(Debug)]
-#[must_use = "futures do nothing unless you `.await` or poll them"]
-pub struct Next<'a, St: ?Sized> {
- stream: &'a mut St,
+pin_project! {
+ /// Future for the [`next`](super::StreamExt::next) method.
+ #[derive(Debug)]
+ #[must_use = "futures do nothing unless you `.await` or poll them"]
+ pub struct Next<'a, St: ?Sized> {
+ stream: &'a mut St,
+ // Make this future `!Unpin` for compatibility with async trait methods.
+ #[pin]
+ _pin: PhantomPinned,
+ }
}
-impl<St: ?Sized + Unpin> Unpin for Next<'_, St> {}
-
impl<'a, St: ?Sized> Next<'a, St> {
pub(super) fn new(stream: &'a mut St) -> Self {
- Next { stream }
+ Next {
+ stream,
+ _pin: PhantomPinned,
+ }
}
}
impl<St: ?Sized + Stream + Unpin> Future for Next<'_, St> {
type Output = Option<St::Item>;
- fn poll(mut self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output> {
- Pin::new(&mut self.stream).poll_next(cx)
+ fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output> {
+ let me = self.project();
+ Pin::new(me.stream).poll_next(cx)
}
}