Module Base.Hashtbl
val sexp_of_t : ('a -> Sexp.t) -> ('b -> Sexp.t) -> ('a, 'b) t -> Sexp.tWe provide a
sexp_of_tbut not at_of_sexpfor this type because one needs to be explicit about the hash and comparison functions used when creating a hashtable. Note thatHashtbl.Poly.tdoes have[@@deriving_inline sexp][@@@end], and uses OCaml's built-in polymorphic comparison and and polymorphic hashing.
Creators
val create : ?growth_allowed:bool -> ?size:int -> (module Base__.Hashtbl_intf.Key with type t = 'a) -> ('a, 'b) tThe module you pass to
createmust have a type that is hashable, sexpable, and comparable.Example:
Hashtbl.create (module Int);; - : (int, '_a) Hashtbl.t = <abstr>;;
val of_alist : ?growth_allowed:bool -> ?size:int -> (module Base__.Hashtbl_intf.Key with type t = 'a) -> ('a * 'b) list -> [ `Ok of ('a, 'b) t | `Duplicate_key of 'a ]Example:
Hashtbl.of_alist (module Int) [(3, "something"); (2, "whatever")] - : [ `Duplicate_key of int | `Ok of (int, string) Hashtbl.t ] = `Ok <abstr>
val of_alist_report_all_dups : ?growth_allowed:bool -> ?size:int -> (module Base__.Hashtbl_intf.Key with type t = 'a) -> ('a * 'b) list -> [ `Ok of ('a, 'b) t | `Duplicate_keys of 'a list ]Whereas
of_alistwill reportDuplicate_keyno matter how many dups there are in your list,of_alist_report_all_dupswill report each and every duplicate entry.For example:
Hashtbl.of_alist (module Int) [(1, "foo"); (1, "bar"); (2, "foo"); (2, "bar")];; - : [ `Duplicate_key of int | `Ok of (int, string) Hashtbl.t ] = `Duplicate_key 1 Hashtbl.of_alist_report_all_dups (module Int) [(1, "foo"); (1, "bar"); (2, "foo"); (2, "bar")];; - : [ `Duplicate_keys of int list | `Ok of (int, string) Hashtbl.t ] = `Duplicate_keys [1; 2]
val of_alist_or_error : ?growth_allowed:bool -> ?size:int -> (module Base__.Hashtbl_intf.Key with type t = 'a) -> ('a * 'b) list -> ('a, 'b) t Or_error.tval of_alist_exn : ?growth_allowed:bool -> ?size:int -> (module Base__.Hashtbl_intf.Key with type t = 'a) -> ('a * 'b) list -> ('a, 'b) tval of_alist_multi : ?growth_allowed:bool -> ?size:int -> (module Base__.Hashtbl_intf.Key with type t = 'a) -> ('a * 'b) list -> ('a, 'b list) tCreates a "multi" hashtable, i.e., a hashtable where each key points to a list potentially containing multiple values. So instead of short-circuiting with a
`Duplicate_keyvariant on duplicates, as inof_alist,of_alist_multifolds those values into a list for the given key:let h = Hashtbl.of_alist_multi (module Int) [(1, "a"); (1, "b"); (2, "c"); (2, "d")];; val h : (int, string list) Hashtbl.t = <abstr> Hashtbl.find_exn h 1;; - : string list = ["b"; "a"]
val create_mapped : ?growth_allowed:bool -> ?size:int -> (module Base__.Hashtbl_intf.Key with type t = 'a) -> get_key:('r -> 'a) -> get_data:('r -> 'b) -> 'r list -> [ `Ok of ('a, 'b) t | `Duplicate_keys of 'a list ]Applies the
get_keyandget_datafunctions to the'r listto create the initial keys and values, respectively, for the new hashtable.create_mapped get_key get_data [x1;...;xn] = of_alist [get_key x1, get_data x1; ...; get_key xn, get_data xn]Example:
let h = Hashtbl.create_mapped (module Int) ~get_key:(fun x -> x) ~get_data:(fun x -> x + 1) [1; 2; 3];; val h : [ `Duplicate_keys of int list | `Ok of (int, int) Hashtbl.t ] = `Ok <abstr> let h = match h with | `Ok x -> x | `Duplicate_keys _ -> failwith "" in Hashtbl.find_exn h 1;; - : int = 2
val create_with_key : ?growth_allowed:bool -> ?size:int -> (module Base__.Hashtbl_intf.Key with type t = 'a) -> get_key:('r -> 'a) -> 'r list -> [ `Ok of ('a, 'r) t | `Duplicate_keys of 'a list ]create_with_key ~get_key [x1;...;xn] = of_alist [get_key x1, x1; ...; get_key xn, xn]
val create_with_key_or_error : ?growth_allowed:bool -> ?size:int -> (module Base__.Hashtbl_intf.Key with type t = 'a) -> get_key:('r -> 'a) -> 'r list -> ('a, 'r) t Or_error.tval create_with_key_exn : ?growth_allowed:bool -> ?size:int -> (module Base__.Hashtbl_intf.Key with type t = 'a) -> get_key:('r -> 'a) -> 'r list -> ('a, 'r) tval group : ?growth_allowed:bool -> ?size:int -> (module Base__.Hashtbl_intf.Key with type t = 'a) -> get_key:('r -> 'a) -> get_data:('r -> 'b) -> combine:('b -> 'b -> 'b) -> 'r list -> ('a, 'b) tLike
create_mapped, applies theget_keyandget_datafunctions to the'r listto create the initial keys and values, respectively, for the new hashtable -- and then, likeadd_multi, folds together values belonging to the same keys. Here, though, the function used for the folding is given bycombine(instead of just being acons).Example:
Hashtbl.group (module Int) ~get_key:(fun x -> x / 2) ~get_data:(fun x -> x) ~combine:(fun x y -> x * y) [ 1; 2; 3; 4] |> Hashtbl.to_alist;; - : (int * int) list = [(2, 4); (1, 6); (0, 1)]
val sexp_of_key : ('a, _) t -> 'a key -> Sexp.tval clear : (_, _) t -> unitval copy : ('a, 'b) t -> ('a, 'b) tval fold : ('a, 'b) t -> init:'c -> f:(key:'a key -> data:'b -> 'c -> 'c) -> 'cAttempting to modify (
set,remove, etc.) the hashtable during iteration (fold,iter,iter_keys,iteri) will raise an exception.
val iter_keys : ('a, _) t -> f:('a key -> unit) -> unitval iter : (_, 'b) t -> f:('b -> unit) -> unitval iteri : ('a, 'b) t -> f:(key:'a key -> data:'b -> unit) -> unitIterates over both keys and values.
Example:
let h = Hashtbl.of_alist_exn (module Int) [(1, 4); (5, 6)] in Hashtbl.iteri h ~f:(fun ~key ~data -> print_endline (Printf.sprintf "%d-%d" key data));; 1-4 5-6 - : unit = ()
val existsi : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> boolval exists : (_, 'b) t -> f:('b -> bool) -> boolval for_alli : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> boolval for_all : (_, 'b) t -> f:('b -> bool) -> boolval counti : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> intval count : (_, 'b) t -> f:('b -> bool) -> intval length : (_, _) t -> intval is_empty : (_, _) t -> boolval mem : ('a, _) t -> 'a key -> boolval remove : ('a, _) t -> 'a key -> unitval set : ('a, 'b) t -> key:'a key -> data:'b -> unitSets the given
keytodata.
val add : ('a, 'b) t -> key:'a key -> data:'b -> [ `Ok | `Duplicate ]addandadd_exnleave the table unchanged if the key was already present.
val add_exn : ('a, 'b) t -> key:'a key -> data:'b -> unitval change : ('a, 'b) t -> 'a key -> f:('b option -> 'b option) -> unitchange t key ~fchangest's value forkeyto bef (find t key).
val update : ('a, 'b) t -> 'a key -> f:('b option -> 'b) -> unitupdate t key ~fischange t key ~f:(fun o -> Some (f o)).
val map : ('a, 'b) t -> f:('b -> 'c) -> ('a, 'c) tmap t freturns a new table with values replaced by the result of applyingfto the current values.Example:
let h = Hashtbl.of_alist_exn (module Int) [(1, 4); (5, 6)] in let h' = Hashtbl.map h ~f:(fun x -> x * 2) in Hashtbl.to_alist h';; - : (int * int) list = [(5, 12); (1, 8)]
val mapi : ('a, 'b) t -> f:(key:'a key -> data:'b -> 'c) -> ('a, 'c) tLike
map, but the functionftakes both key and data as arguments.
val filter_map : ('a, 'b) t -> f:('b -> 'c option) -> ('a, 'c) tReturns a new table by filtering the given table's values by
f: the keys for whichfapplied to the current value returnsSomeare kept, and those for which it returnsNoneare discarded.Example:
let h = Hashtbl.of_alist_exn (module Int) [(1, 4); (5, 6)] in Hashtbl.filter_map h ~f:(fun x -> if x > 5 then Some x else None) |> Hashtbl.to_alist;; - : (int * int) list = [(5, 6)]
val filter_mapi : ('a, 'b) t -> f:(key:'a key -> data:'b -> 'c option) -> ('a, 'c) tLike
filter_map, but the functionftakes both key and data as arguments.
val filter_keys : ('a, 'b) t -> f:('a key -> bool) -> ('a, 'b) tval filter : ('a, 'b) t -> f:('b -> bool) -> ('a, 'b) tval filteri : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> ('a, 'b) tval partition_map : ('a, 'b) t -> f:('b -> [ `Fst of 'c | `Snd of 'd ]) -> ('a, 'c) t * ('a, 'd) tReturns new tables with bound values partitioned by
fapplied to the bound values.
val partition_mapi : ('a, 'b) t -> f:(key:'a key -> data:'b -> [ `Fst of 'c | `Snd of 'd ]) -> ('a, 'c) t * ('a, 'd) tLike
partition_map, but the functionftakes both key and data as arguments.
val partition_tf : ('a, 'b) t -> f:('b -> bool) -> ('a, 'b) t * ('a, 'b) tReturns a pair of tables
(t1, t2), wheret1contains all the elements of the initial table which satisfy the predicatef, andt2contains the rest.
val partitioni_tf : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> ('a, 'b) t * ('a, 'b) tLike
partition_tf, but the functionftakes both key and data as arguments.
val find_or_add : ('a, 'b) t -> 'a key -> default:(unit -> 'b) -> 'bfind_or_add t k ~defaultreturns the data associated with keykif it is in the tablet, and otherwise assignskthe value returned bydefault ().
val findi_or_add : ('a, 'b) t -> 'a key -> default:('a key -> 'b) -> 'bLike
find_or_addbutdefaulttakes the key as an argument.
val find : ('a, 'b) t -> 'a key -> 'b optionfind t kreturnsSome(the current binding) ofkint, orNoneif no such binding exists.
val find_exn : ('a, 'b) t -> 'a key -> 'bfind_exn t kreturns the current binding ofkint, or raisesCaml.Not_foundorNot_found_sif no such binding exists.
val find_and_call : ('a, 'b) t -> 'a key -> if_found:('b -> 'c) -> if_not_found:('a key -> 'c) -> 'cfind_and_call t k ~if_found ~if_not_foundis equivalent to:
match find t k with Some v -> if_found v | None -> if_not_found kexcept that it doesn't allocate the option.
val findi_and_call : ('a, 'b) t -> 'a key -> if_found:(key:'a key -> data:'b -> 'c) -> if_not_found:('a key -> 'c) -> 'cval find_and_remove : ('a, 'b) t -> 'a key -> 'b optionfind_and_remove t kreturns Some (the current binding) of k in t and removes it, or None is no such binding exists.
val merge : ('k, 'a) t -> ('k, 'b) t -> f:(key:'k key -> [ `Left of 'a | `Right of 'b | `Both of 'a * 'b ] -> 'c option) -> ('k, 'c) tMerges two hashtables.
The result of
merge f h1 h2has as keys the set of allkin the union of the sets of keys ofh1andh2for whichd(k)is not None, where:d(k) =
f ~key:k (Some d1) Noneifkinh1maps to d1, andh2does not have data fork;
f ~key:k None (Some d2)ifkinh2maps to d2, andh1does not have data fork;
f ~key:k (Some d1) (Some d2)otherwise, wherekinh1maps tod1andkinh2maps tod2.
Each key
kis mapped to a single piece of datax, whered(k) = Some x.Example:
let h1 = Hashtbl.of_alist_exn (module Int) [(1, 5); (2, 3232)] in let h2 = Hashtbl.of_alist_exn (module Int) [(1, 3)] in Hashtbl.merge h1 h2 ~f:(fun ~key:_ -> function | `Left x -> Some (`Left x) | `Right x -> Some (`Right x) | `Both (x, y) -> if x=y then None else Some (`Both (x,y)) ) |> Hashtbl.to_alist;; - : (int * [> `Both of int * int | `Left of int | `Right of int ]) list = [(2, `Left 3232); (1, `Both (5, 3))]
type 'a merge_into_action=|Remove|Set_to of 'aEvery
keyinsrcwill be removed or set indstaccording to the return value off.
val merge_into : src:('k, 'a) t -> dst:('k, 'b) t -> f:(key:'k key -> 'a -> 'b option -> 'b merge_into_action) -> unitval keys : ('a, _) t -> 'a key listReturns the list of all keys for given hashtable.
val data : (_, 'b) t -> 'b listReturns the list of all data for given hashtable.
val filter_keys_inplace : ('a, _) t -> f:('a key -> bool) -> unitfilter_inplace t ~fremoves all the elements fromtthat don't satisfyf.
val filter_inplace : (_, 'b) t -> f:('b -> bool) -> unitval filteri_inplace : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> unitval map_inplace : (_, 'b) t -> f:('b -> 'b) -> unitmap_inplace t ~fappliesfto all elements int, transforming them in place.
val mapi_inplace : ('a, 'b) t -> f:(key:'a key -> data:'b -> 'b) -> unitval filter_map_inplace : (_, 'b) t -> f:('b -> 'b option) -> unitfilter_map_inplacecombines the effects ofmap_inplaceandfilter_inplace.
val filter_mapi_inplace : ('a, 'b) t -> f:(key:'a key -> data:'b -> 'b option) -> unitval equal : ('a, 'b) t -> ('a, 'b) t -> ('b -> 'b -> bool) -> boolequal t1 t2 fandsimilar t1 t2 fboth return true ifft1andt2have the same keys and for all keysk,f (find_exn t1 k) (find_exn t2 k).equalandsimilaronly differ in their types.
val similar : ('a, 'b1) t -> ('a, 'b2) t -> ('b1 -> 'b2 -> bool) -> boolval to_alist : ('a, 'b) t -> ('a key * 'b) listReturns the list of all (key, data) pairs for given hashtable.
val validate : name:('a key -> string) -> 'b Validate.check -> ('a, 'b) t Validate.checkval incr : ?by:int -> ?remove_if_zero:bool -> ('a, int) t -> 'a key -> unitremove_if_zero's default isfalse.
val add_multi : ('a, 'b list) t -> key:'a key -> data:'b -> unitadd_multi t ~key ~dataifkeyis present in the table then consdataon the list, otherwise addkeywith a single element list.
val hashable_s : ('key, _) t -> (module Base__.Hashtbl_intf.Key with type t = 'key)
include Invariant.S2 with type ('a, 'b) t := ('a, 'b) t
val invariant : 'a Base__.Invariant_intf.inv -> 'b Base__.Invariant_intf.inv -> ('a, 'b) t Base__.Invariant_intf.inv
module type Accessors = Base__.Hashtbl_intf.Accessorsmodule type Creators = Base__.Hashtbl_intf.Creatorsmodule type Key = Base__.Hashtbl_intf.Keymodule type Multi = Base__.Hashtbl_intf.Multimodule type S_poly = Base__.Hashtbl_intf.S_polymodule type S_without_submodules = Base__.Hashtbl_intf.S_without_submodulesmodule type For_deriving = Base__.Hashtbl_intf.For_derivingtype nonrec ('key, 'data, 'z) create_options= ('key, 'data, 'z) Base__.Hashtbl_intf.create_options
module M : functor (K : T.T) -> sig ... endMis meant to be used in combination with OCaml applicative functor types:
include For_deriving with type ('a, 'b) For_deriving.t := ('a, 'b) t
module type Sexp_of_m = sig ... endmodule type M_of_sexp = sig ... end