interpret_intf.ml1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37(***************************************************************************) (* This file is part of the third-party OCaml library `smtml`. *) (* Copyright (C) 2023-2024 formalsec *) (* *) (* This program is free software: you can redistribute it and/or modify *) (* it under the terms of the GNU General Public License as published by *) (* the Free Software Foundation, either version 3 of the License, or *) (* (at your option) any later version. *) (* *) (* This program is distributed in the hope that it will be useful, *) (* but WITHOUT ANY WARRANTY; without even the implied warranty of *) (* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *) (* GNU General Public License for more details. *) (* *) (* You should have received a copy of the GNU General Public License *) (* along with this program. If not, see <https://www.gnu.org/licenses/>. *) (***************************************************************************) type 'a state = { stmts : Ast.script ; smap : (string, Ty.t) Hashtbl.t ; pc : Expr.t list ; solver : 'a } module type S = sig type solver type exec_state val start : ?state:exec_state -> Ast.script -> exec_state end module type Intf = sig module Make (Solver : Solver_intf.S) : S with type solver = Solver.t and type exec_state = Solver.t state end