Monadic.Pc
module Pure_context = Engine.PFS
module Type_env = Engine.Type_env
module FOSolver = Engine.FOSolver
type t = {
pfs : Gillian.Symbolic.Pure_context.t;
gamma : Gillian.Symbolic.Type_env.t;
learned : Gil_syntax.Expr.Set.t;
learned_types : (string * Gillian.Gil_syntax.Type.t) list;
matching : bool;
}
val make :
pfs:Gillian.Symbolic.Pure_context.t ->
gamma:Gillian.Symbolic.Type_env.t ->
matching:bool ->
?learned:Gillian.Gil_syntax.Expr.t list ->
?learned_types:(string * Gillian.Gil_syntax.Type.t) list ->
unit ->
t
val init : ?matching:bool -> unit -> t
val empty : t
val pfs_to_pfs_and_gamma :
Gillian.Gil_syntax.Expr.t list ->
Gillian.Gil_syntax.Expr.t list * (string * Gillian.Gil_syntax.Type.t) list
val extend : t -> Gillian.Gil_syntax.Expr.t list -> t
val extend_types : t -> (string * Gillian.Gil_syntax.Type.t) list -> t
val pp : t Fmt.t
val of_gpc : Engine.Gpc.t -> t
val to_gpc : t -> Engine.Gpc.t