This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.
<!DOCTYPE html>
<htmlxmlns="http://www.w3.org/1999/xhtml"><head><title>Biabduction__SymExec (infer.Biabduction__SymExec)</title><linkrel="stylesheet"href="../../odoc.css"/><metacharset="utf-8"/><metaname="generator"content="odoc 1.5.2"/><metaname="viewport"content="width=device-width,initial-scale=1.0"/><scriptsrc="../../highlight.pack.js"></script><script>hljs.initHighlightingOnLoad();</script></head><body><divclass="content"><header><nav><ahref="../index.html">Up</a>–<ahref="../index.html">infer</a>» Biabduction__SymExec</nav><h1>Module <code>Biabduction__SymExec</code></h1></header><aside><p>Symbolic Execution</p></aside><dl><dtclass="spec value"id="val-declare_locals_and_ret"><ahref="#val-declare_locals_and_ret"class="anchor"></a><code><spanclass="keyword">val</span> declare_locals_and_ret : <ahref="../IR/Tenv/index.html#type-t">IR.Tenv.t</a><span>-></span><ahref="../IR/Procdesc/index.html#type-t">IR.Procdesc.t</a><span>-></span><span><ahref="../Biabduction/Prop/index.html#type-normal">Biabduction.Prop.normal</a><ahref="../Biabduction/Prop/index.html#type-t">Biabduction.Prop.t</a></span><span>-></span><span><ahref="../Biabduction/Prop/index.html#type-normal">Biabduction.Prop.normal</a><ahref="../Biabduction/Prop/index.html#type-t">Biabduction.Prop.t</a></span></code></dt><dd><p>Symbolic execution of the declaration of locals and return value.</p></dd></dl><dl><dtclass="spec value"id="val-node"><ahref="#val-node"class="anchor"></a><code><spanclass="keyword">val</span> node : <span>(exn <span>-></span> unit)</span><span>-></span><span><ahref="../Biabduction/BiabductionSummary/index.html#type-t">Biabduction.BiabductionSummary.t</a><ahref="../Absint/InterproceduralAnalysis/index.html#type-t">Absint.InterproceduralAnalysis.t</a></span><span>-></span><ahref="../Absint/ProcCfg/Exceptional/index.html#type-t">Absint.ProcCfg.Exceptional.t</a><span>-></span><ahref="../Absint__ProcCfg/DefaultNode/index.html#type-t">Absint.ProcCfg.Exceptional.Node.t</a><span>-></span><ahref="../Biabduction/Paths/PathSet/index.html#type-t">Biabduction.Paths.PathSet.t</a><span>-></span><ahref="../Biabduction/Paths/PathSet/index.html#type-t">Biabduction.Paths.PathSet.t</a></code></dt><dd><p>Symbolic execution of the instructions of a node, lifted to sets of propositions.</p></dd></dl><dl><dtclass="spec value"id="val-instrs"><ahref="#val-instrs"class="anchor"></a><code><spanclass="keyword">val</span> instrs : <span>?⁠mask_errors:bool</span><span>-></span><span><ahref="../Biabduction/BiabductionSummary/index.html#type-t">Biabduction.BiabductionSummary.t</a><ahref="../Absint/InterproceduralAnalysis/index.html#type-t">Absint.InterproceduralAnalysis.t</a></span><span>-></span><ahref="../IR/Instrs/index.html#type-not_reversed_t">IR.Instrs.not_reversed_t</a><span>-></span><span><span>(<span><ahref="../Biabduction/Prop/index.html#type-normal">Biabduction.Prop.normal</a><ahref="../Biabduction/Prop/index.html#type-t">Biabduction.Prop.t</a></span> * <ahref="../Biabduction/Paths/Path/index.html#type-t">Biabduction.Paths.Path.t</a>)</span> list</span><span>-></span><span><span>(<span><ahref="../Biabduction/Prop/index.html#type-normal">Biabduction.Prop.normal</a><ahref="../Biabduction/Prop/index.html#type-t">Biabduction.Prop.t</a></span> * <ahref="../Biabduction/Paths/Path/index.html#type-t">Biabduction.Paths.Path.t</a>)</span> list</span></code></dt><dd><p>Symbolic execution of a sequence of instructions. If errors occur and <code>mask_errors</code> is true, just treat as skip.</p></dd></dl><dl><dtclass="spec value"id="val-diverge"><ahref="#val-diverge"class="anchor"></a><code><spanclass="keyword">val</span> diverge : <span><ahref="../Biabduction/Prop/index.html#type-normal">Biabduction.Prop.normal</a><ahref="../Biabduction/Prop/index.html#type-t">Biabduction.Prop.t</a></span><span>-></span><ahref="../Biabduction/Paths/Path/index.html#type-t">Biabduction.Paths.Path.t</a><span>-></span><span><span>(<span><ahref="../Biabduction/Prop/index.html#type-normal">Biabduction.Prop.normal</a><ahref="../Biabduction/Prop/index.html#type-t">Biabduction.Prop.t</a></span> * <ahref="../Biabduction/Paths/Path/index.html#type-t">Biabduction.Paths.Path.t</a>)</span> list</span></code></dt><dd><p>Symbolic execution of the divergent pure computation.</p></dd></dl><dl><dtclass="spec value"id="val-proc_call"><ahref="#val-proc_call"class="anchor"></a><code><spanclass="keyword">val</span> proc_call : <span>(<ahref="../IR/Procdesc/index.html#type-t">IR.Procdesc.t</a> * <ahref="../Biabduction/BiabductionSummary/index.html#type-t">Biabduction.BiabductionSummary.t</a>)</span><span>-></span><ahref="../Biabduction/Builtin/index.html#type-t">Biabduction.Builtin.t</a></code></dt><dtclass="spec value"id="val-unknown_or_scan_call"><ahref="#val-unknown_or_scan_call"class="anchor"></a><code><spanclass="keyword">val</span> unknown_or_scan_call : <span>is_scan:bool</span><span>-></span><span>reason:string</span><span>-></span><ahref="../IR/Typ/index.html#type-t">IR.Typ.t</a><span>-></span><ahref="../IR/Annot/Item/index.html#type-t">IR.Annot.Item.t</a><span>-></span><ahref="../Biabduction/Builtin/index.html#type-t">Biabduction.Builtin.t</a></code></dt><dtclass="spec value"id="val-check_variadic_sentinel"><ahref="#val-check_variadic_sentinel"class="anchor"></a><code><spanclass="keyword">val</span> check_variadic_sentinel : <span>?⁠fails_on_nil:bool</span><span>-></span> int <span>-></span><span>(int * int)</span><span>-></span><ahref="../Biabduction/Builtin/index.html#type-t">Biabduction.Builtin.t</a></code></dt><dtclass="spec value"id="val-check_arith_norm_exp"><ahref="#val-check_arith_norm_exp"class="anchor"></a><code><spanclass="keyword">val</span> check_arith_norm_exp : <span><ahref="../Biabduction/BiabductionSummary/index.html#type-t">Biabduction.BiabductionSummary.t</a><ahref="../Absint/InterproceduralAnalysis/index.html#type-t">Absint.InterproceduralAnalysis.t</a></span><span>-></span><ahref="../IR/Exp/index.html#type-t">IR.Exp.t</a><span>-></span><span><ahref="../Biabduction/Prop/index.html#type-normal">Biabduction.Prop.normal</a><ahref="../Biabduction/Prop/index.html#type-t">Biabduction.Prop.t</a></span><span>-></span><ahref="../IR/Exp/index.html#type-t">IR.Exp.t</a> * <span><ahref="../Biabduction/Prop/index.html#type-normal">Biabduction.Prop.normal</a><ahref="../Biabduction/Prop/index.html#type-t">Biabduction.Prop.t</a></span></code></dt><dd><p>Check for arithmetic problems and normalize an expression.</p></dd></dl><dl><dtclass="spec value"id="val-prune"><ahref="#val-prune"class="anchor"></a><code><spanclass="keyword">val</span> prune : <ahref="../IR/Tenv/index.html#type-t">IR.Tenv.t</a><span>-></span><span>positive:bool</span><span>-></span><ahref="../IR/Exp/index.html#type-t">IR.Exp.t</a><span>-></span><span><ahref="../Biabduction/Prop/index.html#type-normal">Biabduction.Prop.normal</a><ahref="../Biabduction/Prop/index.html#type-t">Biabduction.Prop.t</a></span><span>-></span><ahref="../Biabduction/Propset/index.html#type-t">Biabduction.Propset.t</a></code></dt></dl></div></body></html>