mirror of openzeppelin-contracts
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
pragma solidity ^0.4.24;
|
|
|
|
|
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 "./IERC165.sol";
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @title ERC165
|
|
|
|
* @author Matt Condon (@shrugs)
|
|
|
|
* @dev Implements ERC165 using a lookup table.
|
|
|
|
*/
|
|
|
|
contract ERC165 is IERC165 {
|
|
|
|
|
|
|
|
bytes4 private 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;
|
|
|
|
}
|
|
|
|
}
|