Frama-C API - Lval_hashtbl
Parameters
module Data : Datatype.S
module _ : State_builder.Info_with_size
Signature
Hashtbl are a standard computation. BUT that is INCORRECT to use projectified hashtables if keys have a custom rehash
function (see Datatype.Make_input.rehash
)
include State_builder.S
val self : State.t
The kind of the registered state.
val mark_as_computed : ?project:Project.t -> unit -> unit
Indicate that the registered state will not change again for the given project (default is current ()
).
val is_computed : ?project:Project.t -> unit -> bool
Returns 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.S
val add_hook_on_update : (Datatype.t -> unit) -> unit
Add 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) -> unit
howto_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 key = Cil_types.lval
type data = Data.t
Memoization. Compute on need the data associated to a given key using the given function. If the data is already computed, it is possible to change with change
.
Return the current binding of the given key, or None if no such binding exists.
val mem : key -> bool
val remove : key -> unit
val add_hook_on_change : ((key, data) State_builder.hashtbl_event -> unit) -> unit
Add an hook which is applied each time (just after) a (key,value) pair in the hashtable changes inside the current project.