macro_rules! _local_write_all {
($bytes:expr, $write:expr) => {{
while !$bytes.is_empty() {
match $write {
Err(e) => return Err(e.into()),
Ok(0) => return { Err(crate::Error::UnexpectedStreamWriteEOF) },
Ok(n) => $bytes = $bytes.get(n..).unwrap_or_default(),
}
}
}};
}
macro_rules! _local_write_all_vectored {
($bytes:expr, $this:ident, |$io_slices:ident| $write_many:expr) => {{
match $bytes {
[] => return Ok(()),
[single] => {
<Self as crate::stream::StreamWriter>::write_all($this, single).await?;
}
_ => {
let mut buffer = [std::io::IoSlice::new(&[]); _];
let mut $io_slices = crate::stream::convert_to_io_slices(&mut buffer, $bytes)?;
while !$io_slices.is_empty() {
match $write_many {
Err(e) => return Err(e.into()),
Ok(0) => return Err(crate::Error::UnexpectedStreamWriteEOF),
Ok(n) => std::io::IoSlice::advance_slices(&mut $io_slices, n),
}
}
}
}
}};
}
#[cfg(feature = "async-net")]
mod async_net;
mod bytes_stream;
#[cfg(feature = "embassy-net")]
mod embassy_net;
#[cfg(feature = "std")]
mod std;
mod stream_reader;
mod stream_with_tls;
mod stream_writer;
#[cfg(feature = "tokio")]
mod tokio;
#[cfg(feature = "tokio-rustls")]
mod tokio_rustls;
pub use bytes_stream::BytesStream;
pub use stream_reader::StreamReader;
pub use stream_with_tls::StreamWithTls;
pub use stream_writer::StreamWriter;
pub trait Stream: StreamReader + StreamWriter {}
impl<T> Stream for T where T: StreamReader + StreamWriter {}
#[cfg(feature = "std")]
fn convert_to_io_slices<'buffer, 'bytes>(
buffer: &'buffer mut [::std::io::IoSlice<'bytes>; 8],
elems: &[&'bytes [u8]],
) -> crate::Result<&'buffer mut [::std::io::IoSlice<'bytes>]> {
if elems.len() > 8 {
return crate::misc::unlikely_elem(Err(crate::Error::VectoredWriteOverflow));
}
for (elem, io_slice) in elems.iter().zip(&mut *buffer) {
*io_slice = ::std::io::IoSlice::new(elem);
}
Ok(buffer.get_mut(..elems.len()).unwrap_or_default())
}