sig
type 'a t
val sexp_of_t :
('a -> Sexplib.Sexp.t) -> 'a Interval_intf.S1.t -> Sexplib.Sexp.t
val t_of_sexp :
(Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a Interval_intf.S1.t
val bin_size_t :
'a Bin_prot.Size.sizer -> 'a Interval_intf.S1.t Bin_prot.Size.sizer
val bin_write_t :
'a Bin_prot.Unsafe_write_c.writer ->
'a Interval_intf.S1.t Bin_prot.Write_ml.writer
val bin_write_t_ :
'a Bin_prot.Unsafe_write_c.writer ->
'a Interval_intf.S1.t Bin_prot.Unsafe_write_c.writer
val bin_writer_t :
'a Bin_prot.Type_class.writer ->
'a Interval_intf.S1.t Bin_prot.Type_class.writer
val bin_read_t :
'a Bin_prot.Unsafe_read_c.reader ->
'a Interval_intf.S1.t Bin_prot.Read_ml.reader
val bin_read_t_ :
'a Bin_prot.Unsafe_read_c.reader ->
'a Interval_intf.S1.t Bin_prot.Unsafe_read_c.reader
val bin_read_t__ :
'a Bin_prot.Unsafe_read_c.reader ->
(int -> 'a Interval_intf.S1.t) Bin_prot.Unsafe_read_c.reader
val bin_reader_t :
'a Bin_prot.Type_class.reader ->
'a Interval_intf.S1.t Bin_prot.Type_class.reader
val bin_t :
'a Bin_prot.Type_class.t -> 'a Interval_intf.S1.t Bin_prot.Type_class.t
type 'a interval = 'a Interval_intf.S1.t
module T : sig type 'a bound = 'a type 'a t = 'a 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
module Set :
sig
type 'a t
val sexp_of_t :
('a -> Sexplib.Sexp.t) -> 'a Interval_intf.S1.Set.t -> Sexplib.Sexp.t
val t_of_sexp :
(Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a Interval_intf.S1.Set.t
val bin_size_t :
'a Bin_prot.Size.sizer ->
'a Interval_intf.S1.Set.t Bin_prot.Size.sizer
val bin_write_t :
'a Bin_prot.Unsafe_write_c.writer ->
'a Interval_intf.S1.Set.t Bin_prot.Write_ml.writer
val bin_write_t_ :
'a Bin_prot.Unsafe_write_c.writer ->
'a Interval_intf.S1.Set.t Bin_prot.Unsafe_write_c.writer
val bin_writer_t :
'a Bin_prot.Type_class.writer ->
'a Interval_intf.S1.Set.t Bin_prot.Type_class.writer
val bin_read_t :
'a Bin_prot.Unsafe_read_c.reader ->
'a Interval_intf.S1.Set.t Bin_prot.Read_ml.reader
val bin_read_t_ :
'a Bin_prot.Unsafe_read_c.reader ->
'a Interval_intf.S1.Set.t Bin_prot.Unsafe_read_c.reader
val bin_read_t__ :
'a Bin_prot.Unsafe_read_c.reader ->
(int -> 'a Interval_intf.S1.Set.t) Bin_prot.Unsafe_read_c.reader
val bin_reader_t :
'a Bin_prot.Type_class.reader ->
'a Interval_intf.S1.Set.t Bin_prot.Type_class.reader
val bin_t :
'a Bin_prot.Type_class.t ->
'a Interval_intf.S1.Set.t Bin_prot.Type_class.t
module T :
sig
type 'a t = 'a t
type 'a bound = 'a
type 'a interval = 'a 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
end
end