sig
  type in_value
  type out_value
  type 'key t = private ('key, Fold_map.S.out_value) Core.Std.Map.Poly.t
  type 'a _in_value = Fold_map.S.in_value
  type 'a _out_value = Fold_map.S.out_value
  type ('a, 'b) _t = 'Fold_map.S.t
  val empty : 'Fold_map.S.t
  val singleton : '-> Fold_map.S.in_value -> 'Fold_map.S.t
  val is_empty : 'Fold_map.S.t -> bool
  val length : 'Fold_map.S.t -> int
  val add :
    key:'-> data:Fold_map.S.in_value -> 'Fold_map.S.t -> 'Fold_map.S.t
  val find : 'Fold_map.S.t -> '-> Fold_map.S.out_value
  val remove : 'Fold_map.S.t -> '-> 'Fold_map.S.t
  val set :
    key:'-> data:Fold_map.S.out_value -> 'Fold_map.S.t -> 'Fold_map.S.t
  val mem : 'Fold_map.S.t -> '-> bool
  val iter :
    'Fold_map.S.t ->
    f:(key:'-> data:Fold_map.S.out_value -> unit) -> unit
  val fold :
    'Fold_map.S.t ->
    init:'-> f:(key:'-> data:Fold_map.S.out_value -> '-> 'b) -> 'b
  val filter :
    'Fold_map.S.t ->
    f:(key:'-> data:Fold_map.S.out_value -> bool) -> 'Fold_map.S.t
  val keys : 'Fold_map.S.t -> 'a list
  val data : 'Fold_map.S.t -> Fold_map.S.out_value list
  val to_alist : 'Fold_map.S.t -> ('a * Fold_map.S.out_value) list
  val of_list : ('a * Fold_map.S.in_value) list -> 'Fold_map.S.t
  val for_all : 'Fold_map.S.t -> f:(Fold_map.S.out_value -> bool) -> bool
  val exists : 'Fold_map.S.t -> f:(Fold_map.S.out_value -> bool) -> bool
  val to_map :
    'Fold_map.S.t -> ('a, Fold_map.S.out_value) Core.Std.Map.Poly.t
  val of_map :
    ('a, Fold_map.S.out_value) Core.Std.Map.Poly.t -> 'Fold_map.S.t
end