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
187 lines
5.9 KiB
Solidity
187 lines
5.9 KiB
Solidity
pragma solidity ^0.5.0;
|
|
|
|
/**
|
|
* @dev Interface of the ERC777Token standard as defined in the EIP.
|
|
*
|
|
* This contract uses the
|
|
* https://eips.ethereum.org/EIPS/eip-1820[ERC1820 registry standard] to let
|
|
* token holders and recipients react to token movements by using setting implementers
|
|
* for the associated interfaces in said registry. See {IERC1820Registry} and
|
|
* {ERC1820Implementer}.
|
|
*/
|
|
interface IERC777 {
|
|
/**
|
|
* @dev Returns the name of the token.
|
|
*/
|
|
function name() external view returns (string memory);
|
|
|
|
/**
|
|
* @dev Returns the symbol of the token, usually a shorter version of the
|
|
* name.
|
|
*/
|
|
function symbol() external view returns (string memory);
|
|
|
|
/**
|
|
* @dev Returns the smallest part of the token that is not divisible. This
|
|
* means all token operations (creation, movement and destruction) must have
|
|
* amounts that are a multiple of this number.
|
|
*
|
|
* For most token contracts, this value will equal 1.
|
|
*/
|
|
function granularity() external view returns (uint256);
|
|
|
|
/**
|
|
* @dev Returns the amount of tokens in existence.
|
|
*/
|
|
function totalSupply() external view returns (uint256);
|
|
|
|
/**
|
|
* @dev Returns the amount of tokens owned by an account (`owner`).
|
|
*/
|
|
function balanceOf(address owner) external view returns (uint256);
|
|
|
|
/**
|
|
* @dev Moves `amount` tokens from the caller's account to `recipient`.
|
|
*
|
|
* If send or receive hooks are registered for the caller and `recipient`,
|
|
* the corresponding functions will be called with `data` and empty
|
|
* `operatorData`. See {IERC777Sender} and {IERC777Recipient}.
|
|
*
|
|
* Emits a {Sent} event.
|
|
*
|
|
* Requirements
|
|
*
|
|
* - the caller must have at least `amount` tokens.
|
|
* - `recipient` cannot be the zero address.
|
|
* - if `recipient` is a contract, it must implement the {IERC777Recipient}
|
|
* interface.
|
|
*/
|
|
function send(address recipient, uint256 amount, bytes calldata data) external;
|
|
|
|
/**
|
|
* @dev Destroys `amount` tokens from the caller's account, reducing the
|
|
* total supply.
|
|
*
|
|
* If a send hook is registered for the caller, the corresponding function
|
|
* will be called with `data` and empty `operatorData`. See {IERC777Sender}.
|
|
*
|
|
* Emits a {Burned} event.
|
|
*
|
|
* Requirements
|
|
*
|
|
* - the caller must have at least `amount` tokens.
|
|
*/
|
|
function burn(uint256 amount, bytes calldata data) external;
|
|
|
|
/**
|
|
* @dev Returns true if an account is an operator of `tokenHolder`.
|
|
* Operators can send and burn tokens on behalf of their owners. All
|
|
* accounts are their own operator.
|
|
*
|
|
* See {operatorSend} and {operatorBurn}.
|
|
*/
|
|
function isOperatorFor(address operator, address tokenHolder) external view returns (bool);
|
|
|
|
/**
|
|
* @dev Make an account an operator of the caller.
|
|
*
|
|
* See {isOperatorFor}.
|
|
*
|
|
* Emits an {AuthorizedOperator} event.
|
|
*
|
|
* Requirements
|
|
*
|
|
* - `operator` cannot be calling address.
|
|
*/
|
|
function authorizeOperator(address operator) external;
|
|
|
|
/**
|
|
* @dev Make an account an operator of the caller.
|
|
*
|
|
* See {isOperatorFor} and {defaultOperators}.
|
|
*
|
|
* Emits a {RevokedOperator} event.
|
|
*
|
|
* Requirements
|
|
*
|
|
* - `operator` cannot be calling address.
|
|
*/
|
|
function revokeOperator(address operator) external;
|
|
|
|
/**
|
|
* @dev Returns the list of default operators. These accounts are operators
|
|
* for all token holders, even if {authorizeOperator} was never called on
|
|
* them.
|
|
*
|
|
* This list is immutable, but individual holders may revoke these via
|
|
* {revokeOperator}, in which case {isOperatorFor} will return false.
|
|
*/
|
|
function defaultOperators() external view returns (address[] memory);
|
|
|
|
/**
|
|
* @dev Moves `amount` tokens from `sender` to `recipient`. The caller must
|
|
* be an operator of `sender`.
|
|
*
|
|
* If send or receive hooks are registered for `sender` and `recipient`,
|
|
* the corresponding functions will be called with `data` and
|
|
* `operatorData`. See {IERC777Sender} and {IERC777Recipient}.
|
|
*
|
|
* Emits a {Sent} event.
|
|
*
|
|
* Requirements
|
|
*
|
|
* - `sender` cannot be the zero address.
|
|
* - `sender` must have at least `amount` tokens.
|
|
* - the caller must be an operator for `sender`.
|
|
* - `recipient` cannot be the zero address.
|
|
* - if `recipient` is a contract, it must implement the {IERC777Recipient}
|
|
* interface.
|
|
*/
|
|
function operatorSend(
|
|
address sender,
|
|
address recipient,
|
|
uint256 amount,
|
|
bytes calldata data,
|
|
bytes calldata operatorData
|
|
) external;
|
|
|
|
/**
|
|
* @dev Destoys `amount` tokens from `account`, reducing the total supply.
|
|
* The caller must be an operator of `account`.
|
|
*
|
|
* If a send hook is registered for `account`, the corresponding function
|
|
* will be called with `data` and `operatorData`. See {IERC777Sender}.
|
|
*
|
|
* Emits a {Burned} event.
|
|
*
|
|
* Requirements
|
|
*
|
|
* - `account` cannot be the zero address.
|
|
* - `account` must have at least `amount` tokens.
|
|
* - the caller must be an operator for `account`.
|
|
*/
|
|
function operatorBurn(
|
|
address account,
|
|
uint256 amount,
|
|
bytes calldata data,
|
|
bytes calldata operatorData
|
|
) external;
|
|
|
|
event Sent(
|
|
address indexed operator,
|
|
address indexed from,
|
|
address indexed to,
|
|
uint256 amount,
|
|
bytes data,
|
|
bytes operatorData
|
|
);
|
|
|
|
event Minted(address indexed operator, address indexed to, uint256 amount, bytes data, bytes operatorData);
|
|
|
|
event Burned(address indexed operator, address indexed from, uint256 amount, bytes data, bytes operatorData);
|
|
|
|
event AuthorizedOperator(address indexed operator, address indexed tokenHolder);
|
|
|
|
event RevokedOperator(address indexed operator, address indexed tokenHolder);
|
|
}
|