sig
type t
val sexp_of_t : Interval_intf.S.t -> Sexplib.Sexp.t
val t_of_sexp : Sexplib.Sexp.t -> Interval_intf.S.t
val bin_size_t : Interval_intf.S.t Bin_prot.Size.sizer
val bin_write_t : Interval_intf.S.t Bin_prot.Write_ml.writer
val bin_write_t_ : Interval_intf.S.t Bin_prot.Unsafe_write_c.writer
val bin_writer_t : Interval_intf.S.t Bin_prot.Type_class.writer
val bin_read_t : Interval_intf.S.t Bin_prot.Read_ml.reader
val bin_read_t_ : Interval_intf.S.t Bin_prot.Unsafe_read_c.reader
val bin_read_t__ : (int -> Interval_intf.S.t) Bin_prot.Unsafe_read_c.reader
val bin_reader_t : Interval_intf.S.t Bin_prot.Type_class.reader
val bin_t : Interval_intf.S.t Bin_prot.Type_class.t
type 'a poly_t
val sexp_of_poly_t :
('a -> Sexplib.Sexp.t) -> 'a Interval_intf.S.poly_t -> Sexplib.Sexp.t
val poly_t_of_sexp :
(Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a Interval_intf.S.poly_t
val bin_size_poly_t :
'a Bin_prot.Size.sizer -> 'a Interval_intf.S.poly_t Bin_prot.Size.sizer
val bin_write_poly_t :
'a Bin_prot.Unsafe_write_c.writer ->
'a Interval_intf.S.poly_t Bin_prot.Write_ml.writer
val bin_write_poly_t_ :
'a Bin_prot.Unsafe_write_c.writer ->
'a Interval_intf.S.poly_t Bin_prot.Unsafe_write_c.writer
val bin_writer_poly_t :
'a Bin_prot.Type_class.writer ->
'a Interval_intf.S.poly_t Bin_prot.Type_class.writer
val bin_read_poly_t :
'a Bin_prot.Unsafe_read_c.reader ->
'a Interval_intf.S.poly_t Bin_prot.Read_ml.reader
val bin_read_poly_t_ :
'a Bin_prot.Unsafe_read_c.reader ->
'a Interval_intf.S.poly_t Bin_prot.Unsafe_read_c.reader
val bin_read_poly_t__ :
'a Bin_prot.Unsafe_read_c.reader ->
(int -> 'a Interval_intf.S.poly_t) Bin_prot.Unsafe_read_c.reader
val bin_reader_poly_t :
'a Bin_prot.Type_class.reader ->
'a Interval_intf.S.poly_t Bin_prot.Type_class.reader
val bin_poly_t :
'a Bin_prot.Type_class.t ->
'a Interval_intf.S.poly_t Bin_prot.Type_class.t
type interval = Interval_intf.S.t
type bound
module T : sig type 'a bound = bound type 'a t = t end
val create : 'a T.bound -> 'a T.bound -> 'a T.t
val empty : 'a T.t
val intersect : 'a T.t -> 'a T.t -> 'a T.t
val is_empty : 'a T.t -> bool
val is_empty_or_singleton : 'a T.t -> bool
val bounds : 'a T.t -> ('a T.bound * 'a T.bound) option
val lbound : 'a T.t -> 'a T.bound option
val ubound : 'a T.t -> 'a T.bound option
val bounds_exn : 'a T.t -> 'a T.bound * 'a T.bound
val lbound_exn : 'a T.t -> 'a T.bound
val ubound_exn : 'a T.t -> 'a T.bound
val contains : 'a T.t -> 'a T.bound -> bool
val compare_value :
'a T.t ->
'a T.bound -> [ `Above | `Below | `Interval_is_empty | `Within ]
val bound : 'a T.t -> 'a T.bound -> 'a T.bound option
val is_superset : 'a T.t -> of_:'a T.t -> bool
val is_subset : 'a T.t -> of_:'a T.t -> bool
val map : f:('a T.bound -> 'b T.bound) -> 'a T.t -> 'b T.t
val are_disjoint : 'a T.t list -> bool
val are_disjoint_as_open_intervals : 'a T.t list -> bool
val list_intersect : 'a T.t list -> 'a T.t list -> 'a T.t list
val half_open_intervals_are_a_partition : 'a T.t list -> bool
val to_poly :
Interval_intf.S.t -> Interval_intf.S.bound Interval_intf.S.poly_t
module Set :
sig
type t
val sexp_of_t : Interval_intf.S.Set.t -> Sexplib.Sexp.t
val t_of_sexp : Sexplib.Sexp.t -> Interval_intf.S.Set.t
val bin_size_t : Interval_intf.S.Set.t Bin_prot.Size.sizer
val bin_write_t : Interval_intf.S.Set.t Bin_prot.Write_ml.writer
val bin_write_t_ : Interval_intf.S.Set.t Bin_prot.Unsafe_write_c.writer
val bin_writer_t : Interval_intf.S.Set.t Bin_prot.Type_class.writer
val bin_read_t : Interval_intf.S.Set.t Bin_prot.Read_ml.reader
val bin_read_t_ : Interval_intf.S.Set.t Bin_prot.Unsafe_read_c.reader
val bin_read_t__ :
(int -> Interval_intf.S.Set.t) Bin_prot.Unsafe_read_c.reader
val bin_reader_t : Interval_intf.S.Set.t Bin_prot.Type_class.reader
val bin_t : Interval_intf.S.Set.t Bin_prot.Type_class.t
type 'a poly_t
val sexp_of_poly_t :
('a -> Sexplib.Sexp.t) ->
'a Interval_intf.S.Set.poly_t -> Sexplib.Sexp.t
val poly_t_of_sexp :
(Sexplib.Sexp.t -> 'a) ->
Sexplib.Sexp.t -> 'a Interval_intf.S.Set.poly_t
val bin_size_poly_t :
'a Bin_prot.Size.sizer ->
'a Interval_intf.S.Set.poly_t Bin_prot.Size.sizer
val bin_write_poly_t :
'a Bin_prot.Unsafe_write_c.writer ->
'a Interval_intf.S.Set.poly_t Bin_prot.Write_ml.writer
val bin_write_poly_t_ :
'a Bin_prot.Unsafe_write_c.writer ->
'a Interval_intf.S.Set.poly_t Bin_prot.Unsafe_write_c.writer
val bin_writer_poly_t :
'a Bin_prot.Type_class.writer ->
'a Interval_intf.S.Set.poly_t Bin_prot.Type_class.writer
val bin_read_poly_t :
'a Bin_prot.Unsafe_read_c.reader ->
'a Interval_intf.S.Set.poly_t Bin_prot.Read_ml.reader
val bin_read_poly_t_ :
'a Bin_prot.Unsafe_read_c.reader ->
'a Interval_intf.S.Set.poly_t Bin_prot.Unsafe_read_c.reader
val bin_read_poly_t__ :
'a Bin_prot.Unsafe_read_c.reader ->
(int -> 'a Interval_intf.S.Set.poly_t) Bin_prot.Unsafe_read_c.reader
val bin_reader_poly_t :
'a Bin_prot.Type_class.reader ->
'a Interval_intf.S.Set.poly_t Bin_prot.Type_class.reader
val bin_poly_t :
'a Bin_prot.Type_class.t ->
'a Interval_intf.S.Set.poly_t Bin_prot.Type_class.t
module T :
sig
type 'a t = t
type 'a bound = bound
type 'a interval = interval
end
val create : ('a T.bound * 'a T.bound) list -> 'a T.t
val create_from_intervals : 'a T.interval list -> 'a T.t
val contains : 'a T.t -> 'a T.bound -> bool
val contains_set : container:'a T.t -> contained:'a T.t -> bool
val ubound_exn : 'a T.t -> 'a T.bound
val lbound_exn : 'a T.t -> 'a T.bound
val ubound : 'a T.t -> 'a T.bound option
val lbound : 'a T.t -> 'a T.bound option
val to_poly :
Interval_intf.S.Set.t ->
Interval_intf.S.bound Interval_intf.S.Set.poly_t
end
end