package base
Library
Module
Module type
Parameter
Class
Class type
We use [@@deriving_inline sexp_of][@@@end]
but not [@@deriving sexp]
because we want people to be explicit about the hash and comparison functions used when creating hashtables. One can use Hashtbl.Poly.t
, which does have [@@deriving_inline sexp][@@@end]
, to use polymorphic comparison and hashing.
include Invariant.S2 with type ('a, 'b) t := ('a, 'b) t
val invariant : ('a -> unit) -> ('b -> unit) -> ('a, 'b) t -> unit
val create :
?growth_allowed:bool ->
?size:int ->
(module Base__.Hashtbl_intf.Key with type t = 'a) ->
('a, 'b) t
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 ]
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 ]
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.t
val of_alist_exn :
?growth_allowed:bool ->
?size:int ->
(module Base__.Hashtbl_intf.Key with type t = 'a) ->
('a * 'b) list ->
('a, 'b) t
val of_alist_multi :
?growth_allowed:bool ->
?size:int ->
(module Base__.Hashtbl_intf.Key with type t = 'a) ->
('a * 'b) list ->
('a, 'b list) t
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 ]
create_mapped get_key get_data [x1,...,xn]
= of_alist [get_key x1, get_data x1; ...; get_key xn, get_data xn]
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.t
val 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) t
val 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) t
val clear : (_, _) t -> unit
Attempting to modify (set
, remove
, etc.) the hashtable during iteration (fold
, iter
, iter_keys
, iteri
) will raise an exception.
val iter : (_, 'b) t -> f:('b -> unit) -> unit
val exists : (_, 'b) t -> f:('b -> bool) -> bool
val for_all : (_, 'b) t -> f:('b -> bool) -> bool
val count : (_, 'b) t -> f:('b -> bool) -> int
val length : (_, _) t -> int
val is_empty : (_, _) t -> bool
add
and add_exn
leave the table unchanged if the key was already present.
change t key ~f
changes t
's value for key
to be f (find t key)
.
update t key ~f
is change t key ~f:(fun o -> Some (f o))
.
map t f
returns new table with bound values replaced by f
applied to the bound values
like map
, but function takes both key and data as arguments
returns new table with bound values filtered by f applied to the bound values
like filter_map
, but function takes both key and data as arguments
returns new tables with bound values partitioned by f applied 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) t
like partition_map
, but function takes both key and data as arguments
returns a pair of tables (t1, t2)
, where t1
contains all the elements of the initial table which satisfy the predicate f
, and t2
contains all the elements which do not satisfy f
.
like partition_tf
, but function takes both key and data as arguments
find_or_add t k ~default
returns the data associated with key k if it is in the table t, otherwise it lets d = default() and adds it to the table.
like find_or_add
but default
takes the key as an argument.
find t k
returns Some (the current binding) of k in t, or None if no such binding exists
find_exn t k
returns the current binding of k in t, or raises Caml.Not_found
or Not_found_s
if no such binding exists.
val find_and_call :
('a, 'b) t ->
'a key ->
if_found:('b -> 'c) ->
if_not_found:('a key -> 'c) ->
'c
find_and_call t k ~if_found ~if_not_found
is equivalent to:
match find t k with Some v -> if_found v | None -> if_not_found k
except that it doesn't allocate the option.
find_and_remove t k
returns 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) t
Merge two hashtables.
The result of merge f h1 h2
has as keys the set of all k
in the union of the sets of keys of h1
and h2
for which d(k)
is not None, where:
d(k) =
- f ~key:k (Some d1) None if
k
inh1
is to d1, andh2
does not mapk
;
- f ~key:k None (Some d2) if
k
inh2
is to d2, andh1
does not mapk
;
- f ~key:k (Some d1) (Some d2) otherwise, where
k
inh1
is tod1
andk
inh2
is tod2
.
Each key k
is mapped to a single piece of data x, where d(k)
= Some x.
Every key
in src
will be removed or set in dst
according to the return value of f
.
val merge_into :
src:('k, 'a) t ->
dst:('k, 'b) t ->
f:(key:'k key -> 'a -> 'b option -> 'b merge_into_action) ->
unit
val data : (_, 'b) t -> 'b list
Returns the list of all data for given hashtable.
filter_inplace t ~f
removes all the elements from t
that don't satisfy f
.
val filter_inplace : (_, 'b) t -> f:('b -> bool) -> unit
val map_inplace : (_, 'b) t -> f:('b -> 'b) -> unit
map_inplace t ~f
applies f to all elements in t
, transforming them in place
val filter_map_inplace : (_, 'b) t -> f:('b -> 'b option) -> unit
filter_map_inplace
combines the effects of map_inplace
and filter_inplace
equal t1 t2 f
and similar t1 t2 f
both return true iff t1
and t2
have the same keys and for all keys k
, f (find_exn t1 k) (find_exn t2 k)
. equal
and similar
only differ in their types.
Returns the list of all (key,data) pairs for given hashtable.
val validate :
name:('a key -> string) ->
'b Validate.check ->
('a, 'b) t Validate.check
remove_if_zero
's default is false
.
add_multi t ~key ~data
if key
is present in the table then cons data
on the list, otherwise add key
with a single element list.
remove_multi t key
updates the table, removing the head of the list bound to key
. If the list has only one element (or is empty) then the binding is removed.
find_multi t key
returns the empty list if key
is not present in the table, returns t
's values for key
otherwise
val hashable_s :
('key, _) t ->
(module Base__.Hashtbl_intf.Key
with type t = 'key)