* rename ERC20 to IERC20 * move ERC20.sol to IERC20.sol * rename StandardToken to ERC20 * rename StandardTokenMock to ERC20Mock * move StandardToken.sol to ERC20.sol, likewise test and mock files * rename MintableToken to ERC20Mintable * move MintableToken.sol to ERC20Mintable.sol, likewise test and mock files * rename BurnableToken to ERC20Burnable * move BurnableToken.sol to ERC20Burnable.sol, likewise for related files * rename CappedToken to ERC20Capped * move CappedToken.sol to ERC20Capped.sol, likewise for related files * rename PausableToken to ERC20Pausable * move PausableToken.sol to ERC20Pausable.sol, likewise for related files * rename DetailedERC20 to ERC20Detailed * move DetailedERC20.sol to ERC20Detailed.sol, likewise for related files * rename ERC721 to IERC721, and likewise for other related interfaces * move ERC721.sol to IERC721.sol, likewise for other 721 interfaces * rename ERC721Token to ERC721 * move ERC721Token.sol to ERC721.sol, likewise for related files * rename ERC721BasicToken to ERC721Basic * move ERC721BasicToken.sol to ERC721Basic.sol, likewise for related files * rename ERC721PausableToken to ERC721Pausable * move ERC721PausableToken.sol to ERC721Pausable.sol * rename ERC165 to IERC165 * move ERC165.sol to IERC165.sol * amend comment that ERC20 is based on FirstBlood * fix comments mentioning IERC721Receiver
96 lines
1.9 KiB
Solidity
96 lines
1.9 KiB
Solidity
pragma solidity ^0.4.24;
|
|
|
|
import "../token/ERC20/IERC20.sol";
|
|
import "../token/ERC20/SafeERC20.sol";
|
|
|
|
|
|
contract ERC20FailingMock is IERC20 {
|
|
function totalSupply() public view returns (uint256) {
|
|
return 0;
|
|
}
|
|
|
|
function transfer(address, uint256) public returns (bool) {
|
|
return false;
|
|
}
|
|
|
|
function transferFrom(address, address, uint256) public returns (bool) {
|
|
return false;
|
|
}
|
|
|
|
function approve(address, uint256) public returns (bool) {
|
|
return false;
|
|
}
|
|
|
|
function balanceOf(address) public view returns (uint256) {
|
|
return 0;
|
|
}
|
|
|
|
function allowance(address, address) public view returns (uint256) {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
contract ERC20SucceedingMock is IERC20 {
|
|
function totalSupply() public view returns (uint256) {
|
|
return 0;
|
|
}
|
|
|
|
function transfer(address, uint256) public returns (bool) {
|
|
return true;
|
|
}
|
|
|
|
function transferFrom(address, address, uint256) public returns (bool) {
|
|
return true;
|
|
}
|
|
|
|
function approve(address, uint256) public returns (bool) {
|
|
return true;
|
|
}
|
|
|
|
function balanceOf(address) public view returns (uint256) {
|
|
return 0;
|
|
}
|
|
|
|
function allowance(address, address) public view returns (uint256) {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
contract SafeERC20Helper {
|
|
using SafeERC20 for IERC20;
|
|
|
|
IERC20 failing;
|
|
IERC20 succeeding;
|
|
|
|
constructor() public {
|
|
failing = new ERC20FailingMock();
|
|
succeeding = new ERC20SucceedingMock();
|
|
}
|
|
|
|
function doFailingTransfer() public {
|
|
failing.safeTransfer(address(0), 0);
|
|
}
|
|
|
|
function doFailingTransferFrom() public {
|
|
failing.safeTransferFrom(address(0), address(0), 0);
|
|
}
|
|
|
|
function doFailingApprove() public {
|
|
failing.safeApprove(address(0), 0);
|
|
}
|
|
|
|
function doSucceedingTransfer() public {
|
|
succeeding.safeTransfer(address(0), 0);
|
|
}
|
|
|
|
function doSucceedingTransferFrom() public {
|
|
succeeding.safeTransferFrom(address(0), address(0), 0);
|
|
}
|
|
|
|
function doSucceedingApprove() public {
|
|
succeeding.safeApprove(address(0), 0);
|
|
}
|
|
}
|