SVal.SSubst
type vt = Gillian.Symbolic.Values.t
Type of GIL values
val init : (Gillian.Gil_syntax.Var.t * vt) list -> t
Substitution constructor, with a list of bindings of the form (variable, value)
val is_empty : t -> bool
Is the substitution empty?
val clear : t -> unit
Reset substitution
val domain :
t ->
(Gillian.Gil_syntax.Var.t -> bool) option ->
Gillian.Gil_syntax.Var.Set.t
Domain of the substitution
val get : t -> Gillian.Gil_syntax.Var.t -> vt option
Substitution lookup
val add : t -> Gillian.Gil_syntax.Var.t -> vt -> unit
Substitution incremental update
val put : t -> Gillian.Gil_syntax.Var.t -> vt -> unit
Substitution update
val mem : t -> Gillian.Gil_syntax.Var.t -> bool
Substitution membership
val extend : t -> (Gillian.Gil_syntax.Var.t * vt) list -> unit
Substitution extension with a list of bindings
val filter : t -> (Gillian.Gil_syntax.Var.t -> vt -> bool) -> t
Substitution filter
val projection : t -> Gillian.Gil_syntax.Var.Set.t -> t
Substitution variable filter
val iter : t -> (Gillian.Gil_syntax.Var.t -> vt -> unit) -> unit
Substitution iterator
val fold : t -> (Gillian.Gil_syntax.Var.t -> vt -> 'a -> 'a) -> 'a -> 'a
Substitution fold
val pp : Stdlib.Format.formatter -> t -> unit
Pretty Printer
val full_pp : Stdlib.Format.formatter -> t -> unit
Full pretty Printer
val filter_in_place :
t ->
(Gillian.Gil_syntax.Var.t -> vt -> vt option) ->
unit
val to_list : t -> (Gillian.Gil_syntax.Var.t * vt) list
Convert substitution to list
val subst_in_expr :
t ->
partial:bool ->
Gillian.Gil_syntax.Expr.t ->
Gillian.Gil_syntax.Expr.t
Substitution inside a logical expression
val subst_in_expr_opt :
t ->
Gillian.Gil_syntax.Expr.t ->
Gillian.Gil_syntax.Expr.t option
Optional substitution inside a logical expression
val substitute_asrt :
t ->
partial:bool ->
Gillian.Gil_syntax.Asrt.t ->
Gillian.Gil_syntax.Asrt.t
val substitute_slcmd :
t ->
partial:bool ->
Gillian.Gil_syntax.SLCmd.t ->
Gillian.Gil_syntax.SLCmd.t
val substitute_lcmd :
t ->
partial:bool ->
Gillian.Gil_syntax.LCmd.t ->
Gillian.Gil_syntax.LCmd.t