pub struct Block {
pub header: BlockHeader,
pub events: Vec<AuditEvent>,
}Expand description
A complete block with header and events.
Fields§
§header: BlockHeader§events: Vec<AuditEvent>Implementations§
Source§impl Block
impl Block
Sourcepub fn validate(&self, parent: Option<&BlockHeader>) -> Result<()>
pub fn validate(&self, parent: Option<&BlockHeader>) -> Result<()>
Validate the block (sequential event verification).
For better performance with many events, use validate_batch() instead.
Sourcepub fn validate_batch(&self, parent: Option<&BlockHeader>) -> Result<()>
pub fn validate_batch(&self, parent: Option<&BlockHeader>) -> Result<()>
Validate the block using batch signature verification.
This is 3-8x faster than validate() for blocks with many events,
using Arcanum’s optimized Ed25519 batch verifier.
§Performance
- 10 events: ~2x faster
- 100 events: ~4x faster
- 1000 events: ~6-8x faster
Sourcepub fn validate_parallel(&self, parent: Option<&BlockHeader>) -> Result<()>
pub fn validate_parallel(&self, parent: Option<&BlockHeader>) -> Result<()>
Validate the block using fully parallel processing.
Uses batch signature verification (the main speedup) combined with parallel canonical bytes computation for large blocks (1000+ events).
Note: Parallel merkle tree is not used because BLAKE3 is already SIMD-accelerated, making parallelization overhead counterproductive.
§Performance
- Uses all available CPU cores for signature verification
- 100 events: ~2.5x faster than sequential
- 500 events: ~2.5x faster than sequential
- 1000+ events: ~2.7x faster than sequential (parallel canonical bytes kicks in)
§When to Use
- Blocks with many events where signature verification dominates
- For bulk validation of historical blocks
Trait Implementations§
Source§impl<'de> Deserialize<'de> for Block
impl<'de> Deserialize<'de> for Block
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
impl Eq for Block
impl StructuralPartialEq for Block
Auto Trait Implementations§
impl Freeze for Block
impl RefUnwindSafe for Block
impl Send for Block
impl Sync for Block
impl Unpin for Block
impl UnwindSafe for Block
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
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<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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 moreSource§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.