2020-09-28 10:09:40 +00:00
contract C {
function f ( uint256 d ) public pure {
uint x = addmod ( 1 , 2 , d ) ;
assert ( x < d ) ;
}
function g ( uint256 d ) public pure {
uint x = mulmod ( 1 , 2 , d ) ;
assert ( x < d ) ;
}
function h ( ) public pure returns ( uint256 ) {
uint x = mulmod ( 0 , 1 , 2 ) ;
uint y = mulmod ( 1 , 0 , 2 ) ;
assert ( x == y ) ;
uint z = addmod ( 0 , 1 , 2 ) ;
uint t = addmod ( 1 , 0 , 2 ) ;
assert ( z == t ) ;
}
}
2021-03-31 15:11:54 +00:00
// ====
// SMTEngine: all
2020-09-28 10:09:40 +00:00
// ----
2021-03-31 15:11:54 +00:00
// Warning 6321: (220-227): Unnamed return variable can remain unassigned. Add an explicit return with value to all non-reverting code paths or name the variable.
2023-02-09 16:07:13 +00:00
// Warning 4281: (61-76): CHC: Division by zero happens here.
// Warning 6328: (80-93): CHC: Assertion violation happens here.
// Warning 4281: (147-162): CHC: Division by zero happens here.
// Warning 6328: (166-179): CHC: Assertion violation happens here.
// Info 1391: CHC: 6 verification condition(s) proved safe! Enable the model checker option "show proved safe" to see all of them.