type C _;
function f(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(c : C a) returns () {
start:
assert f(c) == 7; // should not be provable
}
type ref;