sig
type 'a t
val empty : 'a Common.Set.t
val singleton : 'a -> 'a Common.Set.t
val union : 'a Common.Set.t -> 'a Common.Set.t -> 'a Common.Set.t
val inter : 'a Common.Set.t -> 'a Common.Set.t -> 'a Common.Set.t
val diff : 'a Common.Set.t -> 'a Common.Set.t -> 'a Common.Set.t
val mem : 'a -> 'a Common.Set.t -> bool
val is_empty : 'a Common.Set.t -> bool
val subset : 'a Common.Set.t -> 'a Common.Set.t -> bool
val rem : 'a -> 'a Common.Set.t -> 'a Common.Set.t
val add : 'a -> 'a Common.Set.t -> 'a Common.Set.t
val map : ('a -> 'b) -> 'a Common.Set.t -> 'b Common.Set.t
val iter : ('a -> unit) -> 'a Common.Set.t -> unit
val fold : ('a -> 'b -> 'b) -> 'a Common.Set.t -> 'b -> 'b
val filter : ('a -> bool) -> 'a Common.Set.t -> 'a Common.Set.t
val exists : ('a -> bool) -> 'a Common.Set.t -> bool
val for_all : ('a -> bool) -> 'a Common.Set.t -> bool
val cardinal : 'a Common.Set.t -> int
val print :
?sep:string -> 'a Common.formatter -> 'a Common.Set.t Common.formatter
end