mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
22 lines
505 B
Solidity
22 lines
505 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);
|
||
|
}
|
||
|
}
|
||
|
// ----
|