Module List0.Assoc

include Assoc
type ('a, 'b) t = ('a * 'b) list
include Base.Sexpable.S2 with type ('a, 'b) t := ('a'b) t
type ('a, 'b) t
val t_of_sexp : (Sexplib0.Sexp.t -> 'a) -> (Sexplib0.Sexp.t -> 'b) -> Sexplib0.Sexp.t -> ('a'b) t
val sexp_of_t : ('a -> Sexplib0.Sexp.t) -> ('b -> Sexplib0.Sexp.t) -> ('a'b) t -> Sexplib0.Sexp.t
val add : ('a'b) t -> equal:('a -> 'a -> bool) -> 'a -> 'b -> ('a'b) t
val find : ('a'b) t -> equal:('a -> 'a -> bool) -> 'a -> 'b option
val find_exn : ('a'b) t -> equal:('a -> 'a -> bool) -> 'a -> 'b
val mem : ('a'b) t -> equal:('a -> 'a -> bool) -> 'a -> bool
val remove : ('a'b) t -> equal:('a -> 'a -> bool) -> 'a -> ('a'b) t
val map : ('a'b) t -> f:('b -> 'c) -> ('a'c) t
val inverse : ('a'b) t -> ('b'a) t

Bijectivity is not guaranteed because we allow a key to appear more than once.

type ('a, 'b) t = ('a * 'b) Core_kernel__.Import.list
val compare : ('a -> 'a -> Core_kernel__.Import.int) -> ('b -> 'b -> Core_kernel__.Import.int) -> ('a * 'b) Core_kernel__.Import.list -> ('a * 'b) Core_kernel__.Import.list -> Core_kernel__.Import.int