Kind.Tbl
include Hashtbl.S with type key = t
type key = t
val create : int -> 'a t
val clear : 'a t -> unit
val reset : 'a t -> unit
val length : 'a t -> int
val stats : 'a t -> Stdlib.Hashtbl.statistics
val to_seq : 'a t -> (key * 'a) Stdlib.Seq.t
val to_seq_keys : _ t -> key Stdlib.Seq.t
val to_seq_values : 'a t -> 'a Stdlib.Seq.t
val replace_seq : 'a t -> (key * 'a) Stdlib.Seq.t -> unit
get tbl k
finds a binding for the key k
if present, or returns None
if no value is found. Safe version of Hashtbl.find
.
get_or tbl k ~default
returns the value associated to k
if present, and returns default
otherwise (if k
doesn't belong in tbl
).
add_list tbl x y
adds y
to the list x
is bound to. If x
is not bound, it becomes bound to y
.
incr ?by tbl x
increments 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)
.
decr ?by tbl x
is like incr
but 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.
val keys : 'a t -> key CCHashtbl.iter
keys tbl f
iterates on keys (similar order as Hashtbl.iter
).
val values : 'a t -> 'a CCHashtbl.iter
values tbl f
iterates on values in the table.
keys_list tbl
is the list of keys in tbl
. If the key is in the Hashtable multiple times, all occurrences will be returned.
val values_list : 'a t -> 'a list
values_list t
is the list of values in t
.
val to_iter : 'a t -> (key * 'a) CCHashtbl.iter
Iterate on bindings in the table.
val add_iter : 'a t -> (key * 'a) CCHashtbl.iter -> unit
Add the corresponding pairs to the table, using Hashtbl.add
.
val add_iter_with :
f:(key -> 'a -> 'a -> 'a) ->
'a t ->
(key * 'a) CCHashtbl.iter ->
unit
Add the corresponding pairs to the table, using Hashtbl.add
. If a key occurs multiple times in the input, the values are combined using f
in an unspecified order.
val add_seq : 'a t -> (key * 'a) Stdlib.Seq.t -> unit
Add the corresponding pairs to the table, using Hashtbl.add
. Renamed from add_std_seq
since 3.0.
val add_seq_with :
f:(key -> 'a -> 'a -> 'a) ->
'a t ->
(key * 'a) Stdlib.Seq.t ->
unit
Add the corresponding pairs to the table, using Hashtbl.add
. If a key occurs multiple times in the input, the values are combined using f
in an unspecified order.
val of_iter : (key * 'a) CCHashtbl.iter -> 'a t
From the given bindings, added in order.
val of_iter_with :
f:(key -> 'a -> 'a -> 'a) ->
(key * 'a) CCHashtbl.iter ->
'a t
From the given bindings, added in order. If a key occurs multiple times in the input, the values are combined using f
in an unspecified order.
val of_seq : (key * 'a) Stdlib.Seq.t -> 'a t
From the given bindings, added in order. Renamed from of_std_seq
since 3.0.
val of_seq_with : f:(key -> 'a -> 'a -> 'a) -> (key * 'a) Stdlib.Seq.t -> 'a t
From the given bindings, added in order. If a key occurs multiple times in the input, the values are combined using f
in an unspecified order.
val add_iter_count : int t -> key CCHashtbl.iter -> unit
add_iter_count tbl i
increments the count of each element of i
by calling incr
. This is useful for counting how many times each element of i
occurs.
val add_seq_count : int t -> key Stdlib.Seq.t -> unit
add_seq_count tbl seq
increments the count of each element of seq
by calling incr
. This is useful for counting how many times each element of seq
occurs. Renamed from of_std_seq_count
since 3.0.
val of_iter_count : key CCHashtbl.iter -> int t
Like add_seq_count
, but allocates a new table and returns it.
val of_seq_count : key Stdlib.Seq.t -> int t
Like add_seq_count
, but allocates a new table and returns it. Renamed from of_std_seq_count
since 3.0.
to_list tbl
returns the list of (key,value) bindings (order unspecified).
of_list l
builds a table from the given list l
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.
of_list l
builds a table from the given list l
of bindings k_i -> v_i
. If a key occurs multiple times in the input, the values are combined using f
in an unspecified order.
update tbl ~f ~k
updates key k
by calling f k (Some v)
if k
was mapped to v
, or f k None
otherwise; if the call returns None
then k
is removed/stays removed, if the call returns Some v'
then the binding k -> v'
is inserted using Hashtbl.replace
.
get_or_add tbl ~k ~f
finds and returns the binding of k
in tbl
, if it exists. If it does not exist, then f k
is called to obtain a new binding v
; k -> v
is added to tbl
and v
is returned.
val pp :
?pp_start:unit CCHashtbl.printer ->
?pp_stop:unit CCHashtbl.printer ->
?pp_sep:unit CCHashtbl.printer ->
?pp_arrow:unit CCHashtbl.printer ->
key CCHashtbl.printer ->
'a CCHashtbl.printer ->
'a t CCHashtbl.printer
pp ~pp_start ~pp_stop ~pp_sep ~pp arrow pp_k pp_v
returns a table printer given a pp_k
printer for individual key and a pp_v
printer for individual value. pp_start
and pp_stop
control the opening and closing delimiters, by default print nothing. pp_sep
control the separator between binding. pp_arrow
control the arrow between the key and value. Renamed from print
since 2.0.