123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- pragma solidity ^0.5.2;
- import "../../introspection/IERC165.sol";
- /**
- * https://eips.ethereum.org/EIPS/eip-214#specification
- * From the 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 INTERFACE_ID_ERC165 = 0x01ffc9a7;
- /*
- * 0x01ffc9a7 ===
- * bytes4(keccak256('supportsInterface(bytes4)'))
- */
- /**
- * @dev a mapping of interface id to whether or not it's supported
- */
- mapping(bytes4 => bool) private _supportedInterfaces;
- /**
- * @dev A contract implementing SupportsInterfaceWithLookup
- * implement ERC165 itself
- */
- constructor () public {
- _registerInterface(INTERFACE_ID_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[] memory interfaceIds) public {
- for (uint256 i = 0; i < interfaceIds.length; i++) {
- _registerInterface(interfaceIds[i]);
- }
- }
- }
|