jon.recoil.org

Module N.Map

type key = N.t
module Set = N.Set
type !+'a t
val empty : 'a N.Map.t
val is_empty : 'a N.Map.t -> bool
val mem : N.Map.key -> 'a N.Map.t -> bool
val add : N.Map.key -> 'a -> 'a N.Map.t -> 'a N.Map.t
val update : N.Map.key -> ('a option -> 'a option) -> 'a N.Map.t -> 'a N.Map.t
val singleton : N.Map.key -> 'a -> 'a N.Map.t
val remove : N.Map.key -> 'a N.Map.t -> 'a N.Map.t
val merge : (N.Map.key -> 'a option -> 'b option -> 'c option) -> 'a N.Map.t -> 'b N.Map.t -> 'c N.Map.t
val union : (N.Map.key -> 'a -> 'a -> 'a option) -> 'a N.Map.t -> 'a N.Map.t -> 'a N.Map.t
val union_sharing : (N.Map.key -> 'a -> 'a -> 'a option) -> 'a N.Map.t -> 'a N.Map.t -> 'a N.Map.t

union_sharing f m1 m2 is a version of union f m1 m2 that maximizes sharing of the result with m1.

val union_shared : (N.Map.key -> 'a -> 'a -> 'a option) -> 'a N.Map.t -> 'a N.Map.t -> 'a N.Map.t

union_shared f m1 m2 is a version of union_sharing f m1 m2 that also exploits sharing of m1 and m2 to avoid calling f when possible, assuming that f x x = Some x for all xs.

val update_many : (N.Map.key -> 'a option -> 'b -> 'a option) -> 'a N.Map.t -> 'b N.Map.t -> 'a N.Map.t
val compare : ('a -> 'a -> int) -> 'a N.Map.t -> 'a N.Map.t -> int
val equal : ('a -> 'a -> bool) -> 'a N.Map.t -> 'a N.Map.t -> bool
val iter : (N.Map.key -> 'a -> unit) -> 'a N.Map.t -> unit
val fold : (N.Map.key -> 'a -> 'b -> 'b) -> 'a N.Map.t -> 'b -> 'b
val for_all : (N.Map.key -> 'a -> bool) -> 'a N.Map.t -> bool
val exists : (N.Map.key -> 'a -> bool) -> 'a N.Map.t -> bool
val filter : (N.Map.key -> 'a -> bool) -> 'a N.Map.t -> 'a N.Map.t
val filter_map : (N.Map.key -> 'a -> 'b option) -> 'a N.Map.t -> 'b N.Map.t
val filter_map_sharing : (N.Map.key -> 'a -> 'a option) -> 'a N.Map.t -> 'a N.Map.t
val partition : (N.Map.key -> 'a -> bool) -> 'a N.Map.t -> 'a N.Map.t * 'a N.Map.t
val cardinal : 'a N.Map.t -> int
val bindings : 'a N.Map.t -> (N.Map.key * 'a) list
val min_binding : 'a N.Map.t -> N.Map.key * 'a
val min_binding_opt : 'a N.Map.t -> (N.Map.key * 'a) option
val max_binding : 'a N.Map.t -> N.Map.key * 'a
val max_binding_opt : 'a N.Map.t -> (N.Map.key * 'a) option
val choose : 'a N.Map.t -> N.Map.key * 'a
val choose_opt : 'a N.Map.t -> (N.Map.key * 'a) option
val split : N.Map.key -> 'a N.Map.t -> 'a N.Map.t * 'a option * 'a N.Map.t
val find : N.Map.key -> 'a N.Map.t -> 'a
val find_opt : N.Map.key -> 'a N.Map.t -> 'a option
val map : ('a -> 'b) -> 'a N.Map.t -> 'b N.Map.t
val mapi : (N.Map.key -> 'a -> 'b) -> 'a N.Map.t -> 'b N.Map.t
val to_seq : 'a N.Map.t -> (N.Map.key * 'a) Stdlib.Seq.t
val print_debug : (Stdlib.Format.formatter -> 'a -> unit) -> Stdlib.Format.formatter -> 'a N.Map.t -> unit
val of_list : (N.Map.key * 'a) list -> 'a N.Map.t
val disjoint_union : ?eq:('a -> 'a -> bool) -> ?print:(Stdlib.Format.formatter -> 'a -> unit) -> 'a N.Map.t -> 'a N.Map.t -> 'a N.Map.t
val map_keys : (N.Map.key -> N.Map.key) -> 'a N.Map.t -> 'a N.Map.t
val keys : 'a N.Map.t -> Set.t
val data : 'a N.Map.t -> 'a list
val of_set : (N.Map.key -> 'a) -> Set.t -> 'a N.Map.t
val print : (Stdlib.Format.formatter -> 'a -> unit) -> Stdlib.Format.formatter -> 'a N.Map.t -> unit
val diff_domains : 'a N.Map.t -> 'b N.Map.t -> 'a N.Map.t
val inter : (N.Map.key -> 'a -> 'b -> 'c) -> 'a N.Map.t -> 'b N.Map.t -> 'c N.Map.t
val diff : (N.Map.key -> 'a -> 'b -> 'a option) -> 'a N.Map.t -> 'b N.Map.t -> 'a N.Map.t

diff f m1 m2 computes a map whose keys are a subset of the keys of m1. When a binding is defined in both m1 and m2, the function f is used to combine them. Bindings that are only present in m1 are preserved. This is a special case of merge: diff f m1 m2 is equivalent to merge f' m1 m2, where

  • f' _key None _ = None
  • f' _key (Some v) None = Some v
  • f' key (Some v1) (Some v2) = f key v1 v2
val diff_sharing : (N.Map.key -> 'a -> 'b -> 'a option) -> 'a N.Map.t -> 'b N.Map.t -> 'a N.Map.t

diff_sharing f m1 m2 is a version of diff f m1 m2 that maximizes sharing of the result with m1.

val diff_shared : (N.Map.key -> 'a -> 'a -> 'a option) -> 'a N.Map.t -> 'a N.Map.t -> 'a N.Map.t

diff_shared f m1 m2 is a version of diff_sharing f m1 m2 that further exploits sharing of m1 and m2 to avoid calling f when possible, assuming that f x x always returns None.

val inter_domain_is_non_empty : 'a N.Map.t -> 'a N.Map.t -> bool
val get_singleton : 'a N.Map.t -> (N.Map.key * 'a) option
val replace : N.Map.key -> ('a -> 'a) -> 'a N.Map.t -> 'a N.Map.t
val map_sharing : ('a -> 'a) -> 'a N.Map.t -> 'a N.Map.t