type C a;
function f(C a) returns (int);
//axiom (forall x:C a :: {f(x)} (exists y:C a :: f(y) == 42));
function g(C a) returns (C a);
axiom (forall x:C a :: f(g(x)) == 42);
procedure P() returns () {
var z : C int;
assume g(z) == z;
assert (exists x : C int :: f(x) == 42);
}