sig
  type ('a, 'b) t = ('a, 'b) MoreLabels.Hashtbl.t
  val add : ('a, 'b) Core_hashtbl.t -> key:'-> data:'-> unit
  val clear : ('a, 'b) Core_hashtbl.t -> unit
  val copy : ('a, 'b) Core_hashtbl.t -> ('a, 'b) Core_hashtbl.t
  val create : int -> ('a, 'b) Core_hashtbl.t
  val find_all : ('a, 'b) Core_hashtbl.t -> '-> 'b list
  val fold :
    f:(key:'-> data:'-> '-> 'c) ->
    ('a, 'b) Core_hashtbl.t -> init:'-> 'c
  val iter : f:(key:'-> data:'-> unit) -> ('a, 'b) Core_hashtbl.t -> unit
  val length : ('a, 'b) Core_hashtbl.t -> int
  val mem : ('a, 'b) Core_hashtbl.t -> '-> bool
  val remove : ('a, 'b) Core_hashtbl.t -> '-> unit
  val replace : ('a, 'b) Core_hashtbl.t -> key:'-> data:'-> unit
  val find_default :
    ('a, 'b) Core_hashtbl.t -> '-> default:(unit -> 'b) -> 'b
  val find : ('a, 'b) Core_hashtbl.t -> '-> 'b option
  val find_exn : ('a, 'b) Core_hashtbl.t -> '-> 'b
  val iter_vals : f:('-> unit) -> ('b, 'a) Core_hashtbl.t -> unit
  val of_alist : ('a * 'b) list -> ('a, 'b) Core_hashtbl.t
  val to_alist : ('a, 'b) Core_hashtbl.t -> ('a * 'b) list
  val keys : ('a, 'b) Core_hashtbl.t -> 'a list
  val data : ('a, 'b) Core_hashtbl.t -> 'b list
  val sexp_of_t :
    ('-> Sexplib.Sexp.t) ->
    ('-> Sexplib.Sexp.t) -> ('a, 'b) Core_hashtbl.t -> Sexplib.Sexp.t
  val t_of_sexp :
    (Sexplib.Sexp.t -> 'a) ->
    (Sexplib.Sexp.t -> 'b) -> Sexplib.Sexp.t -> ('a, 'b) Core_hashtbl.t
  module Infix :
    sig
      val ( |> ) : ('a, 'b) Core_hashtbl.t -> '-> 'b
      val ( |?> ) : ('a, 'b) Core_hashtbl.t -> '-> 'b option
      val ( <| ) : ('a, 'b) Core_hashtbl.t -> 'a * '-> unit
    end
  module type HashedType =
    sig
      type t
      val equal : t -> t -> bool
      val hash : t -> int
      val sexp_of_t : Core_hashtbl.t -> Sexplib.Sexp.t
      val t_of_sexp : Sexplib.Sexp.t -> Core_hashtbl.t
    end
  module type S =
    sig
      type key
      type 'a t
      val create : int -> 'Core_hashtbl.S.t
      val clear : 'Core_hashtbl.S.t -> unit
      val copy : 'Core_hashtbl.S.t -> 'Core_hashtbl.S.t
      val add :
        'Core_hashtbl.S.t -> key:Core_hashtbl.S.key -> data:'-> unit
      val remove : 'Core_hashtbl.S.t -> Core_hashtbl.S.key -> unit
      val find_all : 'Core_hashtbl.S.t -> Core_hashtbl.S.key -> 'a list
      val replace :
        'Core_hashtbl.S.t -> key:Core_hashtbl.S.key -> data:'-> unit
      val mem : 'Core_hashtbl.S.t -> Core_hashtbl.S.key -> bool
      val iter :
        f:(key:Core_hashtbl.S.key -> data:'-> unit) ->
        'Core_hashtbl.S.t -> unit
      val fold :
        f:(key:Core_hashtbl.S.key -> data:'-> '-> 'b) ->
        'Core_hashtbl.S.t -> init:'-> 'b
      val length : 'Core_hashtbl.S.t -> int
      val find_default :
        'Core_hashtbl.S.t ->
        Core_hashtbl.S.key -> default:(unit -> 'a) -> 'a
      val find : 'Core_hashtbl.S.t -> Core_hashtbl.S.key -> 'a option
      val find_exn : 'Core_hashtbl.S.t -> Core_hashtbl.S.key -> 'a
      val iter_vals : f:('-> unit) -> 'Core_hashtbl.S.t -> unit
      val of_alist : (Core_hashtbl.S.key * 'a) list -> 'Core_hashtbl.S.t
      val to_alist : 'Core_hashtbl.S.t -> (Core_hashtbl.S.key * 'a) list
      val keys : 'Core_hashtbl.S.t -> Core_hashtbl.S.key list
      val data : 'Core_hashtbl.S.t -> 'a list
      val sexp_of_t :
        ('-> Sexplib.Sexp.t) -> 'Core_hashtbl.S.t -> Sexplib.Sexp.t
      val t_of_sexp :
        (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'Core_hashtbl.S.t
      module Infix :
        sig
          val ( |> ) : 'Core_hashtbl.S.t -> Core_hashtbl.S.key -> 'a
          val ( |?> ) :
            'Core_hashtbl.S.t -> Core_hashtbl.S.key -> 'a option
          val ( <| ) : 'Core_hashtbl.S.t -> Core_hashtbl.S.key * '-> unit
        end
    end
  module Make :
    functor (H : HashedType->
      sig
        type key = H.t
        type 'a t
        val create : int -> 'a t
        val clear : 'a t -> unit
        val copy : 'a t -> 'a t
        val add : 'a t -> key:key -> data:'-> unit
        val remove : 'a t -> key -> unit
        val find_all : 'a t -> key -> 'a list
        val replace : 'a t -> key:key -> data:'-> unit
        val mem : 'a t -> key -> bool
        val iter : f:(key:key -> data:'-> unit) -> 'a t -> unit
        val fold :
          f:(key:key -> data:'-> '-> 'b) -> 'a t -> init:'-> 'b
        val length : 'a t -> int
        val find_default : 'a t -> key -> default:(unit -> 'a) -> 'a
        val find : 'a t -> key -> 'a option
        val find_exn : 'a t -> key -> 'a
        val iter_vals : f:('-> unit) -> 'a t -> unit
        val of_alist : (key * 'a) list -> 'a t
        val to_alist : 'a t -> (key * 'a) list
        val keys : 'a t -> key list
        val data : 'a t -> 'a list
        val sexp_of_t : ('-> Sexplib.Sexp.t) -> 'a t -> Sexplib.Sexp.t
        val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a t
        module Infix :
          sig
            val ( |> ) : 'a t -> key -> 'a
            val ( |?> ) : 'a t -> key -> 'a option
            val ( <| ) : 'a t -> key * '-> unit
          end
      end
  val hash : '-> int
  val hash_param : int -> int -> '-> int
end