* 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
39 lines
1.4 KiB
Solidity
39 lines
1.4 KiB
Solidity
pragma solidity ^0.4.24;
|
|
|
|
|
|
/**
|
|
* @title ERC721 token receiver interface
|
|
* @dev Interface for any contract that wants to support safeTransfers
|
|
* from ERC721 asset contracts.
|
|
*/
|
|
contract IERC721Receiver {
|
|
/**
|
|
* @dev Magic value to be returned upon successful reception of an NFT
|
|
* Equals to `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`,
|
|
* which can be also obtained as `IERC721Receiver(0).onERC721Received.selector`
|
|
*/
|
|
bytes4 internal constant ERC721_RECEIVED = 0x150b7a02;
|
|
|
|
/**
|
|
* @notice Handle the receipt of an NFT
|
|
* @dev The ERC721 smart contract calls this function on the recipient
|
|
* after a `safetransfer`. This function MAY throw to revert and reject the
|
|
* transfer. Return of other than the magic value MUST result in the
|
|
* transaction being reverted.
|
|
* Note: the contract address is always the message sender.
|
|
* @param _operator The address which called `safeTransferFrom` function
|
|
* @param _from The address which previously owned the token
|
|
* @param _tokenId The NFT identifier which is being transferred
|
|
* @param _data Additional data with no specified format
|
|
* @return `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`
|
|
*/
|
|
function onERC721Received(
|
|
address _operator,
|
|
address _from,
|
|
uint256 _tokenId,
|
|
bytes _data
|
|
)
|
|
public
|
|
returns(bytes4);
|
|
}
|