Struct BufRecvStream

Source
pub struct BufRecvStream<S, B> { /* private fields */ }
Available on crate feature h3 only.
Expand description

A stream which allows partial reading of the data without data loss.

This fixes the problem where poll_data returns more than the needed amount of bytes, requiring correct implementations to hold on to that extra data and return it later.

§Usage

Implements quic::RecvStream which will first return buffered data, and then read from the stream

Implementations§

Source§

impl<S, B> BufRecvStream<S, B>

Source

pub fn new(stream: S) -> BufRecvStream<S, B>

Source§

impl<B, S> BufRecvStream<S, B>
where S: RecvStream,

Source

pub fn poll_read( &mut self, cx: &mut Context<'_>, ) -> Poll<Result<bool, StreamErrorIncoming>>

Reads more data into the buffer, returning the number of bytes read.

Returns true if the end of the stream is reached.

Source

pub fn take_chunk(&mut self, limit: usize) -> Option<Bytes>

Returns the next chunk of data from the stream

Return None when there is no more buffered data; use Self::poll_read.

Source

pub fn has_remaining(&mut self) -> bool

Returns true if there is remaining buffered data

Source

pub fn is_eos(&self) -> bool

Trait Implementations§

Source§

impl<S, B> AsyncRead for BufRecvStream<S, B>
where B: Buf, S: RecvStream,

Source§

fn poll_read( self: Pin<&mut BufRecvStream<S, B>>, cx: &mut Context<'_>, buf: &mut [u8], ) -> Poll<Result<usize, Error>>

Attempt to read from the AsyncRead into buf. Read more
Source§

fn poll_read_vectored( self: Pin<&mut Self>, cx: &mut Context<'_>, bufs: &mut [IoSliceMut<'_>], ) -> Poll<Result<usize, Error>>

Attempt to read from the AsyncRead into bufs using vectored IO operations. Read more
Source§

impl<S, B> AsyncRead for BufRecvStream<S, B>
where B: Buf, S: RecvStream,

Source§

fn poll_read( self: Pin<&mut BufRecvStream<S, B>>, cx: &mut Context<'_>, buf: &mut ReadBuf<'_>, ) -> Poll<Result<(), Error>>

Attempts to read from the AsyncRead into buf. Read more
Source§

impl<S, B> AsyncWrite for BufRecvStream<S, B>
where B: Buf, S: SendStreamUnframed<B>,

Source§

fn poll_write( self: Pin<&mut BufRecvStream<S, B>>, cx: &mut Context<'_>, buf: &[u8], ) -> Poll<Result<usize, Error>>

Attempt to write bytes from buf into the object. Read more
Source§

fn poll_flush( self: Pin<&mut BufRecvStream<S, B>>, _: &mut Context<'_>, ) -> Poll<Result<(), Error>>

Attempt to flush the object, ensuring that any buffered data reach their destination. Read more
Source§

fn poll_close( self: Pin<&mut BufRecvStream<S, B>>, cx: &mut Context<'_>, ) -> Poll<Result<(), Error>>

Attempt to close the object. Read more
Source§

fn poll_write_vectored( self: Pin<&mut Self>, cx: &mut Context<'_>, bufs: &[IoSlice<'_>], ) -> Poll<Result<usize, Error>>

Attempt to write bytes from bufs into the object using vectored IO operations. Read more
Source§

impl<S, B> AsyncWrite for BufRecvStream<S, B>
where B: Buf, S: SendStreamUnframed<B>,

Source§

fn poll_write( self: Pin<&mut BufRecvStream<S, B>>, cx: &mut Context<'_>, buf: &[u8], ) -> Poll<Result<usize, Error>>

Attempt to write bytes from buf into the object. Read more
Source§

fn poll_flush( self: Pin<&mut BufRecvStream<S, B>>, _: &mut Context<'_>, ) -> Poll<Result<(), Error>>

Attempts to flush the object, ensuring that any buffered data reach their destination. Read more
Source§

fn poll_shutdown( self: Pin<&mut BufRecvStream<S, B>>, cx: &mut Context<'_>, ) -> Poll<Result<(), Error>>

Initiates or attempts to shut down this writer, returning success when the I/O connection has completely shut down. Read more
Source§

fn poll_write_vectored( self: Pin<&mut Self>, cx: &mut Context<'_>, bufs: &[IoSlice<'_>], ) -> Poll<Result<usize, Error>>

Like poll_write, except that it writes from a slice of buffers. Read more
Source§

fn is_write_vectored(&self) -> bool

Determines if this writer has an efficient poll_write_vectored implementation. Read more
Source§

impl<S, B> BidiStream<B> for BufRecvStream<S, B>
where B: Buf, S: BidiStream<B>,

Source§

type SendStream = BufRecvStream<<S as BidiStream<B>>::SendStream, B>

The type for the send half.
Source§

type RecvStream = BufRecvStream<<S as BidiStream<B>>::RecvStream, B>

The type for the receive half.
Source§

fn split( self, ) -> (<BufRecvStream<S, B> as BidiStream<B>>::SendStream, <BufRecvStream<S, B> as BidiStream<B>>::RecvStream)

Split this stream into two halves.
Source§

impl<S, B> Debug for BufRecvStream<S, B>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl<S, B> RecvStream for BufRecvStream<S, B>
where S: RecvStream,

Source§

type Buf = Bytes

The type of Buf for data received on this stream.
Source§

fn poll_data( &mut self, cx: &mut Context<'_>, ) -> Poll<Result<Option<<BufRecvStream<S, B> as RecvStream>::Buf>, StreamErrorIncoming>>

Poll the stream for more data. Read more
Source§

fn stop_sending(&mut self, error_code: u64)

Send a STOP_SENDING QUIC code.
Source§

fn recv_id(&self) -> StreamId

Get QUIC send stream id
Source§

impl<S, B> SendStream<B> for BufRecvStream<S, B>
where B: Buf, S: SendStream<B>,

Source§

fn poll_finish( &mut self, cx: &mut Context<'_>, ) -> Poll<Result<(), StreamErrorIncoming>>

Poll to finish the sending side of the stream.
Source§

fn reset(&mut self, reset_code: u64)

Send a QUIC reset code.
Source§

fn send_id(&self) -> StreamId

Get QUIC send stream id
Source§

fn poll_ready( &mut self, cx: &mut Context<'_>, ) -> Poll<Result<(), StreamErrorIncoming>>

Polls if the stream can send more data.
Source§

fn send_data<T>(&mut self, data: T) -> Result<(), StreamErrorIncoming>
where T: Into<WriteBuf<B>>,

Send more data on the stream.
Source§

impl<S, B> SendStreamUnframed<B> for BufRecvStream<S, B>
where B: Buf, S: SendStreamUnframed<B>,

Source§

fn poll_send<D>( &mut self, cx: &mut Context<'_>, buf: &mut D, ) -> Poll<Result<usize, StreamErrorIncoming>>
where D: Buf,

Attempts to write data into the stream. Read more
Source§

impl<'__pin, S, B> Unpin for BufRecvStream<S, B>
where <PinnedFieldsOfHelperStruct<__Origin<'__pin, S, B>> as PinnedFieldsOfHelperTrait>::Actual: Unpin,

Auto Trait Implementations§

§

impl<S, B> Freeze for BufRecvStream<S, B>
where S: Freeze,

§

impl<S, B> RefUnwindSafe for BufRecvStream<S, B>

§

impl<S, B> Send for BufRecvStream<S, B>
where S: Send, B: Send,

§

impl<S, B> Sync for BufRecvStream<S, B>
where S: Sync, B: Sync,

§

impl<S, B> UnwindSafe for BufRecvStream<S, B>
where S: UnwindSafe, B: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<R> AsyncReadExt for R
where R: AsyncRead + ?Sized,

Source§

fn chain<R>(self, next: R) -> Chain<Self, R>
where Self: Sized, R: AsyncRead,

Creates an adaptor which will chain this stream with another. Read more
Source§

fn read<'a>(&'a mut self, buf: &'a mut [u8]) -> Read<'a, Self>
where Self: Unpin,

Tries to read some bytes directly into the given buf in asynchronous manner, returning a future type. Read more
Source§

fn read_vectored<'a>( &'a mut self, bufs: &'a mut [IoSliceMut<'a>], ) -> ReadVectored<'a, Self>
where Self: Unpin,

Creates a future which will read from the AsyncRead into bufs using vectored IO operations. Read more
Source§

fn read_exact<'a>(&'a mut self, buf: &'a mut [u8]) -> ReadExact<'a, Self>
where Self: Unpin,

Creates a future which will read exactly enough bytes to fill buf, returning an error if end of file (EOF) is hit sooner. Read more
Source§

fn read_to_end<'a>(&'a mut self, buf: &'a mut Vec<u8>) -> ReadToEnd<'a, Self>
where Self: Unpin,

Creates a future which will read all the bytes from this AsyncRead. Read more
Source§

fn read_to_string<'a>( &'a mut self, buf: &'a mut String, ) -> ReadToString<'a, Self>
where Self: Unpin,

Creates a future which will read all the bytes from this AsyncRead. Read more
Source§

fn split(self) -> (ReadHalf<Self>, WriteHalf<Self>)
where Self: Sized + AsyncWrite,

Helper method for splitting this read/write object into two halves. Read more
Source§

fn take(self, limit: u64) -> Take<Self>
where Self: Sized,

Creates an AsyncRead adapter which will read at most limit bytes from the underlying reader. Read more
Source§

impl<W> AsyncWriteExt for W
where W: AsyncWrite + ?Sized,

Source§

fn flush(&mut self) -> Flush<'_, Self>
where Self: Unpin,

Creates a future which will entirely flush this AsyncWrite. Read more
Source§

fn close(&mut self) -> Close<'_, Self>
where Self: Unpin,

Creates a future which will entirely close this AsyncWrite.
Source§

fn write<'a>(&'a mut self, buf: &'a [u8]) -> Write<'a, Self>
where Self: Unpin,

Creates a future which will write bytes from buf into the object. Read more
Source§

fn write_vectored<'a>( &'a mut self, bufs: &'a [IoSlice<'a>], ) -> WriteVectored<'a, Self>
where Self: Unpin,

Creates a future which will write bytes from bufs into the object using vectored IO operations. Read more
Source§

fn write_all<'a>(&'a mut self, buf: &'a [u8]) -> WriteAll<'a, Self>
where Self: Unpin,

Write data into this object. Read more
Source§

fn into_sink<Item>(self) -> IntoSink<Self, Item>
where Item: AsRef<[u8]>, Self: Sized,

Allow using an AsyncWrite as a Sink<Item: AsRef<[u8]>>. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more