blob: 3f055c1d47fe118b5c2133879439ac9b00455ee5 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
type T;
function f(x : [T][int]int) returns (int);
axiom (forall x:[T][int]int :: {f(x)}
(exists t:T :: x[t][13] == 42) ==> f(x) == 5);
procedure P() returns () {
var x : [T][int]int, t : T;
x[t] := x[t][13 := 42];
assert f(x) == 5;
}
type name;
function Field(int) returns (name);
function Unified([name][int]int) returns ([int]int);
axiom(forall M:[name][int]int, x:int, y:int :: {Unified(M[Field(x) := M[Field(x)][x := y]])}
Unified(M[Field(x) := M[Field(x)][x := y]]) == Unified(M)[x := y]);
|