void abort() { }; extern int __VERIFIER_nondet_int(); /*@ requires ((\old(cond) != 0)) && (cond != 0); ensures ((\old(cond) != 0)) && (1); @*/ void __VERIFIER_assert(int cond) { if (!(cond)) { ERROR: {/*@ assert(0); */;abort();} } return; } int main() { int A[1024]; int i; /*@ loop invariant ((i < 1025)); @*/ for (i = 0; i < 1024; i++) { A[i] = __VERIFIER_nondet_int(); } /*@ loop invariant ((i < 1024)); @*/ for (i = 0; A[i] != 0; i++) { if (i >= 1024-1) { break; } } __VERIFIER_assert(i <= 1024); }