functor
  (Elt : sig
           type t
           type sexpable = t
           val sexp_of_t : sexpable -> Sexplib.Sexp.t
           val t_of_sexp : Sexplib.Sexp.t -> sexpable
           val compare : t -> t -> int
           type binable = t
           val bin_size_t : binable Bin_prot.Size.sizer
           val bin_write_t : binable Bin_prot.Map_to_safe.writer
           val bin_write_t_ : binable Bin_prot.Unsafe_write_c.writer
           val bin_read_t : binable Bin_prot.Read_ml.reader
           val bin_read_t_ : binable Bin_prot.Unsafe_read_c.reader
           val bin_read_t__ : (int -> binable) Bin_prot.Unsafe_read_c.reader
           val bin_writer_t : binable Bin_prot.Type_class.writer
           val bin_reader_t : binable Bin_prot.Type_class.reader
           val bin_t : binable Bin_prot.Type_class.t
         end->
  sig
    type elt = Elt.t
    type t
    module T : sig type 'a elt = elt type 'a t = t end
    type sexpable = t
    val sexp_of_t : sexpable -> Sexplib.Sexp.t
    val t_of_sexp : Sexplib.Sexp.t -> sexpable
    val empty : t
    val is_empty : t -> bool
    val mem : t -> elt -> bool
    val add : t -> elt -> t
    val singleton : elt -> t
    val remove : t -> elt -> t
    val union : t -> t -> t
    val union_list : t list -> t
    val inter : t -> t -> t
    val diff : t -> t -> t
    val compare : t -> t -> int
    val equal : t -> t -> bool
    val subset : t -> t -> bool
    val iter : t -> f:(elt -> unit) -> unit
    val fold : t -> init:'-> f:(elt -> '-> 'a) -> 'a
    val fold_until :
      t ->
      init:'-> f:(elt -> '-> [ `Continue of '| `Stop of 'a ]) -> 'a
    val for_all : t -> f:(elt -> bool) -> bool
    val exists : t -> f:(elt -> bool) -> bool
    val filter : t -> f:(elt -> bool) -> t
    val partition : t -> f:(elt -> bool) -> t * t
    val cardinal : t -> int
    val length : t -> int
    val elements : t -> elt list
    val min_elt : t -> elt option
    val min_elt_exn : t -> elt
    val max_elt : t -> elt option
    val max_elt_exn : t -> elt
    val choose : t -> elt option
    val choose_exn : t -> elt
    val of_list : elt list -> t
    val to_list : t -> elt list
    val of_array : elt array -> t
    val to_array : t -> elt array
    val split : elt -> t -> t * bool * t
    val group_by : t -> equiv:(elt -> elt -> bool) -> t list
    val find : t -> f:(elt -> bool) -> elt option
    val find_exn : t -> f:(elt -> bool) -> elt
    val find_index : t -> int -> elt option
    val remove_index : t -> int -> t
    type binable = t
    val bin_size_t : binable Bin_prot.Size.sizer
    val bin_write_t : binable Bin_prot.Map_to_safe.writer
    val bin_write_t_ : binable Bin_prot.Unsafe_write_c.writer
    val bin_read_t : binable Bin_prot.Read_ml.reader
    val bin_read_t_ : binable Bin_prot.Unsafe_read_c.reader
    val bin_read_t__ : (int -> binable) Bin_prot.Unsafe_read_c.reader
    val bin_writer_t : binable Bin_prot.Type_class.writer
    val bin_reader_t : binable Bin_prot.Type_class.reader
    val bin_t : binable Bin_prot.Type_class.t
  end