pub fn verify_proof<'a, H, P, L>(
    root: &'a H::Output,
    proof: P,
    number_of_leaves: usize,
    leaf_index: usize,
    leaf: L
) -> boolwhere
    H: HashT,
    H::Output: PartialEq + AsRef<[u8]>,
    P: IntoIterator<Item = H::Output>,
    L: Into<Leaf<'a, H::Output>>,
Expand description

Verify Merkle Proof correctness versus given root hash.

The proof is NOT expected to contain leaf hash as the first element, but only all adjacent nodes required to eventually by process of concatenating and hashing end up with given root hash.

The proof must not contain the root hash.