class SparseMerkleTree[D <: Digest] extends AnyRef
An implementation of sparse Merkle tree of predefined height. Supported operations are append new leaf and update previously appended leaf.
Linear Supertypes
Ordering
- Alphabetic
- By Inheritance
Inherited
- SparseMerkleTree
- AnyRef
- Any
- Hide All
- Show All
Visibility
- Public
- All
Instance Constructors
-
new
SparseMerkleTree(rootDigest: Option[D], height: Byte, lastProof: SparseMerkleProof[D])(implicit hf: CryptographicHash[D])
- rootDigest
- root hash of the tree
- height
- W parameter from the paper, defines how many bits in the key, up to 127
Value Members
-
final
def
!=(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
final
def
##(): Int
- Definition Classes
- AnyRef → Any
-
final
def
==(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
final
def
asInstanceOf[T0]: T0
- Definition Classes
- Any
-
def
clone(): AnyRef
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws( ... ) @native() @HotSpotIntrinsicCandidate()
-
final
def
eq(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
-
def
equals(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
final
def
getClass(): Class[_]
- Definition Classes
- AnyRef → Any
- Annotations
- @native() @HotSpotIntrinsicCandidate()
-
def
hashCode(): Int
- Definition Classes
- AnyRef → Any
- Annotations
- @native() @HotSpotIntrinsicCandidate()
- val height: Byte
-
final
def
isInstanceOf[T0]: Boolean
- Definition Classes
- Any
- lazy val lastIndex: ID
- val lastProof: SparseMerkleProof[D]
-
final
def
ne(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
-
final
def
notify(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native() @HotSpotIntrinsicCandidate()
-
final
def
notifyAll(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native() @HotSpotIntrinsicCandidate()
- val rootDigest: Option[D]
-
final
def
synchronized[T0](arg0: ⇒ T0): T0
- Definition Classes
- AnyRef
-
def
toString(): String
- Definition Classes
- AnyRef → Any
-
def
update(proof: SparseMerkleProof[D], newLeafData: Option[LeafData], proofsToUpdate: Seq[SparseMerkleProof[D]] = Seq(), filterFn: FilterFn = SparseMerkleTree.passAllFilterFn): Try[(SparseMerkleTree[D], Seq[SparseMerkleProof[D]])]
Both append and update ops are here.
Both append and update ops are here.
- proof
- proof for some leaf
- newLeafData
- new data for the leaf
-
final
def
wait(arg0: Long, arg1: Int): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws( ... )
-
final
def
wait(arg0: Long): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws( ... ) @native()
-
final
def
wait(): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws( ... )
Deprecated Value Members
-
def
finalize(): Unit
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws( classOf[java.lang.Throwable] ) @Deprecated
- Deprecated