Module Containers.Hashtbl
- since
- 0.14
include module type of Stdlib.Hashtbl with type Hashtbl.statistics = Stdlib.Hashtbl.statistics and module Hashtbl.Make = Stdlib.Hashtbl.Make and type ('a, 'b) Hashtbl.t = ('a, 'b) Stdlib.Hashtbl.t
val create : ?random:bool -> int -> ('a, 'b) tval clear : ('a, 'b) t -> unitval reset : ('a, 'b) t -> unitval copy : ('a, 'b) t -> ('a, 'b) tval add : ('a, 'b) t -> 'a -> 'b -> unitval find : ('a, 'b) t -> 'a -> 'bval find_opt : ('a, 'b) t -> 'a -> 'b optionval find_all : ('a, 'b) t -> 'a -> 'b listval mem : ('a, 'b) t -> 'a -> boolval remove : ('a, 'b) t -> 'a -> unitval replace : ('a, 'b) t -> 'a -> 'b -> unitval iter : ('a -> 'b -> unit) -> ('a, 'b) t -> unitval filter_map_inplace : ('a -> 'b -> 'b option) -> ('a, 'b) t -> unitval fold : ('a -> 'b -> 'c -> 'c) -> ('a, 'b) t -> 'c -> 'cval length : ('a, 'b) t -> intval randomize : unit -> unitval is_randomized : unit -> bool
type statistics= Stdlib.Hashtbl.statistics={num_bindings : int;num_buckets : int;max_bucket_length : int;bucket_histogram : int array;}
val stats : ('a, 'b) t -> statisticsval to_seq : ('a, 'b) t -> ('a * 'b) Stdlib.Seq.tval to_seq_keys : ('a, 'b) t -> 'a Stdlib.Seq.tval to_seq_values : ('a, 'b) t -> 'b Stdlib.Seq.tval add_seq : ('a, 'b) t -> ('a * 'b) Stdlib.Seq.t -> unitval replace_seq : ('a, 'b) t -> ('a * 'b) Stdlib.Seq.t -> unitval of_seq : ('a * 'b) Stdlib.Seq.t -> ('a, 'b) t
module type HashedType = sig ... endmodule type S = sig ... endmodule type SeededHashedType = sig ... endmodule type SeededS = sig ... endmodule MakeSeeded : functor (H : SeededHashedType) -> sig ... endinclude CCHashtbl.Poly
val get : ('a, 'b) Stdlib.Hashtbl.t -> 'a -> 'b optionget tbl kfinds a binding for the keykif present, or returnsNoneif no value is found. Safe version ofHashtbl.find.
val get_or : ('a, 'b) Stdlib.Hashtbl.t -> 'a -> default:'b -> 'bget_or tbl k ~defaultreturns the value associated tokif present, and returnsdefaultotherwise (ifkdoesn't belong intbl).- since
- 0.16
val keys : ('a, 'b) Stdlib.Hashtbl.t -> 'a CCHashtbl.iterkeys tbl fiterates on keys (similar order asHashtbl.iter).
val values : ('a, 'b) Stdlib.Hashtbl.t -> 'b CCHashtbl.itervalues tbl fiterates on values in the tabletbl.
val keys_list : ('a, 'b) Stdlib.Hashtbl.t -> 'a listkeys_list tblis the list of keys intbl. If the key is in the Hashtable multiple times, all occurrences will be returned.- since
- 0.8
val values_list : ('a, 'b) Stdlib.Hashtbl.t -> 'b listvalues_list tblis the list of values intbl.- since
- 0.8
val map_list : ('a -> 'b -> 'c) -> ('a, 'b) Stdlib.Hashtbl.t -> 'c listmap_list f tblmaps on atbl's items. Collect into a list.
val incr : ?by:int -> ('a, int) Stdlib.Hashtbl.t -> 'a -> unitincr ?by tbl xincrements or initializes the counter associated withx. Ifget tbl x = None, then after update,get tbl x = Some 1; otherwise, ifget tbl x = Some n, nowget tbl x = Some (n+1).- parameter by
if specified, the int value is incremented by
byrather than 1.
- since
- 0.16
val decr : ?by:int -> ('a, int) Stdlib.Hashtbl.t -> 'a -> unitdecr ?by tbl xis likeincrbut subtract 1 (or the value ofby). If the value reaches 0, the key is removed from the table. This does nothing if the key is not already present in the table.- since
- 0.16
val to_iter : ('a, 'b) Stdlib.Hashtbl.t -> ('a * 'b) CCHashtbl.iterIterate on bindings in the table.
- since
- 2.8
val add_list : ('a, 'b list) Stdlib.Hashtbl.t -> 'a -> 'b -> unitadd_list tbl x yaddsyto the listxis bound to. Ifxis not bound, it becomes bound toy.- since
- 0.16
val add_iter : ('a, 'b) Stdlib.Hashtbl.t -> ('a * 'b) CCHashtbl.iter -> unitAdd the corresponding pairs to the table, using
Hashtbl.add.- since
- 2.8
val add_seq : ('a, 'b) Stdlib.Hashtbl.t -> ('a * 'b) Stdlib.Seq.t -> unitAdd the corresponding pairs to the table, using
Hashtbl.add. Renamed fromadd_std_seqsince 3.0.- since
- 3.0
val of_iter : ('a * 'b) CCHashtbl.iter -> ('a, 'b) Stdlib.Hashtbl.tFrom the given bindings, added in order.
- since
- 2.8
val of_seq : ('a * 'b) Stdlib.Seq.t -> ('a, 'b) Stdlib.Hashtbl.tFrom the given bindings, added in order. Renamed from
of_std_seqsince 3.0.- since
- 3.0
val add_iter_count : ('a, int) Stdlib.Hashtbl.t -> 'a CCHashtbl.iter -> unitadd_iter_count tbl iincrements the count of each element ofiby callingincr. This is useful for counting how many times each element ofioccurs.- since
- 2.8
val add_seq_count : ('a, int) Stdlib.Hashtbl.t -> 'a Stdlib.Seq.t -> unitadd_seq_count tbl seqincrements the count of each element ofseqby callingincr. This is useful for counting how many times each element ofseqoccurs. Renamed fromadd_std_seq_countsince 3.0.- since
- 3.0
val of_iter_count : 'a CCHashtbl.iter -> ('a, int) Stdlib.Hashtbl.tLike
add_seq_count, but allocates a new table and returns it.- since
- 2.8
val of_seq_count : 'a Stdlib.Seq.t -> ('a, int) Stdlib.Hashtbl.tLike
add_seq_count, but allocates a new table and returns it. Renamed fromof_std_seq_countsince 3.0.- since
- 3.0
val to_list : ('a, 'b) Stdlib.Hashtbl.t -> ('a * 'b) listto_list tblreturns the list of (key,value) bindings (order unspecified).
val of_list : ('a * 'b) list -> ('a, 'b) Stdlib.Hashtbl.tof_list lbuilds a table from the given listlof bindingsk_i -> v_i, added in order usingadd. If a key occurs several times, it will be added several times, and the visible binding will be the last one.
val update : ('a, 'b) Stdlib.Hashtbl.t -> f:('a -> 'b option -> 'b option) -> k:'a -> unitupdate tbl ~f ~kupdates keykby callingf k (Some v)ifkwas mapped tov, orf k Noneotherwise; if the call returnsNonethenkis removed/stays removed, if the call returnsSome v'then the bindingk -> v'is inserted usingHashtbl.replace.- since
- 0.14
val get_or_add : ('a, 'b) Stdlib.Hashtbl.t -> f:('a -> 'b) -> k:'a -> 'bget_or_add tbl ~k ~ffinds and returns the binding ofkintbl, if it exists. If it does not exist, thenf kis called to obtain a new bindingv;k -> vis added totblandvis returned.- since
- 1.0
val pp : ?pp_start:unit CCHashtbl.printer -> ?pp_stop:unit CCHashtbl.printer -> ?pp_sep:unit CCHashtbl.printer -> ?pp_arrow:unit CCHashtbl.printer -> 'a CCHashtbl.printer -> 'b CCHashtbl.printer -> ('a, 'b) Stdlib.Hashtbl.t CCHashtbl.printerpp ~pp_start ~pp_stop ~pp_sep ~pp arrow pp_k pp_vreturns a table printer given app_kprinter for individual key and app_vprinter for individual value.pp_startandpp_stopcontrol the opening and closing delimiters, by default print nothing.pp_sepcontrol the separator between binding.pp_arrowcontrol the arrow between the key and value. Renamed fromprintsince 2.0.- since
- 0.13
module type S' = CCHashtbl.Smodule Make' = CCHashtbl.Make