// Source: Antoine Miné: "Tutorial on static inference of numeric invariants by abstract interpretation", FTPL 2017. // Example 4.6. #include extern void abort(void); void reach_error() { assert(0); } void __VERIFIER_assert(int cond) { if(!(cond)) { ERROR: {reach_error();abort();} } } int main() { int x = 40; while (x != 0) { __VERIFIER_assert(x <= 40); x--; __VERIFIER_assert(x >= 0); } __VERIFIER_assert(x == 0); return 0; }