module type S2 = sig
.. end
type ('a, +'b)
t
module T: Core_map_intf.Types
with type 'a key = 'a
with type ('a, +'b) t = ('a, 'b) t
include Binable.S2
include Sexpable.S2
val empty : ('a, 'b) t
val singleton : 'a -> 'b -> ('a, 'b) t
val is_empty : ('a, 'b) t -> bool
val cardinal : ('a, 'b) t -> int
val add : key:'a ->
data:'b -> ('a, 'b) t -> ('a, 'b) t
val add_multi : key:'a ->
data:'b ->
('a, 'b list) t -> ('a, 'b list) t
val change : ('a, 'b) t ->
'a -> ('b option -> 'b option) -> ('a, 'b) t
val find_exn : ('a, 'b) t -> 'a -> 'b
val find : ('a, 'b) t -> 'a -> 'b option
val remove : ('a, 'b) t -> 'a -> ('a, 'b) t
val mem : ('a, 'b) t -> 'a -> bool
val iter : f:(key:'a -> data:'b -> unit) -> ('a, 'b) t -> unit
val map : f:('a -> 'b) -> ('c, 'a) t -> ('c, 'b) t
val mapi : f:(key:'a -> data:'b -> 'c) ->
('a, 'b) t -> ('a, 'c) t
val fold : f:(key:'a -> data:'b -> 'c -> 'c) ->
('a, 'b) t -> init:'c -> 'c
val fold_right : f:(key:'a -> data:'b -> 'c -> 'c) ->
('a, 'b) t -> init:'c -> 'c
val filter : f:(key:'a -> data:'b -> bool) ->
('a, 'b) t -> ('a, 'b) t
val filter_map : f:('a -> 'b option) ->
('c, 'a) t -> ('c, 'b) t
val filter_mapi : f:(key:'a -> data:'b -> 'c option) ->
('a, 'b) t -> ('a, 'c) t
val compare : ('a -> 'a -> int) ->
('b, 'a) t -> ('b, 'a) t -> int
val equal : ('a -> 'a -> bool) ->
('b, 'a) t -> ('b, 'a) t -> bool
val keys : ('a, 'b) t -> 'a list
val has_key : ('a, 'b) t -> 'a -> bool
val data : ('a, 'b) t -> 'b list
val of_alist : ('a * 'b) list ->
[ `Duplicate_key of 'a | `Ok of ('a, 'b) t ]
val of_alist_exn : ('a * 'b) list -> ('a, 'b) t
val of_alist_multi : ('a * 'b) list -> ('a, 'b list) t
val to_alist : ('a, 'b) t -> ('a * 'b) list
val combine_alist : ('a * 'b) list ->
init:'c -> f:('b -> 'c -> 'c) -> ('a, 'c) t
val merge : f:(key:'a -> 'b option -> 'c option -> 'd option) ->
('a, 'b) t ->
('a, 'c) t -> ('a, 'd) t
val min_elt : ('a, 'b) t -> ('a * 'b) option
val min_elt_exn : ('a, 'b) t -> 'a * 'b
val max_elt : ('a, 'b) t -> ('a * 'b) option
val max_elt_exn : ('a, 'b) t -> 'a * 'b
val for_all : f:('a -> bool) -> ('b, 'a) t -> bool
val exists : f:('a -> bool) -> ('b, 'a) t -> bool
val fold_range_inclusive : ('a, 'b) t ->
min:'a -> max:'a -> init:'c -> f:(key:'a -> data:'b -> 'c -> 'c) -> 'c
val range_to_alist : ('a, 'b) t -> min:'a -> max:'a -> ('a * 'b) list
val next_key : ('a, 'b) t -> 'a -> 'a option
val prev_key : ('a, 'b) t -> 'a -> 'a option
val rank : ('a, 'b) t -> 'a -> int option