pub struct Shard<C: Scheme, H: Hasher> { /* private fields */ }Expand description
A broadcastable shard of erasure coded data, including the coding commitment and the configuration used to code the data.
Implementations§
Source§impl<C: Scheme, H: Hasher> Shard<C, H>
impl<C: Scheme, H: Hasher> Shard<C, H>
pub const fn new(commitment: Commitment, index: u16, inner: C::Shard) -> Self
Sourcepub const fn commitment(&self) -> Commitment
pub const fn commitment(&self) -> Commitment
Returns the Commitment for this shard.
Sourcepub fn into_inner(self) -> C::Shard
pub fn into_inner(self) -> C::Shard
Takes the inner shard.
Trait Implementations§
Source§impl<C: Scheme, H: Hasher> Committable for Shard<C, H>
impl<C: Scheme, H: Hasher> Committable for Shard<C, H>
Source§type Commitment = Commitment
type Commitment = Commitment
The type of commitment produced by this object.
Source§fn commitment(&self) -> Self::Commitment
fn commitment(&self) -> Self::Commitment
Source§impl<C: Scheme, H: Hasher> EncodeSize for Shard<C, H>
impl<C: Scheme, H: Hasher> EncodeSize for Shard<C, H>
Source§fn encode_size(&self) -> usize
fn encode_size(&self) -> usize
Returns the encoded size of this value (in bytes).
Source§fn encode_inline_size(&self) -> usize
fn encode_inline_size(&self) -> usize
Returns the encoded size excluding bytes passed to
BufsMut::push
during Write::write_bufs. Used to size the working buffer for inline
writes. Override alongside Write::write_bufs for types where large
Bytes fields go via push; failing to do so will over-allocate.Source§impl<C: Scheme, H: Hasher> Read for Shard<C, H>
impl<C: Scheme, H: Hasher> Read for Shard<C, H>
Source§type Cfg = CodecConfig
type Cfg = CodecConfig
The
Cfg type parameter allows passing configuration during the read process. This is
crucial for safely decoding untrusted data, for example, by providing size limits for
collections or strings. Read moreSource§impl<C: Scheme, H: Hasher> Write for Shard<C, H>
impl<C: Scheme, H: Hasher> Write for Shard<C, H>
Source§fn write_bufs(&self, buf: &mut impl BufsMut)
fn write_bufs(&self, buf: &mut impl BufsMut)
Writes to a
BufsMut, allowing existing Bytes chunks to be
appended via BufsMut::push instead of written inline. Must encode
to the same format as Write::write. Defaults to Write::write.impl<C: Scheme, H: Hasher> Eq for Shard<C, H>
Auto Trait Implementations§
impl<C, H> Freeze for Shard<C, H>
impl<C, H> RefUnwindSafe for Shard<C, H>
impl<C, H> Send for Shard<C, H>
impl<C, H> Sync for Shard<C, H>
impl<C, H> Unpin for Shard<C, H>
impl<C, H> UnsafeUnpin for Shard<C, H>
impl<C, H> UnwindSafe for Shard<C, H>
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Encode for Twhere
T: Write + EncodeSize,
impl<T> Encode for Twhere
T: Write + EncodeSize,
Source§impl<T> EncodeExt for Twhere
T: EncodeSize + Write,
impl<T> EncodeExt for Twhere
T: EncodeSize + Write,
Source§fn encode_with_pool_mut(&self, pool: &BufferPool) -> IoBufMut
fn encode_with_pool_mut(&self, pool: &BufferPool) -> IoBufMut
Source§fn encode_with_pool(&self, pool: &BufferPool) -> IoBufs
fn encode_with_pool(&self, pool: &BufferPool) -> IoBufs
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<T> FutureExt for T
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
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<B> IntoBlock<B> for B
impl<B> IntoBlock<B> for B
Source§fn into_block(self) -> B
fn into_block(self) -> B
Convert this cached block into the underlying block type.
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>
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 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>
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