sig
  type key = class_name
  type 'a t
  val empty : 'a t
  val is_empty : 'a t -> bool
  val add : key -> '-> 'a t -> 'a t
  val cardinal : 'a t -> int
  val modify : key -> ('a option -> 'a) -> 'a t -> 'a t
  val find : key -> 'a t -> 'a
  val remove : key -> 'a t -> 'a t
  val mem : key -> 'a t -> bool
  val iter : (key -> '-> unit) -> 'a t -> unit
  val map : ('-> 'b) -> 'a t -> 'b t
  val mapi : (key -> '-> 'b) -> 'a t -> 'b t
  val fold : (key -> '-> '-> 'b) -> 'a t -> '-> 'b
  val compare : ('-> '-> int) -> 'a t -> 'a t -> int
  val equal : ('-> '-> bool) -> 'a t -> 'a t -> bool
  val merge : ('-> '-> 'a) -> 'a t -> 'a t -> 'a t
  val choose_and_remove : 'a t -> key * 'a * 'a t
  val filter : ('-> bool) -> 'a t -> 'a t
  val filteri : (key -> '-> bool) -> 'a t -> 'a t
  val key_elements : 'a t -> key list
  val value_elements : 'a t -> 'a list
  val elements : 'a t -> (key * 'a) list
  val subset : ('-> '-> bool) -> 'a t -> 'a t -> bool
end