blob: 08967891ab5e78c60e6bc501fb5c292790be0c10 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
type Box;
function box<a>(a) returns (Box);
function unbox<a>(Box) returns (a);
axiom (forall<a> x:a :: unbox(box(x)) == x);
var b1: Box;
var b2: Box;
var b3: Box;
procedure P() returns ()
modifies b1, b2, b3; {
b1 := box(13);
b2 := box(true);
b3 := box(b1);
assert unbox(b1) == 13 && unbox(b2) == true && unbox(unbox(b3)) == 13;
assert unbox(b1) == true; // error
}
|