blob: 88647e6bfacc39a587e2c6832d7ae416c8f7b3c1 (
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
25
26
27
28
29
30
|
type C _;
function f<a>(C a) returns (int);
axiom (forall x : C int :: f(x) == 3);
axiom (forall x : C bool :: f(x) == 7);
procedure P() returns () {
var a : C int, b : C bool, c : C ref;
start:
assert f(a) == 3;
assert f(b) == 7;
assert f(b) == 8; // should not be provable
}
procedure Q() returns () {
var c : C ref;
start:
assert f(c) == 7; // should not be provable
}
procedure R<a>(c : C a) returns () {
start:
assert f(c) == 7; // should not be provable
}
type ref;
|