Module List0.Assoc
include Assoc
include Base.Sexpable.S2 with type ('a, 'b) t := ('a, 'b) t
val t_of_sexp : (Base.Sexp.t -> 'a) -> (Base.Sexp.t -> 'b) -> Base.Sexp.t -> ('a, 'b) t
val sexp_of_t : ('a -> Base.Sexp.t) -> ('b -> Base.Sexp.t) -> ('a, 'b) t -> Base.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 bin_shape_t : Bin_prot.Shape.t -> Bin_prot.Shape.t -> Bin_prot.Shape.t
val bin_size_t : a b. 'a Bin_prot.Size.sizer -> 'b Bin_prot.Size.sizer -> ('a, 'b) t Bin_prot.Size.sizer
val bin_write_t : a b. 'a Bin_prot.Write.writer -> 'b Bin_prot.Write.writer -> ('a, 'b) t Bin_prot.Write.writer
val bin_writer_t : 'a Bin_prot.Type_class.writer -> 'b Bin_prot.Type_class.writer -> ('a, 'b) t Bin_prot.Type_class.writer
val __bin_read_t__ : a b. 'a Bin_prot.Read.reader -> 'b Bin_prot.Read.reader -> (Core_kernel__.Import.int -> ('a, 'b) t) Bin_prot.Read.reader
val bin_read_t : a b. 'a Bin_prot.Read.reader -> 'b Bin_prot.Read.reader -> ('a, 'b) t Bin_prot.Read.reader
val bin_reader_t : 'a Bin_prot.Type_class.reader -> 'b Bin_prot.Type_class.reader -> ('a, 'b) t Bin_prot.Type_class.reader
val bin_t : 'a Bin_prot.Type_class.t -> 'b Bin_prot.Type_class.t -> ('a, 'b) t Bin_prot.Type_class.t
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