Squashed commit of the following:
commit fcf35eb806100de300bd9803ce3150dde1ecc424
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Wed Jul 17 17:16:04 2019 -0300
remove all docsite dependency
commit eeaee9a9d43d70704f6ab17b5126ddbd52b93a50
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Wed Jul 17 17:15:23 2019 -0300
update solidity-docgen
commit f021ff951829ea0c155186749819403c6b76e803
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Wed Jul 17 17:05:06 2019 -0300
update docsite script for new setup
commit ff887699d381cfbbe3acf1f1c0de8e22b58480f3
Merge: c938aa1d 84f85a41
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Wed Jul 17 16:46:46 2019 -0300
Merge branch 'master' into antora
commit c938aa1d9ed05ac83a34e2cebd8353f8331ad6d6
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Tue Jul 16 18:24:29 2019 -0300
make component name shorter
commit 5bbd6931e02cbbd8864c82655ad0f390ceead5f3
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Wed Jul 10 20:16:17 2019 -0300
add all info to docs templates
commit 39682c4515d7cf0f0368ed557f50d2709174208a
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Wed Jul 10 20:13:49 2019 -0300
fix npm docsite script
commit 7ae46bd4a0437abf66150d54d05adf46e3de2cab
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Wed Jul 10 18:48:05 2019 -0300
convert inline docs to asciidoc
commit cfdfd3dee4b4bf582fde22c8cb6e17a603d6e0c8
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Wed Jul 10 17:34:52 2019 -0300
add missing contract names in readmes
commit 15b6a2f9bfb546cf1d3bf4f104278b118bf1b3f4
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Wed Jul 10 17:16:47 2019 -0300
fix script path
commit 80d82b909f9460d1450d401f00b3f309da506b29
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Wed Jul 10 17:13:53 2019 -0300
update version of solidity-docgen
commit a870b6c607b9c2d0012f8a60a4ed1a1c8b7e8ebd
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Wed Jul 10 17:03:53 2019 -0300
add nav generation of api ref
commit 069cff4a25b83752650b54b86d85608c2f547e5e
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Wed Jul 10 16:32:14 2019 -0300
initial migration to asciidoc and new docgen version
commit 55216eed0a6551da913c8d1da4b2a0d0d3faa1a8
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Tue Jun 25 20:39:35 2019 -0300
add basic api doc example
commit 0cbe50ce2173b6d1d9a698329d91220f58822a53
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Tue Jun 25 19:31:31 2019 -0300
add sidebars
commit 256fc942845307258ac9dc25aace48117fa10f79
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Tue Jun 25 15:22:38 2019 -0300
add page titles
commit f4d0effa70e1fc0662729863e8ee72a8821bc458
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Tue Jun 25 15:19:41 2019 -0300
add contracts index file
commit b73b06359979f7d933df7f2b283c50cb1c31b2a0
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Tue Jun 25 15:14:52 2019 -0300
fix header levels
commit fb57d9b820f09a1b7c04eed1a205be0e45866cac
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Tue Jun 25 15:11:47 2019 -0300
switch format to preferred asciidoctor format
commit 032181d8804137332c71534753929d080a31a71f
Author: Francisco Giordano <frangio.1@gmail.com>
Date: Tue Jun 25 15:05:38 2019 -0300
initialize antora component and convert docs to asciidoc
110 lines
4.6 KiB
Solidity
110 lines
4.6 KiB
Solidity
pragma solidity ^0.5.0;
|
|
|
|
/**
|
|
* @dev Interface of the global ERC1820 Registry, as defined in the
|
|
* https://eips.ethereum.org/EIPS/eip-1820[EIP]. Accounts may register
|
|
* implementers for interfaces in this registry, as well as query support.
|
|
*
|
|
* Implementers may be shared by multiple accounts, and can also implement more
|
|
* than a single interface for each account. Contracts can implement interfaces
|
|
* for themselves, but externally-owned accounts (EOA) must delegate this to a
|
|
* contract.
|
|
*
|
|
* {IERC165} interfaces can also be queried via the registry.
|
|
*
|
|
* For an in-depth explanation and source code analysis, see the EIP text.
|
|
*/
|
|
interface IERC1820Registry {
|
|
/**
|
|
* @dev Sets `newManager` as the manager for `account`. A manager of an
|
|
* account is able to set interface implementers for it.
|
|
*
|
|
* By default, each account is its own manager. Passing a value of `0x0` in
|
|
* `newManager` will reset the manager to this initial state.
|
|
*
|
|
* Emits a {ManagerChanged} event.
|
|
*
|
|
* Requirements:
|
|
*
|
|
* - the caller must be the current manager for `account`.
|
|
*/
|
|
function setManager(address account, address newManager) external;
|
|
|
|
/**
|
|
* @dev Returns the manager for `account`.
|
|
*
|
|
* See {setManager}.
|
|
*/
|
|
function getManager(address account) external view returns (address);
|
|
|
|
/**
|
|
* @dev Sets the `implementer` contract as `account`'s implementer for
|
|
* `interfaceHash`.
|
|
*
|
|
* `account` being the zero address is an alias for the caller's address.
|
|
* The zero address can also be used in `implementer` to remove an old one.
|
|
*
|
|
* See {interfaceHash} to learn how these are created.
|
|
*
|
|
* Emits an {InterfaceImplementerSet} event.
|
|
*
|
|
* Requirements:
|
|
*
|
|
* - the caller must be the current manager for `account`.
|
|
* - `interfaceHash` must not be an {IERC165} interface id (i.e. it must not
|
|
* end in 28 zeroes).
|
|
* - `implementer` must implement {IERC1820Implementer} and return true when
|
|
* queried for support, unless `implementer` is the caller. See
|
|
* {IERC1820Implementer-canImplementInterfaceForAddress}.
|
|
*/
|
|
function setInterfaceImplementer(address account, bytes32 interfaceHash, address implementer) external;
|
|
|
|
/**
|
|
* @dev Returns the implementer of `interfaceHash` for `account`. If no such
|
|
* implementer is registered, returns the zero address.
|
|
*
|
|
* If `interfaceHash` is an {IERC165} interface id (i.e. it ends with 28
|
|
* zeroes), `account` will be queried for support of it.
|
|
*
|
|
* `account` being the zero address is an alias for the caller's address.
|
|
*/
|
|
function getInterfaceImplementer(address account, bytes32 interfaceHash) external view returns (address);
|
|
|
|
/**
|
|
* @dev Returns the interface hash for an `interfaceName`, as defined in the
|
|
* corresponding
|
|
* https://eips.ethereum.org/EIPS/eip-1820#interface-name[section of the EIP].
|
|
*/
|
|
function interfaceHash(string calldata interfaceName) external pure returns (bytes32);
|
|
|
|
/**
|
|
* @notice Updates the cache with whether the contract implements an ERC165 interface or not.
|
|
* @param account Address of the contract for which to update the cache.
|
|
* @param interfaceId ERC165 interface for which to update the cache.
|
|
*/
|
|
function updateERC165Cache(address account, bytes4 interfaceId) external;
|
|
|
|
/**
|
|
* @notice Checks whether a contract implements an ERC165 interface or not.
|
|
* If the result is not cached a direct lookup on the contract address is performed.
|
|
* If the result is not cached or the cached value is out-of-date, the cache MUST be updated manually by calling
|
|
* {updateERC165Cache} with the contract address.
|
|
* @param account Address of the contract to check.
|
|
* @param interfaceId ERC165 interface to check.
|
|
* @return True if `account` implements `interfaceId`, false otherwise.
|
|
*/
|
|
function implementsERC165Interface(address account, bytes4 interfaceId) external view returns (bool);
|
|
|
|
/**
|
|
* @notice Checks whether a contract implements an ERC165 interface or not without using nor updating the cache.
|
|
* @param account Address of the contract to check.
|
|
* @param interfaceId ERC165 interface to check.
|
|
* @return True if `account` implements `interfaceId`, false otherwise.
|
|
*/
|
|
function implementsERC165InterfaceNoCache(address account, bytes4 interfaceId) external view returns (bool);
|
|
|
|
event InterfaceImplementerSet(address indexed account, bytes32 indexed interfaceHash, address indexed implementer);
|
|
|
|
event ManagerChanged(address indexed account, address indexed newManager);
|
|
}
|