* 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
34 lines
872 B
Solidity
34 lines
872 B
Solidity
pragma solidity ^0.4.24;
|
|
|
|
import "../token/ERC20/ERC20.sol";
|
|
|
|
|
|
contract ERC223ContractInterface {
|
|
function tokenFallback(address _from, uint256 _value, bytes _data) external;
|
|
}
|
|
|
|
|
|
contract ERC223TokenMock is ERC20 {
|
|
|
|
constructor(address _initialAccount, uint256 _initialBalance) public {
|
|
_mint(_initialAccount, _initialBalance);
|
|
}
|
|
|
|
// ERC223 compatible transfer function (except the name)
|
|
function transferERC223(address _to, uint256 _value, bytes _data) public
|
|
returns (bool success)
|
|
{
|
|
transfer(_to, _value);
|
|
bool isContract = false;
|
|
// solium-disable-next-line security/no-inline-assembly
|
|
assembly {
|
|
isContract := not(iszero(extcodesize(_to)))
|
|
}
|
|
if (isContract) {
|
|
ERC223ContractInterface receiver = ERC223ContractInterface(_to);
|
|
receiver.tokenFallback(msg.sender, _value, _data);
|
|
}
|
|
return true;
|
|
}
|
|
}
|