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 sexp], and uses OCaml's built-in polymorphic comparison and and polymorphic hashing.
Creators
val create : ?growth_allowed:bool -> ?size:int -> 'a Base__.Hashtbl_intf.Key.t -> ('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 -> 'a Base__.Hashtbl_intf.Key.t -> ('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 -> 'a Base__.Hashtbl_intf.Key.t -> ('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 -> 'a Base__.Hashtbl_intf.Key.t -> ('a * 'b) list -> ('a, 'b) t Or_error.tval of_alist_exn : ?growth_allowed:bool -> ?size:int -> 'a Base__.Hashtbl_intf.Key.t -> ('a * 'b) list -> ('a, 'b) tval of_alist_multi : ?growth_allowed:bool -> ?size:int -> 'a Base__.Hashtbl_intf.Key.t -> ('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 -> 'a Base__.Hashtbl_intf.Key.t -> 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 -> 'a Base__.Hashtbl_intf.Key.t -> 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 -> 'a Base__.Hashtbl_intf.Key.t -> get_key:('r -> 'a) -> 'r list -> ('a, 'r) t Or_error.tval create_with_key_exn : ?growth_allowed:bool -> ?size:int -> 'a Base__.Hashtbl_intf.Key.t -> get_key:('r -> 'a) -> 'r list -> ('a, 'r) tval group : ?growth_allowed:bool -> ?size:int -> 'a Base__.Hashtbl_intf.Key.t -> 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 choose : ('a, 'b) t -> ('a key * 'b) optionval choose_exn : ('a, 'b) t -> 'a key * 'bval 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 -> ('c, 'd) Either.t) -> ('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 -> ('c, 'd) Either.t) -> ('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 find_and_call1 : ('a, 'b) t -> 'a key -> a:'d -> if_found:('b -> 'd -> 'c) -> if_not_found:('a key -> 'd -> 'c) -> 'cJust like
find_and_call, but takes an extra argument which is passed toif_foundandif_not_found, so that the client code can avoid allocating closures or using refs to pass this additional information. This function is only useful in code which tries to minimize heap allocation.
val find_and_call2 : ('a, 'b) t -> 'a key -> a:'d -> b:'e -> if_found:('b -> 'd -> 'e -> 'c) -> if_not_found:('a key -> 'd -> 'e -> 'c) -> 'cval findi_and_call : ('a, 'b) t -> 'a key -> if_found:(key:'a key -> data:'b -> 'c) -> if_not_found:('a key -> 'c) -> 'cval findi_and_call1 : ('a, 'b) t -> 'a key -> a:'d -> if_found:(key:'a key -> data:'b -> 'd -> 'c) -> if_not_found:('a key -> 'd -> 'c) -> 'cval findi_and_call2 : ('a, 'b) t -> 'a key -> a:'d -> b:'e -> if_found:(key:'a key -> data:'b -> 'd -> 'e -> 'c) -> if_not_found:('a key -> 'd -> 'e -> '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 (`Left d1)ifkinh1maps to d1, andh2does not have data fork;
f ~key:k (`Right d2)ifkinh2maps to d2, andh1does not have data fork;
f ~key:k (`Both (d1, 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))]
val merge_into : src:('k, 'a) t -> dst:('k, 'b) t -> f:(key:'k key -> 'a -> 'b option -> 'b Base__.Hashtbl_intf.Merge_into_action.t) -> unitEvery
keyinsrcwill be removed or set indstaccording to the return value off.
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 : ('b -> 'b -> bool) -> ('a, 'b) t -> ('a, 'b) t -> boolequal f t1 t2andsimilar f t1 t2both 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 : ('b1 -> 'b2 -> bool) -> ('a, 'b1) t -> ('a, 'b2) t -> 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 -> 'key Base__.Hashtbl_intf.Key.t
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.Key.Smodule 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_derivingmodule Key = Base__.Hashtbl_intf.Keymodule Merge_into_action = Base__.Hashtbl_intf.Merge_into_actiontype 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