package irmin
-
irmin
-
-
irmin_mem
-
Library
Module
Module type
Parameter
Class
Class type
Store
creates a new commit store.
Parameters
module N : sig ... end
module C : sig ... end
Signature
Commit Store
Content-addressable stores
Content-addressable stores are store where it is possible to read and add new values. Keys are derived from the values raw contents and hence are deterministic.
The type for content-addressable backend stores. The 'a
phantom type carries information about the store mutability.
type key = C.key
The type for keys.
type value = C.value
The type for raw values.
val mem : [> Perms.read ] t -> key -> bool Lwt.t
mem t k
is true iff k
is present in t
.
val find : [> Perms.read ] t -> key -> value option Lwt.t
find t k
is Some v
if k
is associated to v
in t
and None
is k
is not present in t
.
val add : [> Perms.write ] t -> value -> key Lwt.t
Write the contents of a value to the store. It's the responsibility of the content-addressable store to generate a consistent key.
val unsafe_add : [> Perms.write ] t -> key -> value -> unit Lwt.t
Same as add
but allows to specify the key directly. The backend might choose to discared that key and/or can be corrupt if the key scheme is not consistent.
val merge : [> Perms.read_write ] t -> info:Info.f -> key option Merge.t
merge
is the 3-way merge function for commit keys.
Key
provides base functions for commit keys.
module Val = C.Val
Val
provides functions for commit values.
module Node : sig ... end
Node
is the underlying node store.