2021-04-29 13:35:57 +00:00
|
|
|
==== Source: Address.sol ====
|
|
|
|
pragma solidity ^0.8.0;
|
|
|
|
function s() pure {}
|
|
|
|
==== Source: ERC20.sol ====
|
|
|
|
pragma solidity ^0.8.0;
|
|
|
|
|
|
|
|
import "./Address.sol";
|
|
|
|
|
|
|
|
function sub(uint256 a, uint256 b) pure returns (uint256) {
|
|
|
|
return a - b;
|
|
|
|
}
|
|
|
|
|
|
|
|
contract ERC20 {
|
|
|
|
mapping (address => uint256) private _balances;
|
|
|
|
|
|
|
|
function transferFrom(uint256 amount) public view {
|
|
|
|
sub(_balances[msg.sender], amount);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// ====
|
|
|
|
// SMTEngine: all
|
|
|
|
// ----
|
2021-09-16 17:18:26 +00:00
|
|
|
// Warning 3944: (ERC20.sol:121-126): CHC: Underflow (resulting value less than 0) happens here.\nCounterexample:\n\namount = 1\n\nTransaction trace:\nERC20.constructor()\nERC20.transferFrom(1){ msg.sender: 0x52f6 }\n ERC20.sol:sub(0, 1) -- internal call
|