Module Ledger.Db

include Merkle_ledger.Base_ledger_intf.S with module Location = Location with module Addr = Location.Addr with type root_hash := Mina_base.Ledger_hash.t with type hash := Mina_base.Ledger_hash.t with type account := Mina_base.Account.t with type key := Signature_lib.Public_key.Compressed.t with type token_id := Mina_base.Token_id.t with type token_id_set := Mina_base.Token_id.Set.t with type account_id := Mina_base.Account_id.t with type account_id_set := Mina_base.Account_id.Set.t
type index = int
type t

no deriving, purposely; signatures that include this one may add deriving

module Addr = Location.Addr
module Location = Location
include Merkle_ledger.Syncable_intf.S with type root_hash := Mina_base.Ledger_hash.t and type hash := Mina_base.Ledger_hash.t and type account := Mina_base.Account.t and type addr := Addr.t and type path = Path.t and type t := t
include Ppx_sexp_conv_lib.Sexpable.S with type t := t
val t_of_sexp : Sexplib0__.Sexp.t -> t
val sexp_of_t : t -> Sexplib0__.Sexp.t
type path = Path.t
val depth : t -> int
val num_accounts : t -> int
val merkle_path_at_addr_exn : t -> Addr.t -> path
val get_inner_hash_at_addr_exn : t -> Addr.t -> Mina_base.Ledger_hash.t
val set_inner_hash_at_addr_exn : t -> Addr.t -> Mina_base.Ledger_hash.t -> unit
val set_all_accounts_rooted_at_exn : t -> Addr.t -> Mina_base.Account.t list -> unit
val set_batch_accounts : t -> (Addr.t * Mina_base.Account.t) list -> unit
val get_all_accounts_rooted_at_exn : t -> Addr.t -> (Addr.t * Mina_base.Account.t) list

Get all of the accounts that are in a subtree of the underlying Merkle tree rooted at `address`. The accounts are ordered by their addresses.

val make_space_for : t -> int -> unit
val to_list : t -> Mina_base.Account.t list

list of accounts in the ledger

val iteri : t -> f:( index -> Mina_base.Account.t -> unit ) -> unit

iterate over all indexes and accounts

val foldi : t -> init:'accum -> f:( Addr.t -> 'accum -> Mina_base.Account.t -> 'accum ) -> 'accum

fold over accounts in the ledger, passing the Merkle address

val foldi_with_ignored_accounts : t -> Mina_base.Account_id.Set.t -> init:'accum -> f:( Addr.t -> 'accum -> Mina_base.Account.t -> 'accum ) -> 'accum

the set of account_ids are ledger elements to skip during the fold, because they're in a mask

val fold_until : t -> init:'accum -> f: ( 'accum -> Mina_base.Account.t -> ( 'accum, 'stop ) Base.Continue_or_stop.t ) -> finish:( 'accum -> 'stop ) -> 'stop

fold over accounts until stop condition reached when calling f; calls finish for result

val accounts : t -> Mina_base.Account_id.Set.t

set of account ids associated with accounts

val token_owner : t -> Mina_base.Token_id.t -> Mina_base.Account_id.t option

Get the account id that owns a token.

val token_owners : t -> Mina_base.Account_id.Set.t

Get the set of all accounts which own a token.

Get all of the tokens for which a public key has accounts.

val location_of_account : t -> Mina_base.Account_id.t -> Location.t option
val location_of_account_batch : t -> Mina_base.Account_id.t list -> (Mina_base.Account_id.t * Location.t option) list
val get_or_create_account : t -> Mina_base.Account_id.t -> Mina_base.Account.t -> ([ `Added | `Existed ] * Location.t) Core.Or_error.t

This may return an error if the ledger is full.

val close : t -> unit

the ledger should not be used after calling close

val last_filled : t -> Location.t option

for account locations in the ledger, the last (rightmost) filled location

val get_uuid : t -> Uuid.t
val get_directory : t -> string option

return Some directory for ledgers that use a file system, else None

val get : t -> Location.t -> Mina_base.Account.t option
val get_batch : t -> Location.t list -> (Location.t * Mina_base.Account.t option) list
val set : t -> Location.t -> Mina_base.Account.t -> unit
val set_batch : t -> (Location.t * Mina_base.Account.t) list -> unit
val get_at_index_exn : t -> int -> Mina_base.Account.t
val set_at_index_exn : t -> int -> Mina_base.Account.t -> unit
val index_of_account_exn : t -> Mina_base.Account_id.t -> int
val merkle_root : t -> Mina_base.Ledger_hash.t

meant to be a fast operation: the root hash is stored, rather than calculated dynamically

val merkle_path : t -> Location.t -> Path.t
val merkle_path_at_index_exn : t -> int -> Path.t
val remove_accounts_exn : t -> Mina_base.Account_id.t list -> unit
val detached_signal : t -> unit Async_kernel.Deferred.t

Triggers when the ledger has been detached and should no longer be accessed.

val create : ?directory_name:string -> depth:int -> unit -> t
val create_checkpoint : t -> directory_name:string -> unit -> t

create_checkpoint would create the checkpoint and open a db connection to that checkpoint

val make_checkpoint : t -> directory_name:string -> unit

make_checkpoint would only create the checkpoint

val with_ledger : depth:int -> f:( t -> 'a ) -> 'a
module For_tests : sig ... end