Frama-C API - Caml_weak_hashtbl
 Build a weak hashtbl over a datatype Data by using Weak.Make provided by the OCaml standard library. Note that the table is not saved on disk.
Parameters
module Data : Datatype.Smodule _ : Info_with_sizeSignature
Hashtbl are a standard computation. BUT it is INCORRECT to use projectified hashtables if keys have a custom rehash function (see Datatype.Make_input.rehash)
include S
val self : State.tThe kind of the registered state.
val mark_as_computed : ?project:Project.t -> unit -> unitIndicate that the registered state will not change again for the given project (default is current ()).
val is_computed : ?project:Project.t -> unit -> boolReturns true iff the registered state will not change again for the given project (default is current ()).
Exportation of some inputs (easier use of State_builder.Register).
module Datatype : Datatype.Sval add_hook_on_update : (Datatype.t -> unit) -> unitAdd an hook which is applied each time (just before) the project library changes the local value of the state.
val howto_marshal : (Datatype.t -> 'a) -> ('a -> Datatype.t) -> unithowto_marshal marshal unmarshal registers a custom couple of functions (marshal, unmarshal) to be used for serialization. Default functions are identities. In particular, this function must be used if Datatype.t is not marshallable and do_not_save is not called.
type data = Data.tmerge x returns an instance of x found in the table if any, or else adds x and return x.
val add : data -> unitadd x adds x to the table. If there is already an instance of x, it is unspecified which one will be returned by subsequent calls to find and merge.
val iter : (data -> unit) -> unitval fold : (data -> 'a -> 'a) -> 'a -> 'aval mem : data -> boolmem x returns true if there is at least one instance of x in the table, false otherwise.
val remove : data -> unitremove x removes from the table one instance of x. Does nothing if there is no instance of x.
