* Update to ganache-cli v6.1.0 and truffle v4.1.0 * Update to stable version of ganache-cli * fix: update event emission warning - Fix event emission warnings for solidity 4.21 after truffle has been updated to use this version * fix pr review comments * update to truffle v4.1.5 * update package-lock * add additional emit keywords * update solidity-coverage to 0.4.15 * update to solium 1.1.6 * fix MerkleProof coverage analysis by testing through wrapper * change version pragma to ^0.4.21 * fix solium linting errors
34 lines
870 B
Solidity
34 lines
870 B
Solidity
pragma solidity ^0.4.21;
|
|
|
|
import "../token/ERC20/BasicToken.sol";
|
|
|
|
|
|
contract ERC223ContractInterface {
|
|
function tokenFallback(address _from, uint256 _value, bytes _data) external;
|
|
}
|
|
|
|
|
|
contract ERC223TokenMock is BasicToken {
|
|
|
|
function ERC223TokenMock(address initialAccount, uint256 initialBalance) public {
|
|
balances[initialAccount] = initialBalance;
|
|
totalSupply_ = 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;
|
|
assembly {
|
|
isContract := not(iszero(extcodesize(_to)))
|
|
}
|
|
if (isContract) {
|
|
ERC223ContractInterface receiver = ERC223ContractInterface(_to);
|
|
receiver.tokenFallback(msg.sender, _value, _data);
|
|
}
|
|
return true;
|
|
}
|
|
}
|