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) t
- val clear : ('a, 'b) t -> unit
- val reset : ('a, 'b) t -> unit
- val copy : ('a, 'b) t -> ('a, 'b) t
- val add : ('a, 'b) t -> 'a -> 'b -> unit
- val find : ('a, 'b) t -> 'a -> 'b
- val find_opt : ('a, 'b) t -> 'a -> 'b option
- val find_all : ('a, 'b) t -> 'a -> 'b list
- val mem : ('a, 'b) t -> 'a -> bool
- val remove : ('a, 'b) t -> 'a -> unit
- val replace : ('a, 'b) t -> 'a -> 'b -> unit
- val iter : ('a -> 'b -> unit) -> ('a, 'b) t -> unit
- val filter_map_inplace : ('a -> 'b -> 'b option) -> ('a, 'b) t -> unit
- val fold : ('a -> 'b -> 'c -> 'c) -> ('a, 'b) t -> 'c -> 'c
- val length : ('a, 'b) t -> int
- val randomize : unit -> unit
- val 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 -> statistics
- val to_seq : ('a, 'b) t -> ('a * 'b) Stdlib.Seq.t
- val to_seq_keys : ('a, 'b) t -> 'a Stdlib.Seq.t
- val to_seq_values : ('a, 'b) t -> 'b Stdlib.Seq.t
- val add_seq : ('a, 'b) t -> ('a * 'b) Stdlib.Seq.t -> unit
- val replace_seq : ('a, 'b) t -> ('a * 'b) Stdlib.Seq.t -> unit
- val 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 option
- Safe version of - Hashtbl.find.
- val get_or : ('a, 'b) Stdlib.Hashtbl.t -> 'a -> default:'b -> 'b
- get_or tbl k ~defaultreturns the value associated to- kif present, and returns- defaultotherwise (if- kdoesn't belong in- tbl).- since
- 0.16
 
- val keys : ('a, 'b) Stdlib.Hashtbl.t -> 'a CCHashtbl.sequence
- Iterate on keys (similar order as - Hashtbl.iter).
- val values : ('a, 'b) Stdlib.Hashtbl.t -> 'b CCHashtbl.sequence
- Iterate on values in the table. 
- val keys_list : ('a, 'b) Stdlib.Hashtbl.t -> 'a list
- keys_list tis the list of keys in- t. 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 list
- values_list tis the list of values in- t.- since
- 0.8
 
- val map_list : ('a -> 'b -> 'c) -> ('a, 'b) Stdlib.Hashtbl.t -> 'c list
- Map on a hashtable's items, collect into a list. 
- val incr : ?by:int -> ('a, int) Stdlib.Hashtbl.t -> 'a -> unit
- incr ?by tbl xincrements or initializes the counter associated with- x. If- get tbl x = None, then after update,- get tbl x = Some 1; otherwise, if- get tbl x = Some n, now- get 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 -> unit
- Like - incrbut subtract 1 (or the value of- by). 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_seq : ('a, 'b) Stdlib.Hashtbl.t -> ('a * 'b) CCHashtbl.sequence
- Iterate on bindings in the table. 
- val add_list : ('a, 'b list) Stdlib.Hashtbl.t -> 'a -> 'b -> unit
- add_list tbl x yadds- yto the list- xis bound to. If- xis not bound, it becomes bound to- y.- since
- 0.16
 
- val add_seq : ('a, 'b) Stdlib.Hashtbl.t -> ('a * 'b) CCHashtbl.sequence -> unit
- Add the corresponding pairs to the table, using - Hashtbl.add.- since
- 0.16
 
- val of_seq : ('a * 'b) CCHashtbl.sequence -> ('a, 'b) Stdlib.Hashtbl.t
- From the given bindings, added in order. 
- val add_seq_count : ('a, int) Stdlib.Hashtbl.t -> 'a CCHashtbl.sequence -> unit
- add_seq_count tbl seqincrements the count of each element of- seqby calling- incr. This is useful for counting how many times each element of- seqoccurs.- since
- 0.16
 
- val of_seq_count : 'a CCHashtbl.sequence -> ('a, int) Stdlib.Hashtbl.t
- Like - add_seq_count, but allocates a new table and returns it.- since
- 0.16
 
- val of_list : ('a * 'b) list -> ('a, 'b) Stdlib.Hashtbl.t
- Build a table from the given list of bindings - k_i -> v_i, added in order using- add. 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 -> unit
- update tbl ~f ~kupdates key- kby calling- f k (Some v)if- kwas mapped to- v, or- f k Noneotherwise; if the call returns- Nonethen- kis removed/stays removed, if the call returns- Some v'then the binding- k -> v'is inserted using- Hashtbl.replace.- since
- 0.14
 
- val get_or_add : ('a, 'b) Stdlib.Hashtbl.t -> f:('a -> 'b) -> k:'a -> 'b
- get_or_add tbl ~k ~ffinds and returns the binding of- kin- tbl, if it exists. If it does not exist, then- f kis called to obtain a new binding- v;- k -> vis added to- tbland- vis returned.- since
- 1.0
 
- val pp : 'a CCHashtbl.printer -> 'b CCHashtbl.printer -> ('a, 'b) Stdlib.Hashtbl.t CCHashtbl.printer
- Printer for table. Renamed from - printsince 2.0.- since
- 0.13
 
module type S' = CCHashtbl.Smodule Make' = CCHashtbl.Make