(* User Modes: +i Invisible User Mode +o Oper User Mode +w WALLOPS User Mode Channel Modes: Type A: +b Ban Channel Mode Type B: +k Key Channel Mode +o Operator Channel Membership Prefix (@) +v Voice Channel Membership Prefix (+) Type C: +l Client Limit Channel Mode Type D: +i Invite-Only Channel Mode +m Moderated Channel Mode +n No External Messages Mode +s Secret Channel Mode +t Protected Topic Channel Mode *) type user = [`i | `o | `w] type chan_a = [`b] type chan_b = [`k | `o | `v] type chan_c = [`l] type chan_d = [`i | `m | `s | `t | `n] type chan = [chan_a | chan_b | chan_c | chan_d] type t = [user | chan] val pp : Format.formatter -> [< t] -> unit val to_char : [< t] -> char val of_char_user : char -> [> user] val of_char_chan : char -> [> chan] module Set : sig type t type elt = [user | chan_d] val empty : t val singleton : [< elt] -> t val mem : [< elt] -> t -> bool val add : [< elt] -> t -> t val remove : [< elt] -> t -> t val union : t -> t -> t val inter : t -> t -> t val diff : t -> t -> t val equal : t -> t -> bool val pp : Format.formatter -> t -> unit val to_string : t -> string val of_string : string -> t val of_list : [< elt] list -> t (* val to_list : t -> elt list *) type change = { add : t; rem : t; } val pp_change : Format.formatter -> change -> unit val no_change : change val normalize : t -> change -> t * change end module Parse : sig exception Error type user_modes = Set.change type 'a set_or_unset = [ | `set of 'a | `unset ] type chan_modes = { chan_modes : Set.change; chan_key : string set_or_unset option; chan_limit : int set_or_unset option; (* TODO: ban, op, voice *) } val user_modes : string -> user_modes val chan_modes : string -> string list -> chan_modes end