mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
23 lines
523 B
Solidity
23 lines
523 B
Solidity
pragma experimental SMTChecker;
|
|
|
|
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);
|
|
}
|
|
}
|
|
// ====
|
|
// SMTSolvers: z3
|