pub struct MerkleTree { /* private fields */ }Expand description
A Merkle tree for verifying context packet integrity
Implementations§
Source§impl MerkleTree
impl MerkleTree
Sourcepub fn from_leaves(leaves: Vec<(String, Hash)>) -> Self
pub fn from_leaves(leaves: Vec<(String, Hash)>) -> Self
Build a Merkle tree from a list of (id, hash) pairs (zero-copy construction)
Sourcepub fn contains(&self, target_hash: &Hash) -> bool
pub fn contains(&self, target_hash: &Hash) -> bool
Verify that a hash is part of this tree (zero-copy traversal)
Sourcepub fn contains_iterative(&self, target_hash: &Hash) -> bool
pub fn contains_iterative(&self, target_hash: &Hash) -> bool
Optimized search using iterative traversal (prevents stack overflow for deep trees)
Sourcepub fn get_proof_by_hash(&self, target_hash: &Hash) -> Option<MerkleProof>
pub fn get_proof_by_hash(&self, target_hash: &Hash) -> Option<MerkleProof>
Generate an inclusion proof for a leaf by its hash Returns None if the hash is not found in the tree
Sourcepub fn verify_proof(&self, proof: &MerkleProof) -> bool
pub fn verify_proof(&self, proof: &MerkleProof) -> bool
Verify a proof against this tree’s root
Trait Implementations§
Source§impl Clone for MerkleTree
impl Clone for MerkleTree
Source§fn clone(&self) -> MerkleTree
fn clone(&self) -> MerkleTree
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for MerkleTree
impl Debug for MerkleTree
Auto Trait Implementations§
impl Freeze for MerkleTree
impl RefUnwindSafe for MerkleTree
impl Send for MerkleTree
impl Sync for MerkleTree
impl Unpin for MerkleTree
impl UnwindSafe for MerkleTree
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,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§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>
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