|
|
|
(*
|
|
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
|
|
|
*)
|
|
|
|
|
|
|
|
open! NS0
|
|
|
|
|
|
|
|
module type S = sig
|
|
|
|
type elt
|
|
|
|
type compare_elt
|
|
|
|
type t [@@deriving compare, equal, sexp_of]
|
|
|
|
|
|
|
|
include Comparer.S with type t := t
|
|
|
|
|
|
|
|
module Provide_hash (_ : sig
|
|
|
|
type t = elt [@@deriving hash]
|
|
|
|
end) : sig
|
|
|
|
type t [@@deriving hash]
|
|
|
|
end
|
|
|
|
with type t := t
|
|
|
|
|
|
|
|
module Provide_of_sexp (_ : sig
|
|
|
|
type t = elt [@@deriving of_sexp]
|
|
|
|
end) : sig
|
|
|
|
type t [@@deriving of_sexp]
|
|
|
|
end
|
|
|
|
with type t := t
|
|
|
|
|
|
|
|
(** {1 Pretty-print} *)
|
|
|
|
|
|
|
|
val pp_full :
|
|
|
|
?pre:(unit, unit) fmt
|
|
|
|
-> ?suf:(unit, unit) fmt
|
|
|
|
-> ?sep:(unit, unit) fmt
|
|
|
|
-> elt pp
|
|
|
|
-> t pp
|
|
|
|
|
|
|
|
module Provide_pp (_ : sig
|
|
|
|
type t = elt
|
|
|
|
|
|
|
|
val pp : t pp
|
|
|
|
end) : sig
|
|
|
|
val pp : t pp
|
|
|
|
val pp_diff : (t * t) pp
|
|
|
|
end
|
|
|
|
|
|
|
|
(** {1 Construct} *)
|
|
|
|
|
|
|
|
val empty : t
|
|
|
|
val of_ : elt -> t
|
|
|
|
val of_option : elt option -> t
|
|
|
|
val of_list : elt list -> t
|
|
|
|
val add : elt -> t -> t
|
|
|
|
val add_option : elt option -> t -> t
|
|
|
|
val add_list : elt list -> t -> t
|
|
|
|
val remove : elt -> t -> t
|
|
|
|
val diff : t -> t -> t
|
|
|
|
val inter : t -> t -> t
|
|
|
|
val union : t -> t -> t
|
|
|
|
val diff_inter : t -> t -> t * t
|
|
|
|
val diff_inter_diff : t -> t -> t * t * t
|
|
|
|
val union_list : t list -> t
|
|
|
|
|
|
|
|
(** {1 Query} *)
|
|
|
|
|
|
|
|
val is_empty : t -> bool
|
|
|
|
val cardinal : t -> int
|
|
|
|
val mem : elt -> t -> bool
|
|
|
|
val subset : t -> of_:t -> bool
|
|
|
|
val disjoint : t -> t -> bool
|
|
|
|
val max_elt : t -> elt option
|
|
|
|
val only_elt : t -> elt option
|
|
|
|
val classify : t -> elt zero_one_many
|
|
|
|
|
|
|
|
val choose : t -> elt option
|
|
|
|
(** Find an unspecified element. Different elements may be chosen for
|
|
|
|
equivalent sets. [O(1)]. *)
|
|
|
|
|
|
|
|
val choose_exn : t -> elt
|
|
|
|
(** Find an unspecified element. Different elements may be chosen for
|
|
|
|
equivalent sets. [O(1)]. *)
|
|
|
|
|
|
|
|
val pop : t -> (elt * t) option
|
|
|
|
(** Find and remove an unspecified element. [O(1)]. *)
|
|
|
|
|
|
|
|
val pop_exn : t -> elt * t
|
|
|
|
(** Find and remove an unspecified element. [O(1)]. *)
|
|
|
|
|
|
|
|
(** {1 Transform} *)
|
|
|
|
|
|
|
|
val map : t -> f:(elt -> elt) -> t
|
|
|
|
val flat_map : t -> f:(elt -> t) -> t
|
|
|
|
val filter : t -> f:(elt -> bool) -> t
|
|
|
|
val partition : t -> f:(elt -> bool) -> t * t
|
|
|
|
|
|
|
|
(** {1 Traverse} *)
|
|
|
|
|
|
|
|
val iter : t -> f:(elt -> unit) -> unit
|
|
|
|
val exists : t -> f:(elt -> bool) -> bool
|
|
|
|
val for_all : t -> f:(elt -> bool) -> bool
|
|
|
|
val fold : t -> 's -> f:(elt -> 's -> 's) -> 's
|
|
|
|
val reduce : t -> f:(elt -> elt -> elt) -> elt option
|
|
|
|
|
|
|
|
(** {1 Convert} *)
|
|
|
|
|
|
|
|
val to_list : t -> elt list
|
|
|
|
val to_iter : t -> elt iter
|
|
|
|
val of_iter : elt iter -> t
|
|
|
|
end
|