* 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
70 lines
1.8 KiB
Solidity
70 lines
1.8 KiB
Solidity
pragma solidity ^0.4.24;
|
|
|
|
import "../../introspection/IERC165.sol";
|
|
|
|
|
|
/**
|
|
* https://github.com/ethereum/EIPs/blob/master/EIPS/eip-214.md#specification
|
|
* > Any attempts to make state-changing operations inside an execution instance with STATIC set to true will instead throw an exception.
|
|
* > These operations include [...], LOG0, LOG1, LOG2, [...]
|
|
*
|
|
* therefore, because this contract is staticcall'd we need to not emit events (which is how solidity-coverage works)
|
|
* solidity-coverage ignores the /mocks folder, so we duplicate its implementation here to avoid instrumenting it
|
|
*/
|
|
contract SupportsInterfaceWithLookupMock is IERC165 {
|
|
|
|
bytes4 public constant InterfaceId_ERC165 = 0x01ffc9a7;
|
|
/**
|
|
* 0x01ffc9a7 ===
|
|
* bytes4(keccak256('supportsInterface(bytes4)'))
|
|
*/
|
|
|
|
/**
|
|
* @dev a mapping of interface id to whether or not it's supported
|
|
*/
|
|
mapping(bytes4 => bool) internal supportedInterfaces;
|
|
|
|
/**
|
|
* @dev A contract implementing SupportsInterfaceWithLookup
|
|
* implement ERC165 itself
|
|
*/
|
|
constructor()
|
|
public
|
|
{
|
|
_registerInterface(InterfaceId_ERC165);
|
|
}
|
|
|
|
/**
|
|
* @dev implement supportsInterface(bytes4) using a lookup table
|
|
*/
|
|
function supportsInterface(bytes4 _interfaceId)
|
|
external
|
|
view
|
|
returns (bool)
|
|
{
|
|
return supportedInterfaces[_interfaceId];
|
|
}
|
|
|
|
/**
|
|
* @dev private method for registering an interface
|
|
*/
|
|
function _registerInterface(bytes4 _interfaceId)
|
|
internal
|
|
{
|
|
require(_interfaceId != 0xffffffff);
|
|
supportedInterfaces[_interfaceId] = true;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
contract ERC165InterfacesSupported is SupportsInterfaceWithLookupMock {
|
|
constructor (bytes4[] _interfaceIds)
|
|
public
|
|
{
|
|
for (uint256 i = 0; i < _interfaceIds.length; i++) {
|
|
_registerInterface(_interfaceIds[i]);
|
|
}
|
|
}
|
|
}
|