package octez-libs
elt_bytes x
returns the byte sequence representation of the element x
.
include HASH
include MINIMAL_HASH
val pp : Format.formatter -> t -> unit
val pp_short : Format.formatter -> t -> unit
include Tezos_stdlib.Compare.S with type t := t
val hash_string : ?key:string -> string list -> t
hash_string ?key inputs
returns a hash.
Raises an Assert_failure
if String.length key > 64
.
val zero : t
include RAW_DATA with type t := t
val to_hex : t -> Tezos_stdlib.Hex.t
val of_hex : Tezos_stdlib.Hex.t -> t Tezos_error_monad.Error_monad.tzresult
val of_hex_opt : Tezos_stdlib.Hex.t -> t option
val of_hex_exn : Tezos_stdlib.Hex.t -> t
val to_string : t -> string
val of_string : string -> t Tezos_error_monad.Error_monad.tzresult
val of_string_opt : string -> t option
val of_string_exn : string -> t
val of_bytes : Bytes.t -> t Tezos_error_monad.Error_monad.tzresult
include INDEXES with type t := t
val hash : t -> int
val seeded_hash : int -> t -> int
val to_path : t -> string list -> string list
val of_path : string list -> t option
val of_path_exn : string list -> t
module Set : sig ... end
module Map : sig ... end
module Table : sig ... end
module Error_table : sig ... end
module WeakRingTable : sig ... end
compute xs
computes a full binary tree from the list xs
.
In this tree the ith leaf (from left to right) is the ith element of the list xs
. If xs
is the empty list, then the result is the empty tree. If the length of xs
is not a power of 2, then the tree is padded with leaves containing the last element of xs
such that a full tree is obtained.
Example: given the list [1; 2; 3]
, the tree
/\ / \ /\ /\ 1 2 3 3
is built.
val empty : t
The empty
Merkle tree.
A path
to an element in a Merkle tree.
A path
is either:
Left (p, r)
, indicating that the element is in the left subtree, from which the pathp
should be taken to find the element.r
is the left subtree where this branching decision is made.Right (l, p)
, indicating that the element is in the right subtree, from which the pathp
should be taken to find the element.l
is the left subtree where this branching decision is made.Op
, indicating that the path traversal has reached the element.
Example:
/\ / \ /\ /\ 4 5 6 7
The path to the third leaf, containing 6
will be:
Right (node (leaf 4, leaf 5), Left (Op, leaf 7))
Consequently, the path will contain all the information to reconstruct the full tree, except the element to which the path lead.
val path_encoding : path Data_encoding.t
Encoding of a path.
val bounded_path_encoding : ?max_length:int -> unit -> path Data_encoding.t
Encoding of a path, with optional bound max_length
.
The encoding is bounded to log2(max_length) * (size + 1) + 1
bytes.
compute_path xs i
computes the path to the i
th leaf of the Merkle tree computed from xs
, that will also contain the ith element of xs
.