cap_async_std/os/unix/net/incoming.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
use crate::os::unix::net::UnixStream;
use async_std::io;
use async_std::os::unix;
use async_std::stream::Stream;
use async_std::task::{Context, Poll};
use std::fmt;
use std::pin::Pin;
/// An iterator over incoming connections to a [`UnixListener`].
///
/// This corresponds to [`async_std::os::unix::net::Incoming`].
///
/// [`async_std::os::unix::net::Incoming`]: https://docs.rs/async-std/latest/async_std/os/unix/net/struct.Incoming.html
/// [`UnixListener`]: struct.UnixListener.html
pub struct Incoming<'a> {
std: unix::net::Incoming<'a>,
}
impl<'a> Incoming<'a> {
/// Constructs a new instance of `Self` from the given
/// `async_std::os::unix::net::Incoming`.
///
/// This grants access the resources the
/// `async_std::os::unix::net::Incoming` instance already has access to,
/// without any sandboxing.
#[inline]
pub fn from_std(std: unix::net::Incoming<'a>) -> Self {
Self { std }
}
}
impl<'a> Stream for Incoming<'a> {
type Item = io::Result<UnixStream>;
#[inline]
fn poll_next(mut self: Pin<&mut Self>, cx: &mut Context) -> Poll<Option<Self::Item>> {
Stream::poll_next(Pin::new(&mut self.std), cx).map(|poll| {
poll.map(|result| {
let unix_stream = result?;
Ok(UnixStream::from_std(unix_stream))
})
})
}
#[inline]
fn size_hint(&self) -> (usize, Option<usize>) {
self.std.size_hint()
}
}
impl<'a> fmt::Debug for Incoming<'a> {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
self.std.fmt(f)
}
}