|
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
|
|
|
|
pragma solidity ^0.6.0;
|
|
|
|
|
Rename ERC interfaces to I prefix (#1252)
* 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
7 years ago
|
|
|
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
|
|
|
|
*/
|
Rename ERC interfaces to I prefix (#1252)
* 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
7 years ago
|
|
|
contract SupportsInterfaceWithLookupMock is IERC165 {
|
|
|
|
/*
|
|
|
|
* bytes4(keccak256('supportsInterface(bytes4)')) == 0x01ffc9a7
|
|
|
|
*/
|
|
|
|
bytes4 public constant INTERFACE_ID_ERC165 = 0x01ffc9a7;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @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) public view override returns (bool) {
|
|
|
|
return _supportedInterfaces[interfaceId];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @dev Private method for registering an interface.
|
|
|
|
*/
|
|
|
|
function _registerInterface(bytes4 interfaceId) internal {
|
|
|
|
require(interfaceId != 0xffffffff, "ERC165InterfacesSupported: invalid interface id");
|
|
|
|
_supportedInterfaces[interfaceId] = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
contract ERC165InterfacesSupported is SupportsInterfaceWithLookupMock {
|
|
|
|
constructor (bytes4[] memory interfaceIds) public {
|
|
|
|
for (uint256 i = 0; i < interfaceIds.length; i++) {
|
|
|
|
_registerInterface(interfaceIds[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|