Module IR.HilInstr
type call
=
|
Direct of Procname.t
|
Indirect of HilExp.t
type of a procedure call; either direct or via function pointer
type t
=
|
Assign of HilExp.AccessExpression.t * HilExp.t * IBase.Location.t
LHS access expression, RHS expression
|
Assume of HilExp.t * [ `Then | `Else ] * Sil.if_kind * IBase.Location.t
Assumed expression, true_branch boolean, source of the assume (conditional, ternary, etc.)
|
Call of AccessPath.base * call * HilExp.t list * CallFlags.t * IBase.Location.t
Var to hold the return, call expression, formals
|
Metadata of Sil.instr_metadata
type translation
=
|
Instr of t
HIL instruction to execute
|
Bind of Var.t * HilExp.AccessExpression.t
add binding to identifier map
Result of translating an SIL instruction
val of_sil : include_array_indexes:bool -> f_resolve_id:(Var.t -> HilExp.AccessExpression.t option) -> Sil.instr -> translation
convert an SIL instruction into an HIL instruction. The
f_resolve_id
function should map an SSA temporary variable to the access path it represents. Evaluating the HIL instruction should produce the same result as evaluating the SIL instruction and replacing the temporary variables usingf_resolve_id
.