Wp.SigsSourceCommon Types and Signatures
type equation = | Set of Lang.F.term * Lang.F.termSet(a,b) is a := b.
| Assert of Lang.F.predOriented equality or arbitrary relation
Access conditions
Abstract location or concrete value
type 'a rloc = | Rloc of Ctypes.c_object * 'a| Rrange of 'a * Ctypes.c_object * Lang.F.term option * Lang.F.term optionContiguous set of locations
type 'a sloc = | Sloc of 'a| Sarray of 'a * Ctypes.c_object * intfull sized range (optimized assigns)
*)| Srange of 'a * Ctypes.c_object * Lang.F.term option * Lang.F.term option| Sdescr of Lang.F.var list * 'a * Lang.F.predStructured set of locations
Typed set of locations
type 'a logic = | Vexp of Lang.F.term| Vloc of 'a| Vset of Wp__.Vset.vset list| Lset of 'a sloc listLogical values, locations, or sets of
Scope management for locals and formals
Container for the returned value of a function
Polarity of predicate compilation
Frame Conditions. Consider a function phi(m) over memory m, we want memories m1,m2 and condition p such that p(m1,m2) -> phi(m1) = phi(m2).
name used for generating lemmatriggers for the lemmaconditions for the frame lemma to holdmem1,mem2 to two memories for which the lemma holdsIt is sometimes possible to reverse memory models abstractions into ACSL left-values via the definitions below.
and s_host = | Mvar of Frama_c_kernel.Cil_types.varinfoVariable
*)| Mmem of Lang.F.termPointed value
*)| Mval of s_lvalPointed value of another abstract left-value
*)type mval = | MtermNot a state-related value
*)| Maddr of s_lvalThe value is the address of an l-value in current memory
*)| Mlval of s_lval * Lang.datakindThe value is the value of an l-value in current memory
*)| Mchunk of string * Lang.datakindThe value is an abstract memory chunk (description)
*)Reversed abstract value
type update = | Mstore of s_lval * Lang.F.termAn update of the ACSL left-value with the given value
*)Reversed update
Compiler for C expressions
Compiler for ACSL expressions
Compiler for Performing Assigns