Frama-C API - Current_loc
A reference to the current location. If you are careful to set this to the current location then you can use some built-in logging functions that will print the location.
include State_builder.Ref with type data = Filepath.position * Filepath.position
include State_builder.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 = Filepath.position * Filepath.positionType of the referenced value.
val set : data -> unitChange the referenced value.
val get : unit -> dataGet the referenced value.
val add_hook_on_change : (data -> unit) -> unitAdd an hook which is applied each time (just after) the value of the state changes inside the current project.
val with_loc : data -> ('a -> 'b) -> 'a -> 'bwith_loc loc f x set the current location to loc, which can be used with Current_loc.get () or via the option ~current in Log functions. The old location is saved and set back after execution of f x. If f x raises an exception, it is caught and re-raised after setting the location to its old value.
val with_loc_opt : data option -> ('a -> 'b) -> 'a -> 'bSame behavior than with_loc but takes an location option. The location is set to loc for Some loc and unchanged otherwise.
module Operators : sig ... end