solidity/test/libsolidity/smtCheckerTests/file_level/recursion.sol

29 lines
617 B
Solidity
Raw Normal View History

2021-04-08 19:41:35 +00:00
function exp(uint base, uint exponent) pure returns (uint power) {
if (exponent == 0)
return 1;
power = exp(base, exponent / 2);
power *= power;
if (exponent & 1 == 1)
power *= base;
}
contract C {
function g(uint base, uint exponent) internal pure returns (uint) {
return exp(base, exponent);
}
function f() public pure {
// All of these should hold but the SMTChecker can't prove them.
2021-07-16 13:44:36 +00:00
// Disabled because of Spacer nondet
/*
2021-04-08 19:41:35 +00:00
assert(g(0, 0) == 1);
assert(g(0, 1) == 0);
assert(g(1, 0) == 1);
assert(g(2, 3) == 8);
assert(g(3, 10) == 59049);
2021-07-16 13:44:36 +00:00
*/
2021-04-08 19:41:35 +00:00
}
}
// ====
// SMTEngine: all
// ----