Struct MMR

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

Implementations§

§

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

pub fn new(mmr_size: u64, store: S) -> MMR<T, M, S>

pub fn mmr_size(&self) -> u64

pub fn is_empty(&self) -> bool

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

pub fn store(&self) -> &S

§

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

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

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

get_root

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

get_ancestor_root

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

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

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

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

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

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

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

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

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
§

impl<T> CheckedConversion for T

§

fn checked_from<T>(t: T) -> Option<Self>
where Self: TryFrom<T>,

Convert from a value of T into an equivalent instance of Option<Self>. Read more
§

fn checked_into<T>(self) -> Option<T>
where Self: TryInto<T>,

Consume self to return Some equivalent value of Option<T>. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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
§

impl<T, U> IntoKey<U> for T
where U: FromKey<T>,

§

fn into_key(self) -> U

§

impl<Src, Dest> IntoTuple<Dest> for Src
where Dest: FromTuple<Src>,

§

fn into_tuple(self) -> Dest

§

impl<T> IsType<T> for T

§

fn from_ref(t: &T) -> &T

Cast reference.
§

fn into_ref(&self) -> &T

Cast reference.
§

fn from_mut(t: &mut T) -> &mut T

Cast mutable reference.
§

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

Cast mutable reference.
§

impl<T, Outer> IsWrappedBy<Outer> for T
where Outer: AsRef<T> + AsMut<T> + From<T>, T: From<Outer>,

§

fn from_ref(outer: &Outer) -> &T

Get a reference to the inner from the outer.

§

fn from_mut(outer: &mut Outer) -> &mut T

Get a mutable reference to the inner from the outer.

§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
§

impl<T> SaturatedConversion for T

§

fn saturated_from<T>(t: T) -> Self
where Self: UniqueSaturatedFrom<T>,

Convert from a value of T into an equivalent instance of Self. Read more
§

fn saturated_into<T>(self) -> T
where Self: UniqueSaturatedInto<T>,

Consume self to return an equivalent value of T. Read more
Source§

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

Source§

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>,

Source§

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

impl<T, U> TryIntoKey<U> for T
where U: TryFromKey<T>,

§

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

§

fn try_into_key(self) -> Result<U, <U as TryFromKey<T>>::Error>

§

impl<S, T> UncheckedInto<T> for S
where T: UncheckedFrom<S>,

§

fn unchecked_into(self) -> T

The counterpart to unchecked_from.
§

impl<T, S> UniqueSaturatedInto<T> for S
where T: Bounded, S: TryInto<T>,

§

fn unique_saturated_into(self) -> T

Consume self to return an equivalent value of T.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

impl<T> ErasedDestructor for T
where T: 'static,

§

impl<T> JsonSchemaMaybe for T

§

impl<T> MaybeRefUnwindSafe for T
where T: RefUnwindSafe,

§

impl<T> MaybeSendSync for T