2019-08-20 13:03:45 +00:00
|
|
|
contract C
|
|
|
|
{
|
|
|
|
function f(uint x, bool b) public pure {
|
|
|
|
require(x < 100);
|
|
|
|
while (x < 10) {
|
|
|
|
if (b)
|
|
|
|
x = x + 1;
|
|
|
|
else
|
|
|
|
x = 0;
|
|
|
|
}
|
|
|
|
// CHC proves it safe because
|
|
|
|
// 1- if it doesn't go in the loop in the first place, x >= 10
|
|
|
|
// 2- if it goes in the loop and b == true, x increases until >= 10
|
|
|
|
// 3- if it goes in the loop and b == false, it's an infinite loop, therefore
|
|
|
|
// the assertion and the error are unreachable.
|
|
|
|
assert(x > 0);
|
|
|
|
}
|
|
|
|
}
|
2019-12-04 15:39:34 +00:00
|
|
|
// ====
|
2021-03-31 15:11:54 +00:00
|
|
|
// SMTEngine: all
|
2019-12-04 15:39:34 +00:00
|
|
|
// SMTSolvers: z3
|
2021-03-12 23:02:36 +00:00
|
|
|
// ----
|
2023-02-09 16:07:13 +00:00
|
|
|
// Info 1391: CHC: 2 verification condition(s) proved safe! Enable the model checker option "show proved safe" to see all of them.
|