Enum libp2p_mplex::MaxBufferBehaviour
source · pub enum MaxBufferBehaviour {
ResetStream,
Block,
}
Expand description
Behaviour when the maximum length of the buffer is reached.
Variants§
ResetStream
Reset the substream whose frame buffer overflowed.
Note: If more than
MplexConfig::set_max_buffer_size()
frames are received in succession for a substream in the context of trying to read data from a different substream, the former substream may be reset before application code had a chance to read from the buffer. The max. buffer size needs to be sized appropriately when using this option to balance maximum resource usage and the probability of premature termination of a substream.
Block
No new message can be read from the underlying connection from any substream as long as the buffer for a single substream is full, i.e. application code is expected to read from the full buffer.
Note: To avoid blocking without making progress, application tasks should ensure that, when woken, always try to read (i.e. make progress) from every substream on which data is expected. This is imperative in general, as a woken task never knows for which substream it has been woken, but failure to do so with
MaxBufferBehaviour::Block
in particular may lead to stalled execution or spinning of a task without progress.
Trait Implementations§
source§impl Clone for MaxBufferBehaviour
impl Clone for MaxBufferBehaviour
source§fn clone(&self) -> MaxBufferBehaviour
fn clone(&self) -> MaxBufferBehaviour
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for MaxBufferBehaviour
impl Debug for MaxBufferBehaviour
source§impl PartialEq for MaxBufferBehaviour
impl PartialEq for MaxBufferBehaviour
impl Copy for MaxBufferBehaviour
impl Eq for MaxBufferBehaviour
impl StructuralPartialEq for MaxBufferBehaviour
Auto Trait Implementations§
impl Freeze for MaxBufferBehaviour
impl RefUnwindSafe for MaxBufferBehaviour
impl Send for MaxBufferBehaviour
impl Sync for MaxBufferBehaviour
impl Unpin for MaxBufferBehaviour
impl UnwindSafe for MaxBufferBehaviour
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)source§impl<T> CloneToUninit for Twhere
T: Copy,
impl<T> CloneToUninit for Twhere
T: Copy,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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