Struct polkadot_ckb_merkle_mountain_range::MMR

source ·
pub struct MMR<T, M, S> { /* private fields */ }

Implementations§

source§

impl<T, M, S> MMR<T, M, S>

source

pub fn new(mmr_size: u64, store: S) -> Self

source

pub fn mmr_size(&self) -> u64

source

pub fn is_empty(&self) -> bool

source

pub fn batch(&self) -> &MMRBatch<T, S>

source

pub fn store(&self) -> &S

source§

impl<T: Clone + PartialEq, M: Merge<Item = T>, S: MMRStoreReadOps<T>> MMR<T, M, S>

source

pub fn push(&mut self, elem: T) -> Result<u64>

source

pub fn get_root(&self) -> Result<T>

get_root

source

pub fn get_ancestor_peaks_and_root( &self, prev_mmr_size: u64 ) -> Result<(Vec<T>, T)>

get_ancestor_root

source

pub fn gen_proof(&self, pos_list: Vec<u64>) -> Result<MerkleProof<T, M>>

Generate merkle proof for positions

  1. sort positions
  2. push merkle proof to proof by peak from left to right
  3. push bagged right hand side root
source

pub fn gen_node_proof( &self, pos_list: Vec<u64> ) -> Result<NodeMerkleProof<T, M>>

Generate node merkle proof for positions

  1. sort positions
  2. push merkle proof to proof by peak from left to right
  3. push bagged right hand side root
source

pub fn gen_ancestry_proof( &self, prev_mmr_size: u64 ) -> Result<AncestryProof<T, M>>

Generate proof that prior merkle root r’ is an ancestor of current merkle proof r

  1. calculate positions of peaks of old root r’ given mmr size n
  2. generate membership proof of peaks in root r
  3. calculate r’ from peaks(n)
  4. return (mmr root r’, peak hashes, membership proof of peaks(n) in r)
source§

impl<T, M, S: MMRStoreWriteOps<T>> MMR<T, M, S>

source

pub fn commit(&mut self) -> Result<()>

Auto Trait Implementations§

§

impl<T, M, S> Freeze for MMR<T, M, S>
where S: Freeze,

§

impl<T, M, S> RefUnwindSafe for MMR<T, M, S>

§

impl<T, M, S> Send for MMR<T, M, S>
where S: Send, M: Send, T: Send,

§

impl<T, M, S> Sync for MMR<T, M, S>
where S: Sync, M: Sync, T: Sync,

§

impl<T, M, S> Unpin for MMR<T, M, S>
where S: Unpin, M: Unpin, T: Unpin,

§

impl<T, M, S> UnwindSafe for MMR<T, M, S>
where S: UnwindSafe, M: UnwindSafe, T: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoEither for T

source§

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 more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.