package bap-primus-support
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
sha256=631fc58628418e4856709a0cfc923a65e00c9494fbd28d444c633d11194831de
    
    
  md5=3db9deac8d429b9b8a8ec9aec54987b1
    
    
  doc/bap-plugin-primus_wandering/Primus_wandering_main/Make/argument-2-Machine/Id/Table/index.html
Module Id.Table
include Core_kernel.Hashtbl_intf.S
  with type ('a, 'b) hashtbl = ('a, 'b) Core_kernel.Hashtbl.t
  with type key = t
include Core_kernel.Hashtbl_intf.S_plain
  with type ('a, 'b) hashtbl = ('a, 'b) Core_kernel.Hashtbl.t
  with type key = t
type key = ttype ('a, 'b) hashtbl = ('a, 'b) Core_kernel.Hashtbl.tval sexp_of_t : 
  ('b -> Ppx_sexp_conv_lib.Sexp.t) ->
  'b t ->
  Ppx_sexp_conv_lib.Sexp.ttype ('a, 'b) t_ = 'b ttype 'a key_ = keyval hashable : key Base.Hashable.tval create : 
  ('a key_, 'b, unit -> ('a, 'b) t_)
    Core_kernel.Hashtbl_intf.create_options_without_hashableval of_alist : 
  ('a key_,
    'b,
    ('a key_ * 'b) list ->
    [ `Ok of ('a, 'b) t_ | `Duplicate_key of 'a key_ ])
    Core_kernel.Hashtbl_intf.create_options_without_hashableval of_alist_report_all_dups : 
  ('a key_,
    'b,
    ('a key_ * 'b) list ->
    [ `Ok of ('a, 'b) t_ | `Duplicate_keys of 'a key_ list ])
    Core_kernel.Hashtbl_intf.create_options_without_hashableval of_alist_or_error : 
  ('a key_, 'b, ('a key_ * 'b) list -> ('a, 'b) t_ Base__.Or_error.t)
    Core_kernel.Hashtbl_intf.create_options_without_hashableval of_alist_exn : 
  ('a key_, 'b, ('a key_ * 'b) list -> ('a, 'b) t_)
    Core_kernel.Hashtbl_intf.create_options_without_hashableval of_alist_multi : 
  ('a key_, 'b list, ('a key_ * 'b) list -> ('a, 'b list) t_)
    Core_kernel.Hashtbl_intf.create_options_without_hashableval 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_kernel.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] val 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_kernel.Hashtbl_intf.create_options_without_hashable create_with_key ~get_key [x1,...,xn]
   = of_alist [get_key x1, x1; ...; get_key xn, xn] val create_with_key_or_error : 
  ('a key_,
    'r,
    get_key:('r -> 'a key_) ->
    'r list ->
    ('a, 'r) t_ Base__.Or_error.t)
    Core_kernel.Hashtbl_intf.create_options_without_hashableval create_with_key_exn : 
  ('a key_, 'r, get_key:('r -> 'a key_) -> 'r list -> ('a, 'r) t_)
    Core_kernel.Hashtbl_intf.create_options_without_hashableval group : 
  ('a key_,
    'b,
    get_key:('r -> 'a key_) ->
    get_data:('r -> 'b) ->
    combine:('b -> 'b -> 'b) ->
    'r list ->
    ('a, 'b) t_)
    Core_kernel.Hashtbl_intf.create_options_without_hashableinclude Base.Hashtbl.Accessors
  with type ('a, 'b) t := ('a, 'b) t_
  with type 'a key := 'a key_
Accessors
val clear : (_, _) t_ -> unitAttempting 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) -> unitIterates 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 = ()
val exists : (_, 'b) t_ -> f:('b -> bool) -> boolval for_all : (_, 'b) t_ -> f:('b -> bool) -> boolval count : (_, 'b) t_ -> f:('b -> bool) -> intval length : (_, _) t_ -> intval is_empty : (_, _) t_ -> booladd 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 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)]
Like map, but the function f takes both key and data as arguments.
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)]
Like filter_map, but the function f takes both key and data as arguments.
val partition_map : 
  ('a, 'b) t_ ->
  f:('b -> [ `Fst of 'c | `Snd of 'd ]) ->
  ('a, 'c) t_ * ('a, 'd) t_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 the function f 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 the rest.
Like partition_tf, but the function f 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, and otherwise assigns k the value returned by default ().
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) ->
  'cfind_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_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 (Some d1) Noneif- kin- h1maps to d1, and- h2does not have data for- k;
- f ~key:k None (Some d2)if- kin- h2maps to d2, and- h1does not have data for- k;
- f ~key:k (Some d1) (Some d2)otherwise, where- kin- h1maps to- d1and- kin- h2maps 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))]
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) ->
  unitval data : (_, 'b) t_ -> 'b listReturns 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) -> unitval map_inplace : (_, 'b) t_ -> f:('b -> 'b) -> unitmap_inplace t ~f applies f to all elements in t, transforming them in place.
val filter_map_inplace : (_, 'b) t_ -> f:('b -> 'b option) -> unitfilter_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.
remove_if_zero's default is false.
include Base.Hashtbl.Multi
  with type ('a, 'b) t := ('a, 'b) t_
  with type 'a key := 'a key_
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.
module Provide_of_sexp (Key : sig ... end) : sig ... endmodule Provide_bin_io (Key : sig ... end) : sig ... endinclude sig ... end
val t_of_sexp : 
  (Ppx_sexp_conv_lib.Sexp.t -> 'v_x__002_) ->
  Ppx_sexp_conv_lib.Sexp.t ->
  'v_x__002_ tinclude Bin_prot.Binable.S1 with type 'v t := 'v t
val bin_shape_t : Bin_prot.Shape.t -> Bin_prot.Shape.tval bin_size_t : ('a, 'a t) Bin_prot.Size.sizer1val bin_write_t : ('a, 'a t) Bin_prot.Write.writer1val bin_read_t : ('a, 'a t) Bin_prot.Read.reader1val __bin_read_t__ : ('a, int -> 'a t) Bin_prot.Read.reader1val bin_writer_t : ('a, 'a t) Bin_prot.Type_class.S1.writerval bin_reader_t : ('a, 'a t) Bin_prot.Type_class.S1.readerval bin_t : ('a, 'a t) Bin_prot.Type_class.S1.t