pub enum HashTree<'a> {
Empty,
Fork(Box<ForkInner<'a>>),
Labeled(Cow<'a, [u8]>, Box<HashTree<'a>>),
Leaf(Cow<'a, [u8]>),
Pruned(Hash),
}Expand description
HashTree as defined in the interfaces spec. https://sdk.dfinity.org/docs/interface-spec/index.html#_certificate
Variants§
Empty
Fork(Box<ForkInner<'a>>)
Labeled(Cow<'a, [u8]>, Box<HashTree<'a>>)
Leaf(Cow<'a, [u8]>)
Pruned(Hash)
Implementations§
Source§impl<'a> HashTree<'a>
impl<'a> HashTree<'a>
pub fn reconstruct(&self) -> Hash
Sourcepub fn get_labels<'b: 'a>(&'b self) -> Vec<&'b [u8]>
pub fn get_labels<'b: 'a>(&'b self) -> Vec<&'b [u8]>
Collect and return all of the labels in this HashTree.
This method is intended for testing purposes.
Sourcepub fn get_leaf_values<'b: 'a>(&'b self) -> Vec<&'b [u8]>
pub fn get_leaf_values<'b: 'a>(&'b self) -> Vec<&'b [u8]>
Collect and return all of the values in this HashTree.
This method is intended for testing purposes.
Trait Implementations§
Source§impl Serialize for HashTree<'_>
impl Serialize for HashTree<'_>
Source§fn serialize<S>(
&self,
serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
fn serialize<S>(
&self,
serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
Serialize this value into the given Serde serializer. Read more
impl<'a> Eq for HashTree<'a>
impl<'a> StructuralPartialEq for HashTree<'a>
Auto Trait Implementations§
impl<'a> Freeze for HashTree<'a>
impl<'a> RefUnwindSafe for HashTree<'a>
impl<'a> Send for HashTree<'a>
impl<'a> Sync for HashTree<'a>
impl<'a> Unpin for HashTree<'a>
impl<'a> UnwindSafe for HashTree<'a>
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