sig
module type OrderedType = Map.OrderedType
module type S =
sig
type key
type +'a t
val empty : 'a Extmap.S.t
val is_empty : 'a Extmap.S.t -> bool
val mem : Extmap.S.key -> 'a Extmap.S.t -> bool
val add : Extmap.S.key -> 'a -> 'a Extmap.S.t -> 'a Extmap.S.t
val singleton : Extmap.S.key -> 'a -> 'a Extmap.S.t
val remove : Extmap.S.key -> 'a Extmap.S.t -> 'a Extmap.S.t
val merge :
(Extmap.S.key -> 'a option -> 'b option -> 'c option) ->
'a Extmap.S.t -> 'b Extmap.S.t -> 'c Extmap.S.t
val union :
(Extmap.S.key -> 'a -> 'a -> 'a option) ->
'a Extmap.S.t -> 'a Extmap.S.t -> 'a Extmap.S.t
val compare :
('a -> 'a -> int) -> 'a Extmap.S.t -> 'a Extmap.S.t -> int
val equal :
('a -> 'a -> bool) -> 'a Extmap.S.t -> 'a Extmap.S.t -> bool
val iter : (Extmap.S.key -> 'a -> unit) -> 'a Extmap.S.t -> unit
val fold :
(Extmap.S.key -> 'a -> 'b -> 'b) -> 'a Extmap.S.t -> 'b -> 'b
val for_all : (Extmap.S.key -> 'a -> bool) -> 'a Extmap.S.t -> bool
val exists : (Extmap.S.key -> 'a -> bool) -> 'a Extmap.S.t -> bool
val filter :
(Extmap.S.key -> 'a -> bool) -> 'a Extmap.S.t -> 'a Extmap.S.t
val partition :
(Extmap.S.key -> 'a -> bool) ->
'a Extmap.S.t -> 'a Extmap.S.t * 'a Extmap.S.t
val cardinal : 'a Extmap.S.t -> int
val bindings : 'a Extmap.S.t -> (Extmap.S.key * 'a) list
val min_binding : 'a Extmap.S.t -> Extmap.S.key * 'a
val max_binding : 'a Extmap.S.t -> Extmap.S.key * 'a
val choose : 'a Extmap.S.t -> Extmap.S.key * 'a
val split :
Extmap.S.key ->
'a Extmap.S.t -> 'a Extmap.S.t * 'a option * 'a Extmap.S.t
val find : Extmap.S.key -> 'a Extmap.S.t -> 'a
val map : ('a -> 'b) -> 'a Extmap.S.t -> 'b Extmap.S.t
val mapi : (Extmap.S.key -> 'a -> 'b) -> 'a Extmap.S.t -> 'b Extmap.S.t
val change :
('a option -> 'a option) ->
Extmap.S.key -> 'a Extmap.S.t -> 'a Extmap.S.t
val inter :
(Extmap.S.key -> 'a -> 'b -> 'c option) ->
'a Extmap.S.t -> 'b Extmap.S.t -> 'c Extmap.S.t
val diff :
(Extmap.S.key -> 'a -> 'b -> 'a option) ->
'a Extmap.S.t -> 'b Extmap.S.t -> 'a Extmap.S.t
val submap :
(Extmap.S.key -> 'a -> 'b -> bool) ->
'a Extmap.S.t -> 'b Extmap.S.t -> bool
val disjoint :
(Extmap.S.key -> 'a -> 'b -> bool) ->
'a Extmap.S.t -> 'b Extmap.S.t -> bool
val set_union : 'a Extmap.S.t -> 'a Extmap.S.t -> 'a Extmap.S.t
val set_inter : 'a Extmap.S.t -> 'b Extmap.S.t -> 'a Extmap.S.t
val set_diff : 'a Extmap.S.t -> 'b Extmap.S.t -> 'a Extmap.S.t
val set_submap : 'a Extmap.S.t -> 'b Extmap.S.t -> bool
val set_disjoint : 'a Extmap.S.t -> 'b Extmap.S.t -> bool
val set_compare : 'a Extmap.S.t -> 'b Extmap.S.t -> int
val set_equal : 'a Extmap.S.t -> 'b Extmap.S.t -> bool
val find_def : 'a -> Extmap.S.key -> 'a Extmap.S.t -> 'a
val find_opt : Extmap.S.key -> 'a Extmap.S.t -> 'a option
val find_exn : exn -> Extmap.S.key -> 'a Extmap.S.t -> 'a
val map_filter : ('a -> 'b option) -> 'a Extmap.S.t -> 'b Extmap.S.t
val mapi_filter :
(Extmap.S.key -> 'a -> 'b option) -> 'a Extmap.S.t -> 'b Extmap.S.t
val mapi_fold :
(Extmap.S.key -> 'a -> 'acc -> 'acc * 'b) ->
'a Extmap.S.t -> 'acc -> 'acc * 'b Extmap.S.t
val mapi_filter_fold :
(Extmap.S.key -> 'a -> 'acc -> 'acc * 'b option) ->
'a Extmap.S.t -> 'acc -> 'acc * 'b Extmap.S.t
val fold_left :
('b -> Extmap.S.key -> 'a -> 'b) -> 'b -> 'a Extmap.S.t -> 'b
val fold_right :
(Extmap.S.key -> 'a -> 'b -> 'b) -> 'a Extmap.S.t -> 'b -> 'b
val fold2_inter :
(Extmap.S.key -> 'a -> 'b -> 'c -> 'c) ->
'a Extmap.S.t -> 'b Extmap.S.t -> 'c -> 'c
val fold2_union :
(Extmap.S.key -> 'a option -> 'b option -> 'c -> 'c) ->
'a Extmap.S.t -> 'b Extmap.S.t -> 'c -> 'c
val translate :
(Extmap.S.key -> Extmap.S.key) -> 'a Extmap.S.t -> 'a Extmap.S.t
val add_new :
exn -> Extmap.S.key -> 'a -> 'a Extmap.S.t -> 'a Extmap.S.t
val replace :
exn -> Extmap.S.key -> 'a -> 'a Extmap.S.t -> 'a Extmap.S.t
val keys : 'a Extmap.S.t -> Extmap.S.key list
val values : 'a Extmap.S.t -> 'a list
val of_list : (Extmap.S.key * 'a) list -> 'a Extmap.S.t
val contains : 'a Extmap.S.t -> Extmap.S.key -> bool
val domain : 'a Extmap.S.t -> unit Extmap.S.t
val subdomain :
(Extmap.S.key -> 'a -> bool) -> 'a Extmap.S.t -> unit Extmap.S.t
val is_num_elt : int -> 'a Extmap.S.t -> bool
type 'a enumeration
val val_enum : 'a Extmap.S.enumeration -> (Extmap.S.key * 'a) option
val start_enum : 'a Extmap.S.t -> 'a Extmap.S.enumeration
val next_enum : 'a Extmap.S.enumeration -> 'a Extmap.S.enumeration
val start_ge_enum :
Extmap.S.key -> 'a Extmap.S.t -> 'a Extmap.S.enumeration
val next_ge_enum :
Extmap.S.key -> 'a Extmap.S.enumeration -> 'a Extmap.S.enumeration
end
module Make :
functor (Ord : OrderedType) ->
sig
type key = Ord.t
type +'a t
val empty : 'a t
val is_empty : 'a t -> bool
val mem : key -> 'a t -> bool
val add : key -> 'a -> 'a t -> 'a t
val singleton : key -> 'a -> 'a t
val remove : key -> 'a t -> 'a t
val merge :
(key -> 'a option -> 'b option -> 'c option) ->
'a t -> 'b t -> 'c t
val union : (key -> 'a -> 'a -> 'a option) -> 'a t -> 'a t -> 'a t
val compare : ('a -> 'a -> int) -> 'a t -> 'a t -> int
val equal : ('a -> 'a -> bool) -> 'a t -> 'a t -> bool
val iter : (key -> 'a -> unit) -> 'a t -> unit
val fold : (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b
val for_all : (key -> 'a -> bool) -> 'a t -> bool
val exists : (key -> 'a -> bool) -> 'a t -> bool
val filter : (key -> 'a -> bool) -> 'a t -> 'a t
val partition : (key -> 'a -> bool) -> 'a t -> 'a t * 'a t
val cardinal : 'a t -> int
val bindings : 'a t -> (key * 'a) list
val min_binding : 'a t -> key * 'a
val max_binding : 'a t -> key * 'a
val choose : 'a t -> key * 'a
val split : key -> 'a t -> 'a t * 'a option * 'a t
val find : key -> 'a t -> 'a
val map : ('a -> 'b) -> 'a t -> 'b t
val mapi : (key -> 'a -> 'b) -> 'a t -> 'b t
val change : ('a option -> 'a option) -> key -> 'a t -> 'a t
val inter : (key -> 'a -> 'b -> 'c option) -> 'a t -> 'b t -> 'c t
val diff : (key -> 'a -> 'b -> 'a option) -> 'a t -> 'b t -> 'a t
val submap : (key -> 'a -> 'b -> bool) -> 'a t -> 'b t -> bool
val disjoint : (key -> 'a -> 'b -> bool) -> 'a t -> 'b t -> bool
val set_union : 'a t -> 'a t -> 'a t
val set_inter : 'a t -> 'b t -> 'a t
val set_diff : 'a t -> 'b t -> 'a t
val set_submap : 'a t -> 'b t -> bool
val set_disjoint : 'a t -> 'b t -> bool
val set_compare : 'a t -> 'b t -> int
val set_equal : 'a t -> 'b t -> bool
val find_def : 'a -> key -> 'a t -> 'a
val find_opt : key -> 'a t -> 'a option
val find_exn : exn -> key -> 'a t -> 'a
val map_filter : ('a -> 'b option) -> 'a t -> 'b t
val mapi_filter : (key -> 'a -> 'b option) -> 'a t -> 'b t
val mapi_fold :
(key -> 'a -> 'acc -> 'acc * 'b) -> 'a t -> 'acc -> 'acc * 'b t
val mapi_filter_fold :
(key -> 'a -> 'acc -> 'acc * 'b option) ->
'a t -> 'acc -> 'acc * 'b t
val fold_left : ('b -> key -> 'a -> 'b) -> 'b -> 'a t -> 'b
val fold_right : (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b
val fold2_inter :
(key -> 'a -> 'b -> 'c -> 'c) -> 'a t -> 'b t -> 'c -> 'c
val fold2_union :
(key -> 'a option -> 'b option -> 'c -> 'c) ->
'a t -> 'b t -> 'c -> 'c
val translate : (key -> key) -> 'a t -> 'a t
val add_new : exn -> key -> 'a -> 'a t -> 'a t
val replace : exn -> key -> 'a -> 'a t -> 'a t
val keys : 'a t -> key list
val values : 'a t -> 'a list
val of_list : (key * 'a) list -> 'a t
val contains : 'a t -> key -> bool
val domain : 'a t -> unit t
val subdomain : (key -> 'a -> bool) -> 'a t -> unit t
val is_num_elt : int -> 'a t -> bool
type 'a enumeration
val val_enum : 'a enumeration -> (key * 'a) option
val start_enum : 'a t -> 'a enumeration
val next_enum : 'a enumeration -> 'a enumeration
val start_ge_enum : key -> 'a t -> 'a enumeration
val next_ge_enum : key -> 'a enumeration -> 'a enumeration
end
end