mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
31 lines
996 B
Solidity
31 lines
996 B
Solidity
contract C {
|
|
function f(uint32 a, uint32 b) internal pure returns (uint256) {
|
|
return a >> b;
|
|
}
|
|
function t() public pure {
|
|
assert(f(0x4266, 0) == 0x4266);
|
|
// Fails because the above is true.
|
|
assert(f(0x4266, 0) == 0x426);
|
|
|
|
assert(f(0x4266, 8) == 0x42);
|
|
// Fails because the above is true.
|
|
assert(f(0x4266, 8) == 0x420);
|
|
|
|
assert(f(0x4266, 0x10) == 0);
|
|
// Fails because the above is true.
|
|
assert(f(0x4266, 0x10) == 255);
|
|
|
|
assert(f(0x4266, 0x11) == 0);
|
|
// Fails because the above is true.
|
|
assert(f(0x4266, 0x11) == 255);
|
|
}
|
|
}
|
|
// ====
|
|
// SMTEngine: all
|
|
// ----
|
|
// Warning 6328: (213-242): CHC: Assertion violation happens here.
|
|
// Warning 6328: (317-346): CHC: Assertion violation happens here.
|
|
// Warning 6328: (421-451): CHC: Assertion violation happens here.
|
|
// Warning 6328: (526-556): CHC: Assertion violation happens here.
|
|
// Info 1391: CHC: 4 verification condition(s) proved safe! Enable the model checker option "show proved safe" to see all of them.
|