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: DistributionShard<C>, ) -> Self
Sourcepub const fn commitment(&self) -> Commitment
pub const fn commitment(&self) -> Commitment
Returns the Commitment for this shard.
Sourcepub fn into_inner(self) -> DistributionShard<C>
pub fn into_inner(self) -> DistributionShard<C>
Takes the inner DistributionShard.
Sourcepub fn verify_into_weak(self) -> Option<Self>
pub fn verify_into_weak(self) -> Option<Self>
Verifies the shard and returns the weak shard for broadcasting if valid.
Returns Some(weak_shard) if the shard is valid and can be rebroadcast,
or None if the shard is invalid or already weak.
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§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 moreimpl<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>where
<C as Scheme>::StrongShard: RefUnwindSafe,
<C as Scheme>::WeakShard: RefUnwindSafe,
H: RefUnwindSafe,
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) -> IoBuf
fn encode_with_pool(&self, pool: &BufferPool) -> IoBuf
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