sig
  type 'a t
  val empty : 'Main.Type.UMap.t
  val is_empty : 'Main.Type.UMap.t -> bool
  val add :
    ?eq:('-> '-> bool) ->
    Main.Type.UChar.t -> '-> 'Main.Type.UMap.t -> 'Main.Type.UMap.t
  val add_range :
    ?eq:('-> '-> bool) ->
    Main.Type.UChar.t ->
    Main.Type.UChar.t -> '-> 'Main.Type.UMap.t -> 'Main.Type.UMap.t
  val find : Main.Type.UChar.t -> 'Main.Type.UMap.t -> 'a
  val remove :
    Main.Type.UChar.t -> 'Main.Type.UMap.t -> 'Main.Type.UMap.t
  val remove_range :
    Main.Type.UChar.t ->
    Main.Type.UChar.t -> 'Main.Type.UMap.t -> 'Main.Type.UMap.t
  val from : Main.Type.UChar.t -> 'Main.Type.UMap.t -> 'Main.Type.UMap.t
  val after : Main.Type.UChar.t -> 'Main.Type.UMap.t -> 'Main.Type.UMap.t
  val until : Main.Type.UChar.t -> 'Main.Type.UMap.t -> 'Main.Type.UMap.t
  val before :
    Main.Type.UChar.t -> 'Main.Type.UMap.t -> 'Main.Type.UMap.t
  val mem : Main.Type.UChar.t -> 'Main.Type.UMap.t -> bool
  val iter : (Main.Type.UChar.t -> '-> unit) -> 'Main.Type.UMap.t -> unit
  val iter_range :
    (Main.Type.UChar.t -> Main.Type.UChar.t -> '-> unit) ->
    'Main.Type.UMap.t -> unit
  val map :
    ?eq:('-> '-> bool) ->
    ('-> 'a) -> 'Main.Type.UMap.t -> 'Main.Type.UMap.t
  val mapi :
    ?eq:('-> '-> bool) ->
    (Main.Type.UChar.t -> '-> 'a) ->
    'Main.Type.UMap.t -> 'Main.Type.UMap.t
  val fold :
    (Main.Type.UChar.t -> '-> '-> 'b) -> 'Main.Type.UMap.t -> '-> 'b
  val fold_range :
    (Main.Type.UChar.t -> Main.Type.UChar.t -> '-> '-> 'b) ->
    'Main.Type.UMap.t -> '-> 'b
  val set_to_map : Main.Type.USet.t -> '-> 'Main.Type.UMap.t
  val domain : 'Main.Type.UMap.t -> Main.Type.USet.t
  val map_to_set : ('-> bool) -> 'Main.Type.UMap.t -> Main.Type.USet.t
  val umap_of_imap : 'Main.Type.IMap.t -> 'Main.Type.UMap.t
  val imap_of_umap : 'Main.Type.UMap.t -> 'Main.Type.IMap.t
end