package vcaml

  1. Overview
  2. Docs
Legend:
Page
Library
Module
Module type
Parameter
Class
Class type
Source

Module Buffer.TableSource

Sourcetype key = t
Sourcetype ('a, 'b) hashtbl = ('a, 'b) Core.Hashtbl.t
Sourcetype 'b t = (key, 'b) hashtbl
include Ppx_compare_lib.Equal.S1 with type 'b t := 'b t
Sourceval sexp_of_t : ('b -> Sexplib0.Sexp.t) -> 'b t -> Sexplib0.Sexp.t
Sourcetype ('a, 'b) t_ = 'b t
Sourcetype 'a key_ = key
Sourceval hashable : key Base.Hashable.t
include Base.Invariant.S1 with type 'b t := 'b t
Sourceval invariant : 'a Base__.Invariant_intf.inv -> 'a t Base__.Invariant_intf.inv
Sourceval create : ('a key_, 'b, unit -> ('a, 'b) t_) Core.Hashtbl_intf.create_options_without_hashable
Sourceval of_alist : ('a key_, 'b, ('a key_ * 'b) list -> [ `Ok of ('a, 'b) t_ | `Duplicate_key of 'a key_ ]) Core.Hashtbl_intf.create_options_without_hashable
Sourceval of_alist_report_all_dups : ('a key_, 'b, ('a key_ * 'b) list -> [ `Ok of ('a, 'b) t_ | `Duplicate_keys of 'a key_ list ]) Core.Hashtbl_intf.create_options_without_hashable
Sourceval of_alist_or_error : ('a key_, 'b, ('a key_ * 'b) list -> ('a, 'b) t_ Base__.Or_error.t) Core.Hashtbl_intf.create_options_without_hashable
Sourceval of_alist_exn : ('a key_, 'b, ('a key_ * 'b) list -> ('a, 'b) t_) Core.Hashtbl_intf.create_options_without_hashable
Sourceval of_alist_multi : ('a key_, 'b list, ('a key_ * 'b) list -> ('a, 'b list) t_) Core.Hashtbl_intf.create_options_without_hashable
Sourceval create_mapped : ('a key_, 'b, get_key:('r -> 'a key_) -> get_data:('r -> 'b) -> 'r list -> [ `Ok of ('a, 'b) t_ | `Duplicate_keys of 'a key_ list ]) Core.Hashtbl_intf.create_options_without_hashable
 create_mapped get_key get_data [x1,...,xn]
   = of_alist [get_key x1, get_data x1; ...; get_key xn, get_data xn] 
Sourceval create_with_key : ('a key_, 'r, get_key:('r -> 'a key_) -> 'r list -> [ `Ok of ('a, 'r) t_ | `Duplicate_keys of 'a key_ list ]) Core.Hashtbl_intf.create_options_without_hashable
 create_with_key ~get_key [x1,...,xn]
   = of_alist [get_key x1, x1; ...; get_key xn, xn] 
Sourceval create_with_key_or_error : ('a key_, 'r, get_key:('r -> 'a key_) -> 'r list -> ('a, 'r) t_ Base__.Or_error.t) Core.Hashtbl_intf.create_options_without_hashable
Sourceval create_with_key_exn : ('a key_, 'r, get_key:('r -> 'a key_) -> 'r list -> ('a, 'r) t_) Core.Hashtbl_intf.create_options_without_hashable
Sourceval group : ('a key_, 'b, get_key:('r -> 'a key_) -> get_data:('r -> 'b) -> combine:('b -> 'b -> 'b) -> 'r list -> ('a, 'b) t_) Core.Hashtbl_intf.create_options_without_hashable
include Core.Hashtbl_intf.Accessors with type ('a, 'b) t := ('a, 'b) t_ with type 'a key := 'a key_
include Base.Hashtbl.Accessors with type ('a, 'b) t := ('a, 'b) t_ with type 'a key := 'a key_

Accessors

Sourceval sexp_of_key : ('a, _) t_ -> 'a key_ -> Base__.Sexp.t
Sourceval clear : (_, _) t_ -> unit
Sourceval copy : ('a, 'b) t_ -> ('a, 'b) t_
Sourceval fold : ('a, 'b) t_ -> init:'c -> f:(key:'a key_ -> data:'b -> 'c -> 'c) -> 'c

Attempting to modify (set, remove, etc.) the hashtable during iteration (fold, iter, iter_keys, iteri) will raise an exception.

Sourceval iter_keys : ('a, _) t_ -> f:('a key_ -> unit) -> unit
Sourceval iter : (_, 'b) t_ -> f:('b -> unit) -> unit
Sourceval iteri : ('a, 'b) t_ -> f:(key:'a key_ -> data:'b -> unit) -> unit

Iterates 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 = ()
Sourceval existsi : ('a, 'b) t_ -> f:(key:'a key_ -> data:'b -> bool) -> bool
Sourceval exists : (_, 'b) t_ -> f:('b -> bool) -> bool
Sourceval for_alli : ('a, 'b) t_ -> f:(key:'a key_ -> data:'b -> bool) -> bool
Sourceval for_all : (_, 'b) t_ -> f:('b -> bool) -> bool
Sourceval counti : ('a, 'b) t_ -> f:(key:'a key_ -> data:'b -> bool) -> int
Sourceval count : (_, 'b) t_ -> f:('b -> bool) -> int
Sourceval length : (_, _) t_ -> int
Sourceval is_empty : (_, _) t_ -> bool
Sourceval mem : ('a, _) t_ -> 'a key_ -> bool
Sourceval remove : ('a, _) t_ -> 'a key_ -> unit
Sourceval choose : ('a, 'b) t_ -> ('a key_ * 'b) option
Sourceval choose_exn : ('a, 'b) t_ -> 'a key_ * 'b
Sourceval set : ('a, 'b) t_ -> key:'a key_ -> data:'b -> unit

Sets the given key to data.

Sourceval add : ('a, 'b) t_ -> key:'a key_ -> data:'b -> [ `Ok | `Duplicate ]

add and add_exn leave the table unchanged if the key was already present.

Sourceval add_exn : ('a, 'b) t_ -> key:'a key_ -> data:'b -> unit
Sourceval change : ('a, 'b) t_ -> 'a key_ -> f:('b option -> 'b option) -> unit

change t key ~f changes t's value for key to be f (find t key).

Sourceval update : ('a, 'b) t_ -> 'a key_ -> f:('b option -> 'b) -> unit

update t key ~f is change t key ~f:(fun o -> Some (f o)).

Sourceval update_and_return : ('a, 'b) t_ -> 'a key_ -> f:('b option -> 'b) -> 'b

update_and_return t key ~f is update, but returns the result of f o.

Sourceval map : ('a, 'b) t_ -> f:('b -> 'c) -> ('a, 'c) t_

map t f returns a new table with values replaced by the result of applying f to 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)]
Sourceval mapi : ('a, 'b) t_ -> f:(key:'a key_ -> data:'b -> 'c) -> ('a, 'c) t_

Like map, but the function f takes both key and data as arguments.

Sourceval filter_map : ('a, 'b) t_ -> f:('b -> 'c option) -> ('a, 'c) t_

Returns a new table by filtering the given table's values by f: the keys for which f applied to the current value returns Some are kept, and those for which it returns None are 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)]
Sourceval filter_mapi : ('a, 'b) t_ -> f:(key:'a key_ -> data:'b -> 'c option) -> ('a, 'c) t_

Like filter_map, but the function f takes both key and data as arguments.

Sourceval filter_keys : ('a, 'b) t_ -> f:('a key_ -> bool) -> ('a, 'b) t_
Sourceval filter : ('a, 'b) t_ -> f:('b -> bool) -> ('a, 'b) t_
Sourceval filteri : ('a, 'b) t_ -> f:(key:'a key_ -> data:'b -> bool) -> ('a, 'b) t_
Sourceval partition_map : ('a, 'b) t_ -> f:('b -> ('c, 'd) Base__.Either.t) -> ('a, 'c) t_ * ('a, 'd) t_

Returns new tables with bound values partitioned by f applied to the bound values.

Sourceval partition_mapi : ('a, 'b) t_ -> f:(key:'a key_ -> data:'b -> ('c, 'd) Base__.Either.t) -> ('a, 'c) t_ * ('a, 'd) t_

Like partition_map, but the function f takes both key and data as arguments.

Sourceval partition_tf : ('a, 'b) t_ -> f:('b -> bool) -> ('a, 'b) t_ * ('a, 'b) t_

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 the rest.

Sourceval partitioni_tf : ('a, 'b) t_ -> f:(key:'a key_ -> data:'b -> bool) -> ('a, 'b) t_ * ('a, 'b) t_

Like partition_tf, but the function f takes both key and data as arguments.

Sourceval find_or_add : ('a, 'b) t_ -> 'a key_ -> default:(unit -> 'b) -> 'b

find_or_add t k ~default returns the data associated with key k if it is in the table t, and otherwise assigns k the value returned by default ().

Sourceval findi_or_add : ('a, 'b) t_ -> 'a key_ -> default:('a key_ -> 'b) -> 'b

Like find_or_add but default takes the key as an argument.

Sourceval find : ('a, 'b) t_ -> 'a key_ -> 'b option

find t k returns Some (the current binding) of k in t, or None if no such binding exists.

Sourceval find_exn : ('a, 'b) t_ -> 'a key_ -> 'b

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.

Sourceval 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.

Sourceval find_and_call1 : ('a, 'b) t_ -> 'a key_ -> a:'d -> if_found:('b -> 'd -> 'c) -> if_not_found:('a key_ -> 'd -> 'c) -> 'c

Just like find_and_call, but takes an extra argument which is passed to if_found and if_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.

Sourceval 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) -> 'c
Sourceval findi_and_call : ('a, 'b) t_ -> 'a key_ -> if_found:(key:'a key_ -> data:'b -> 'c) -> if_not_found:('a key_ -> 'c) -> 'c
Sourceval 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) -> 'c
Sourceval 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) -> 'c
Sourceval find_and_remove : ('a, 'b) t_ -> 'a key_ -> 'b 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.

Sourceval 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_

Merges 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 (`Left d1) if k in h1 maps to d1, and h2 does not have data for k;
  • f ~key:k (`Right d2) if k in h2 maps to d2, and h1 does not have data for k;
  • f ~key:k (`Both (d1, d2)) otherwise, where k in h1 maps to d1 and k in h2 maps to d2.

Each key k is mapped to a single piece of data x, where d(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))]
Sourceval 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) -> unit

Every key in src will be removed or set in dst according to the return value of f.

Sourceval keys : ('a, _) t_ -> 'a key_ list

Returns the list of all keys for given hashtable.

Sourceval data : (_, 'b) t_ -> 'b list

Returns the list of all data for given hashtable.

Sourceval filter_keys_inplace : ('a, _) t_ -> f:('a key_ -> bool) -> unit

filter_inplace t ~f removes all the elements from t that don't satisfy f.

Sourceval filter_inplace : (_, 'b) t_ -> f:('b -> bool) -> unit
Sourceval filteri_inplace : ('a, 'b) t_ -> f:(key:'a key_ -> data:'b -> bool) -> unit
Sourceval map_inplace : (_, 'b) t_ -> f:('b -> 'b) -> unit

map_inplace t ~f applies f to all elements in t, transforming them in place.

Sourceval mapi_inplace : ('a, 'b) t_ -> f:(key:'a key_ -> data:'b -> 'b) -> unit
Sourceval filter_map_inplace : (_, 'b) t_ -> f:('b -> 'b option) -> unit

filter_map_inplace combines the effects of map_inplace and filter_inplace.

Sourceval filter_mapi_inplace : ('a, 'b) t_ -> f:(key:'a key_ -> data:'b -> 'b option) -> unit
Sourceval equal : ('b -> 'b -> bool) -> ('a, 'b) t_ -> ('a, 'b) t_ -> bool

equal f t1 t2 and similar f t1 t2 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.

Sourceval similar : ('b1 -> 'b2 -> bool) -> ('a, 'b1) t_ -> ('a, 'b2) t_ -> bool
Sourceval to_alist : ('a, 'b) t_ -> ('a key_ * 'b) list

Returns the list of all (key, data) pairs for given hashtable.

Sourceval incr : ?by:int -> ?remove_if_zero:bool -> ('a, int) t_ -> 'a key_ -> unit

remove_if_zero's default is false.

Sourceval decr : ?by:int -> ?remove_if_zero:bool -> ('a, int) t_ -> 'a key_ -> unit
Sourceval validate : name:('a key_ -> Base.String.t) -> 'b Validate.check -> ('a, 'b) t_ Validate.check
include Base.Hashtbl.Multi with type ('a, 'b) t := ('a, 'b) t_ with type 'a key := 'a key_
Sourceval add_multi : ('a, 'b list) t_ -> key:'a key_ -> data:'b -> unit

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.

Sourceval remove_multi : ('a, _ list) t_ -> 'a key_ -> unit

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.

Sourceval find_multi : ('a, 'b list) t_ -> 'a key_ -> 'b list

find_multi t key returns the empty list if key is not present in the table, returns t's values for key otherwise.

Sourcemodule Provide_of_sexp (Key : sig ... end) : sig ... end
Sourcemodule Provide_bin_io (Key : sig ... end) : sig ... end
OCaml

Innovation. Community. Security.