Contract 0x5d96991648d22935bdf6c7064b65c3c93f82aa61

 
Txn Hash Method
Block
From
To
Value [Txn Fee]
0x62fc0b5e3cfc1b5d781ceba4c20e0e9483429e41d788db4abe84d1c57542adb4Withdraw Dividen...147548072022-01-28 8:19:461 min ago0x8d51084465a9b552441051fcc99fd422d9c7d413 IN  Hero Floki: HERO Token0 BNB0.00019589
0x75e97767f343b4ef04ed669591c076d14a9272885d148d45aaf358864f057364Approve147397182022-01-27 19:41:1512 hrs 40 mins ago0xc17a94261dad8471f9fb53eb809021679997d397 IN  Hero Floki: HERO Token0 BNB0.000222625
0x5c6e84cc75d1d7ce7ff29091c65a28d5ae9af7f08069638d1a1d8596ceff82bbTransfer147353672022-01-27 16:03:4216 hrs 17 mins ago0x16f428fb9af9ce336793bd681dc92a8e9708bc23 IN  Hero Floki: HERO Token0 BNB0.00300212
0xe6de2367584374af4ae7ff015857abd53c550c9af5639b997ffdac116f3296b6Transfer147150762022-01-26 23:06:021 day 9 hrs ago0xfe12c3e563dbe6668e364cd74fc56bbf3595649d IN  Hero Floki: HERO Token0 BNB0.00322724
0xb1c40c684bf1ec9edfd901a144084ba75f078801c8261e76fdc9cfeab0ae3d71Approve147014122022-01-26 11:38:201 day 20 hrs ago0xe4624b81c63fcb7557d3dfb60a0ff510c173df99 IN  Hero Floki: HERO Token0 BNB0.000222625
0x0df747516619fbb0c5902038f681a6c0f58f3974f7151ceaab8a9afa4097e117Approve146854712022-01-25 22:21:122 days 10 hrs ago0xfe2e658a3774d44d9b44e20c02de49b16fc7af7b IN  Hero Floki: HERO Token0 BNB0.000222625
0x628d1c2ac449542d6abf8491f8dc0a82811efdba6956011ec2be6c1f7b0ffa86Approve146842522022-01-25 21:20:152 days 11 hrs ago0x1b886559000feaede46efb9d2ebfa222c883afd4 IN  Hero Floki: HERO Token0 BNB0.000222625
0x8700ccf6a847686ee5810d6a2a64912cbbfff1d8ce14fd9d02440eaa02742d84Withdraw Dividen...146823652022-01-25 19:45:542 days 12 hrs ago0x3b74ba755ad5924a10dc6dc958478bae25516432 IN  Hero Floki: HERO Token0 BNB0.00060973
0xb44936ce64e1e48f7b7b9f821e9d64a43dacdecfa9c04240a9eb573e91595b79Approve146796102022-01-25 17:28:092 days 14 hrs ago0x42f48aa501b96b63e84e7a8312ca2ce9d4d333bb IN  Hero Floki: HERO Token0 BNB0.000222625
0x416c373bc8677556b3763a64c8ff318cb691e89b0c9e040b00172d2900f266fdWithdraw Dividen...146743832022-01-25 13:05:012 days 19 hrs ago0xf04f3c0bf0acff01d886505313159903f923da30 IN  Hero Floki: HERO Token0 BNB0.00060973
0x67a9361edc69c89e67d77a1615385815f837ff4e49abcfd443f11fcabed8e3eaApprove146679872022-01-25 7:45:033 days 36 mins ago0xc560b4f548a0bf7a4b6cb79041e10f059474a6c4 IN  Hero Floki: HERO Token0 BNB0.000222625
0x6c032c104552b3c9122db246d793787820a9f685ae1c7fe2ef2271d0e895d0c8Transfer146618342022-01-25 2:36:173 days 5 hrs ago0xa3d6ee82c32152a467a9b9336959ed79c37e9b40 IN  Hero Floki: HERO Token0 BNB0.00307718
0x9f3161179c9855d78b84680003daadbecf09d9b75d6d4d88fcee549e964ed0cfApprove146359422022-01-24 4:59:134 days 3 hrs ago0xdd76800b8f02fc9cf050b6fa8368ae07981c5466 IN  Hero Floki: HERO Token0 BNB0.000222625
0xbdd1c84fd542fd7819f0d463fae8f545be0bfe9f1c0beec7ed3b8cff749329fdApprove146155742022-01-23 11:59:054 days 20 hrs ago0x4df8833bf7c867edddf8f9fb0345bf427ddb10b5 IN  Hero Floki: HERO Token0 BNB0.000222625
0x78a041a6ca2b64e769fe68012ae87994d473820426b1ff6d10b1481b4283a641Approve146100272022-01-23 7:21:305 days 59 mins ago0x2af417624ba919b94d4025b76ab2b60dcde16d67 IN  Hero Floki: HERO Token0 BNB0.000222625
0xad515b3385b8ca032ccc40c1b5058bc6ea885354d6d4fce100cfa5412ed4f805Withdraw Dividen...146094792022-01-23 6:54:065 days 1 hr ago0x8872dbdfe0769b47c0028154e0ebe37bb0cafc1a IN  Hero Floki: HERO Token0 BNB0.00045973
0x00d93cc01472c79840627fe095a0b3764e2701c3b1b8ba98c989ac3ad87e824dWithdraw Dividen...145945062022-01-22 18:24:565 days 13 hrs ago0x0c493fcd131cf78509cf38c26dc6088c533c6b21 IN  Hero Floki: HERO Token0 BNB0.00060973
0x09bc55d95b505a06a142b10b4eb0d4482d0974a44da32661fcda70b2c920c3baApprove145942472022-01-22 18:11:595 days 14 hrs ago0x550de02f63e32ee5e3316523caff342dfb621c4e IN  Hero Floki: HERO Token0 BNB0.000222625
0x4fa9c206dcaccd56691546b00c3b9bd2188d5db6816464106499ffb3d0ea3e13Approve145942082022-01-22 18:10:025 days 14 hrs ago0xf0c3b19c4a60d49dbf2665c7ef5af1d3be593464 IN  Hero Floki: HERO Token0 BNB0.000222625
0x6134221d86057085f4588c4f2c5b50e87dd9963037ed4e97ba8b13d63a2105c6Approve145941682022-01-22 18:08:025 days 14 hrs ago0x9f929f3552de5b6c385b0261357942fa3e6d7abf IN  Hero Floki: HERO Token0 BNB0.000222625
0x83a83efc3c5f74618ceaa1661f04698a5feb8be310c4df243ef706d9f94b3b65Approve145941312022-01-22 18:06:115 days 14 hrs ago0x28f86137a4fe7fae13efd53684f19adb5e47b943 IN  Hero Floki: HERO Token0 BNB0.000222625
0x57b7723baf3db1cb0fb44b56ba4c8c6506f231b727521520fd084309da78b979Approve145940942022-01-22 18:04:205 days 14 hrs ago0x5ae06fa16ece13f42e12b769d725d4fbde114d31 IN  Hero Floki: HERO Token0 BNB0.000222625
0x300c356f306b61ddc4c4e55567e02bad5fd5299ba35eac6ca39bbfd9e943628bApprove145940462022-01-22 18:01:565 days 14 hrs ago0x7ee7999a3111b4e8f3367ef668c9fa7e0f3f930e IN  Hero Floki: HERO Token0 BNB0.000222625
0x23139568c2ebbff4af0e9fa22837c50a241a69505d1f45bc011ac718a81f560dApprove145939972022-01-22 17:59:285 days 14 hrs ago0x27cf03c08cac131501467ecd693ed73e89623c96 IN  Hero Floki: HERO Token0 BNB0.000222625
0xd5ba218e957d57a62d7a33c38ea94a6e0299cebc5f6643406cc53a26002c33a1Approve145939422022-01-22 17:56:435 days 14 hrs ago0x3ec66df93eea7b732b707673967cad79fac53ff6 IN  Hero Floki: HERO Token0 BNB0.000222625
[ Download CSV Export 

OVERVIEW

HeroFloki pays his long-term holders! Every Hours Hero holders can claim BUSD & CAKE from the Hero Vault! Just hold $HERO to earn 4% CAKE and 4% BUSD, a highly potential x100 token, each transaction, automatically every 60 minutes.

Latest 25 internal transaction
Parent Txn Hash Block From To Value
0xca3efa335b548bea796016c9336a93aa8e55e04308362901c3299d2815f87b35144471172022-01-17 14:49:4410 days 17 hrs ago PancakeSwap: Router v2 Hero Floki: HERO Token0.048976454397830734 BNB
0xca3efa335b548bea796016c9336a93aa8e55e04308362901c3299d2815f87b35144471172022-01-17 14:49:4410 days 17 hrs ago Hero Floki: HERO Token PancakeSwap: Router v20.80144954065328023 BNB
0xca3efa335b548bea796016c9336a93aa8e55e04308362901c3299d2815f87b35144471172022-01-17 14:49:4410 days 17 hrs ago Hero Floki: HERO Token PancakeSwap: Router v21.202174310979920343 BNB
0xca3efa335b548bea796016c9336a93aa8e55e04308362901c3299d2815f87b35144471172022-01-17 14:49:4410 days 17 hrs ago Hero Floki: HERO Token PancakeSwap: Router v21.202174310979920343 BNB
0xca3efa335b548bea796016c9336a93aa8e55e04308362901c3299d2815f87b35144471172022-01-17 14:49:4410 days 17 hrs ago Hero Floki: HERO TokenHero Floki: Deployer1.602899081306560457 BNB
0xca3efa335b548bea796016c9336a93aa8e55e04308362901c3299d2815f87b35144471172022-01-17 14:49:4410 days 17 hrs ago PancakeSwap: Router v2 Hero Floki: HERO Token4.760978572110662148 BNB
0x083d25cce087a50202c7b30a7ee65890d0547b0b8de811cdbe57c05cbbc544de139776192022-01-01 6:38:1627 days 1 hr ago PancakeSwap: Router v2 Hero Floki: HERO Token0.047718671809019225 BNB
0x083d25cce087a50202c7b30a7ee65890d0547b0b8de811cdbe57c05cbbc544de139776192022-01-01 6:38:1627 days 1 hr ago Hero Floki: HERO Token PancakeSwap: Router v20.763681287947012554 BNB
0x083d25cce087a50202c7b30a7ee65890d0547b0b8de811cdbe57c05cbbc544de139776192022-01-01 6:38:1627 days 1 hr ago Hero Floki: HERO Token PancakeSwap: Router v21.145521931920518829 BNB
0x083d25cce087a50202c7b30a7ee65890d0547b0b8de811cdbe57c05cbbc544de139776192022-01-01 6:38:1627 days 1 hr ago Hero Floki: HERO Token PancakeSwap: Router v21.145521931920518829 BNB
0x083d25cce087a50202c7b30a7ee65890d0547b0b8de811cdbe57c05cbbc544de139776192022-01-01 6:38:1627 days 1 hr ago Hero Floki: HERO TokenHero Floki: Deployer1.527362575894025105 BNB
0x083d25cce087a50202c7b30a7ee65890d0547b0b8de811cdbe57c05cbbc544de139776192022-01-01 6:38:1627 days 1 hr ago PancakeSwap: Router v2 Hero Floki: HERO Token4.52400328686626254 BNB
0x7a047535d2241261c2b1757129ed310a997e0281ec6b21c012a1de020d84ebf6137423452021-12-24 2:21:1035 days 6 hrs ago PancakeSwap: Router v2 Hero Floki: HERO Token0.058084440815812777 BNB
0x7a047535d2241261c2b1757129ed310a997e0281ec6b21c012a1de020d84ebf6137423452021-12-24 2:21:1035 days 6 hrs ago Hero Floki: HERO Token PancakeSwap: Router v20.861782669458485028 BNB
0x7a047535d2241261c2b1757129ed310a997e0281ec6b21c012a1de020d84ebf6137423452021-12-24 2:21:1035 days 6 hrs ago Hero Floki: HERO Token PancakeSwap: Router v21.292674004187727541 BNB
0x7a047535d2241261c2b1757129ed310a997e0281ec6b21c012a1de020d84ebf6137423452021-12-24 2:21:1035 days 6 hrs ago Hero Floki: HERO Token PancakeSwap: Router v21.292674004187727541 BNB
0x7a047535d2241261c2b1757129ed310a997e0281ec6b21c012a1de020d84ebf6137423452021-12-24 2:21:1035 days 6 hrs ago Hero Floki: HERO TokenHero Floki: Deployer1.723565338916970054 BNB
0x7a047535d2241261c2b1757129ed310a997e0281ec6b21c012a1de020d84ebf6137423452021-12-24 2:21:1035 days 6 hrs ago PancakeSwap: Router v2 Hero Floki: HERO Token5.099424211249547676 BNB
0xf1ee75c6db6ae22856f93e60a7a4eb754a90ec251c2f4b26ea00cfd015b79264133276962021-12-09 15:06:3749 days 17 hrs ago PancakeSwap: Router v2 Hero Floki: HERO Token0.071271805501362488 BNB
0xf1ee75c6db6ae22856f93e60a7a4eb754a90ec251c2f4b26ea00cfd015b79264133276962021-12-09 15:06:3749 days 17 hrs ago Hero Floki: HERO Token PancakeSwap: Router v20.965228075905642873 BNB
0xf1ee75c6db6ae22856f93e60a7a4eb754a90ec251c2f4b26ea00cfd015b79264133276962021-12-09 15:06:3749 days 17 hrs ago Hero Floki: HERO Token PancakeSwap: Router v21.447842113858464307 BNB
0xf1ee75c6db6ae22856f93e60a7a4eb754a90ec251c2f4b26ea00cfd015b79264133276962021-12-09 15:06:3749 days 17 hrs ago Hero Floki: HERO Token PancakeSwap: Router v21.447842113858464306 BNB
0xf1ee75c6db6ae22856f93e60a7a4eb754a90ec251c2f4b26ea00cfd015b79264133276962021-12-09 15:06:3749 days 17 hrs ago Hero Floki: HERO TokenHero Floki: Deployer1.930456151811285742 BNB
0xf1ee75c6db6ae22856f93e60a7a4eb754a90ec251c2f4b26ea00cfd015b79264133276962021-12-09 15:06:3749 days 17 hrs ago PancakeSwap: Router v2 Hero Floki: HERO Token5.693395842381048318 BNB
0x2834e18af2f20250dc7270a5f05b39e3dae6fa6b79173c7cea81aca7759ffdf5131003622021-12-01 9:38:5057 days 22 hrs ago PancakeSwap: Router v2 Hero Floki: HERO Token0.09797261305280891 BNB
[ Download CSV Export 
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
HeroFloki

Compiler Version
v0.8.7+commit.e28d00a7

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at BscScan.com on 2021-10-02
*/

pragma solidity ^0.8.7;

////////////////////////////////
//////// HERO FLOKI v3 /////////
////////////////////////////////

//     __  ____________  ____     ________    ____  __ __ ____
//    / / / / ____/ __ \/ __ \   / ____/ /   / __ \/ //_//  _/
//   / /_/ / __/ / /_/ / / / /  / /_  / /   / / / / ,<   / /  
//  / __  / /___/ _, _/ /_/ /  / __/ / /___/ /_/ / /| |_/ /   
// /_/ /_/_____/_/ |_|\____/  /_/   /_____/\____/_/ |_/___/   
//

////////////////////////////////
////// www.herofloki.com ///////
////////////////////////////////


// SPDX-License-Identifier: MIT
/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `recipient`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address recipient, uint256 amount) external returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(address owner, address spender) external view returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `sender` to `recipient` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(address indexed owner, address indexed spender, uint256 value);
}

// : MIT
/**
 * @dev Interface for the optional metadata functions from the ERC20 standard.
 *
 * _Available since v4.1._
 */
interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

    /**
     * @dev Returns the symbol of the token.
     */
    function symbol() external view returns (string memory);

    /**
     * @dev Returns the decimals places of the token.
     */
    function decimals() external view returns (uint8);
}

//  : MIT
/**
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
}

//  : MIT
/**
 * @dev Implementation of the {IERC20} interface.
 *
 * This implementation is agnostic to the way tokens are created. This means
 * that a supply mechanism has to be added in a derived contract using {_mint}.
 * For a generic mechanism see {ERC20PresetMinterPauser}.
 *
 * TIP: For a detailed writeup see our guide
 * https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How
 * to implement supply mechanisms].
 *
 * We have followed general OpenZeppelin Contracts guidelines: functions revert
 * instead returning `false` on failure. This behavior is nonetheless
 * conventional and does not conflict with the expectations of ERC20
 * applications.
 *
 * Additionally, an {Approval} event is emitted on calls to {transferFrom}.
 * This allows applications to reconstruct the allowance for all accounts just
 * by listening to said events. Other implementations of the EIP may not emit
 * these events, as it isn't required by the specification.
 *
 * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}
 * functions have been added to mitigate the well-known issues around setting
 * allowances. See {IERC20-approve}.
 */
contract ERC20 is Context, IERC20, IERC20Metadata {
    mapping(address => uint256) private _balances;

    mapping(address => mapping(address => uint256)) private _allowances;

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

    /**
     * @dev Sets the values for {name} and {symbol}.
     *
     * The default value of {decimals} is 18. To select a different value for
     * {decimals} you should overload it.
     *
     * All two of these values are immutable: they can only be set once during
     * construction.
     */
    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

    /**
     * @dev Returns the name of the token.
     */
    function name() public view virtual override returns (string memory) {
        return _name;
    }

    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view virtual override returns (string memory) {
        return _symbol;
    }

    /**
     * @dev Returns the number of decimals used to get its user representation.
     * For example, if `decimals` equals `2`, a balance of `505` tokens should
     * be displayed to a user as `5.05` (`505 / 10 ** 2`).
     *
     * Tokens usually opt for a value of 18, imitating the relationship between
     * Ether and Wei. This is the value {ERC20} uses, unless this function is
     * overridden;
     *
     * NOTE: This information is only used for _display_ purposes: it in
     * no way affects any of the arithmetic of the contract, including
     * {IERC20-balanceOf} and {IERC20-transfer}.
     */
    function decimals() public view virtual override returns (uint8) {
        return 18;
    }

    /**
     * @dev See {IERC20-totalSupply}.
     */
    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;
    }

    /**
     * @dev See {IERC20-balanceOf}.
     */
    function balanceOf(address account) public view virtual override returns (uint256) {
        return _balances[account];
    }

    /**
     * @dev See {IERC20-transfer}.
     *
     * Requirements:
     *
     * - `recipient` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    /**
     * @dev See {IERC20-allowance}.
     */
    function allowance(address owner, address spender) public view virtual override returns (uint256) {
        return _allowances[owner][spender];
    }

    /**
     * @dev See {IERC20-approve}.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    /**
     * @dev See {IERC20-transferFrom}.
     *
     * Emits an {Approval} event indicating the updated allowance. This is not
     * required by the EIP. See the note at the beginning of {ERC20}.
     *
     * Requirements:
     *
     * - `sender` and `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     * - the caller must have allowance for ``sender``'s tokens of at least
     * `amount`.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);

        uint256 currentAllowance = _allowances[sender][_msgSender()];
        require(currentAllowance >= amount, "ERC20: transfer amount exceeds allowance");
        unchecked {
            _approve(sender, _msgSender(), currentAllowance - amount);
        }

        return true;
    }

    /**
     * @dev Atomically increases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue);
        return true;
    }

    /**
     * @dev Atomically decreases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     * - `spender` must have allowance for the caller of at least
     * `subtractedValue`.
     */
    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        unchecked {
            _approve(_msgSender(), spender, currentAllowance - subtractedValue);
        }

        return true;
    }

    /**
     * @dev Moves `amount` of tokens from `sender` to `recipient`.
     *
     * This internal function is equivalent to {transfer}, and can be used to
     * e.g. implement automatic token fees, slashing mechanisms, etc.
     *
     * Emits a {Transfer} event.
     *
     * Requirements:
     *
     * - `sender` cannot be the zero address.
     * - `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     */
    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(sender, recipient, amount);

        uint256 senderBalance = _balances[sender];
        require(senderBalance >= amount, "ERC20: transfer amount exceeds balance");
        unchecked {
            _balances[sender] = senderBalance - amount;
        }
        _balances[recipient] += amount;

        emit Transfer(sender, recipient, amount);

        _afterTokenTransfer(sender, recipient, amount);
    }

    /** @dev Creates `amount` tokens and assigns them to `account`, increasing
     * the total supply.
     *
     * Emits a {Transfer} event with `from` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     */
    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");

        _beforeTokenTransfer(address(0), account, amount);

        _totalSupply += amount;
        _balances[account] += amount;
        emit Transfer(address(0), account, amount);

        _afterTokenTransfer(address(0), account, amount);
    }

    /**
     * @dev Destroys `amount` tokens from `account`, reducing the
     * total supply.
     *
     * Emits a {Transfer} event with `to` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     * - `account` must have at least `amount` tokens.
     */
    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");

        _beforeTokenTransfer(account, address(0), amount);

        uint256 accountBalance = _balances[account];
        require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
        unchecked {
            _balances[account] = accountBalance - amount;
        }
        _totalSupply -= amount;

        emit Transfer(account, address(0), amount);

        _afterTokenTransfer(account, address(0), amount);
    }

    /**
     * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
     *
     * This internal function is equivalent to `approve`, and can be used to
     * e.g. set automatic allowances for certain subsystems, etc.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `owner` cannot be the zero address.
     * - `spender` cannot be the zero address.
     */
    function _approve(
        address owner,
        address spender,
        uint256 amount
    ) internal virtual {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");

        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    /**
     * @dev Hook that is called before any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * will be transferred to `to`.
     * - when `from` is zero, `amount` tokens will be minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens will be burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}

    /**
     * @dev Hook that is called after any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * has been transferred to `to`.
     * - when `from` is zero, `amount` tokens have been minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens have been burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _afterTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}

//  : MIT
/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize, which returns 0 for contracts in
        // construction, since the code is only stored at the end of the
        // constructor execution.

        uint256 size;
        assembly {
            size := extcodesize(account)
        }
        return size > 0;
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, "Address: insufficient balance");

        (bool success, ) = recipient.call{value: amount}("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

    /**
     * @dev Performs a Solidity function call using a low level `call`. A
     * plain `call` is an unsafe replacement for a function call: use this
     * function instead.
     *
     * If `target` reverts with a revert reason, it is bubbled up by this
     * function (like regular Solidity function calls).
     *
     * Returns the raw returned data. To convert to the expected return value,
     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
     *
     * Requirements:
     *
     * - `target` must be a contract.
     * - calling `target` with `data` must not revert.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionCall(target, data, "Address: low-level call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with
     * `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        return functionCallWithValue(target, data, 0, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value
    ) internal returns (bytes memory) {
        return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
    }

    /**
     * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
     * with `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(address(this).balance >= value, "Address: insufficient balance for call");
        require(isContract(target), "Address: call to non-contract");

        (bool success, bytes memory returndata) = target.call{value: value}(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {
        return functionStaticCall(target, data, "Address: low-level static call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal view returns (bytes memory) {
        require(isContract(target), "Address: static call to non-contract");

        (bool success, bytes memory returndata) = target.staticcall(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionDelegateCall(target, data, "Address: low-level delegate call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(isContract(target), "Address: delegate call to non-contract");

        (bool success, bytes memory returndata) = target.delegatecall(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the
     * revert reason using the provided one.
     *
     * _Available since v4.3._
     */
    function verifyCallResult(
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) internal pure returns (bytes memory) {
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

//  : MIT
/**
 * @title SafeERC20
 * @dev Wrappers around ERC20 operations that throw on failure (when the token
 * contract returns false). Tokens that return no value (and instead revert or
 * throw on failure) are also supported, non-reverting calls are assumed to be
 * successful.
 * To use this library you can add a `using SafeERC20 for IERC20;` statement to your contract,
 * which allows you to call the safe operations as `token.safeTransfer(...)`, etc.
 */
library SafeERC20 {
    using Address for address;

    function safeTransfer(
        IERC20 token,
        address to,
        uint256 value
    ) internal {
        _callOptionalReturn(token, abi.encodeWithSelector(token.transfer.selector, to, value));
    }

    function safeTransferFrom(
        IERC20 token,
        address from,
        address to,
        uint256 value
    ) internal {
        _callOptionalReturn(token, abi.encodeWithSelector(token.transferFrom.selector, from, to, value));
    }

    /**
     * @dev Deprecated. This function has issues similar to the ones found in
     * {IERC20-approve}, and its usage is discouraged.
     *
     * Whenever possible, use {safeIncreaseAllowance} and
     * {safeDecreaseAllowance} instead.
     */
    function safeApprove(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        // safeApprove should only be called when setting an initial allowance,
        // or when resetting it to zero. To increase and decrease it, use
        // 'safeIncreaseAllowance' and 'safeDecreaseAllowance'
        require(
            (value == 0) || (token.allowance(address(this), spender) == 0),
            "SafeERC20: approve from non-zero to non-zero allowance"
        );
        _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, value));
    }

    function safeIncreaseAllowance(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        uint256 newAllowance = token.allowance(address(this), spender) + value;
        _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance));
    }

    function safeDecreaseAllowance(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        unchecked {
            uint256 oldAllowance = token.allowance(address(this), spender);
            require(oldAllowance >= value, "SafeERC20: decreased allowance below zero");
            uint256 newAllowance = oldAllowance - value;
            _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance));
        }
    }

    /**
     * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement
     * on the return value: the return value is optional (but if data is returned, it must not be false).
     * @param token The token targeted by the call.
     * @param data The call data (encoded using abi.encode or one of its variants).
     */
    function _callOptionalReturn(IERC20 token, bytes memory data) private {
        // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since
        // we're implementing it ourselves. We use {Address.functionCall} to perform this call, which verifies that
        // the target address contains contract code and also asserts for success in the low-level call.

        bytes memory returndata = address(token).functionCall(data, "SafeERC20: low-level call failed");
        if (returndata.length > 0) {
            // Return data is optional
            require(abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed");
        }
    }
}

//  : MIT
/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract contract Ownable is Context {
    address private _owner;

    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _setOwner(_msgSender());
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view virtual returns (address) {
        return _owner;
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        _setOwner(address(0));
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Can only be called by the current owner.
     */
    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        _setOwner(newOwner);
    }

    function _setOwner(address newOwner) private {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

//  : MIT
/**
 * @dev Wrappers over Solidity's uintXX/intXX casting operators with added overflow
 * checks.
 *
 * Downcasting from uint256/int256 in Solidity does not revert on overflow. This can
 * easily result in undesired exploitation or bugs, since developers usually
 * assume that overflows raise errors. `SafeCast` restores this intuition by
 * reverting the transaction when such an operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 *
 * Can be combined with {SafeMath} and {SignedSafeMath} to extend it to smaller types, by performing
 * all math on `uint256` and `int256` and then downcasting.
 */
library SafeCast {
    /**
     * @dev Returns the downcasted uint224 from uint256, reverting on
     * overflow (when the input is greater than largest uint224).
     *
     * Counterpart to Solidity's `uint224` operator.
     *
     * Requirements:
     *
     * - input must fit into 224 bits
     */
    function toUint224(uint256 value) internal pure returns (uint224) {
        require(value <= type(uint224).max, "SafeCast: value doesn't fit in 224 bits");
        return uint224(value);
    }

    /**
     * @dev Returns the downcasted uint128 from uint256, reverting on
     * overflow (when the input is greater than largest uint128).
     *
     * Counterpart to Solidity's `uint128` operator.
     *
     * Requirements:
     *
     * - input must fit into 128 bits
     */
    function toUint128(uint256 value) internal pure returns (uint128) {
        require(value <= type(uint128).max, "SafeCast: value doesn't fit in 128 bits");
        return uint128(value);
    }

    /**
     * @dev Returns the downcasted uint96 from uint256, reverting on
     * overflow (when the input is greater than largest uint96).
     *
     * Counterpart to Solidity's `uint96` operator.
     *
     * Requirements:
     *
     * - input must fit into 96 bits
     */
    function toUint96(uint256 value) internal pure returns (uint96) {
        require(value <= type(uint96).max, "SafeCast: value doesn't fit in 96 bits");
        return uint96(value);
    }

    /**
     * @dev Returns the downcasted uint64 from uint256, reverting on
     * overflow (when the input is greater than largest uint64).
     *
     * Counterpart to Solidity's `uint64` operator.
     *
     * Requirements:
     *
     * - input must fit into 64 bits
     */
    function toUint64(uint256 value) internal pure returns (uint64) {
        require(value <= type(uint64).max, "SafeCast: value doesn't fit in 64 bits");
        return uint64(value);
    }

    /**
     * @dev Returns the downcasted uint32 from uint256, reverting on
     * overflow (when the input is greater than largest uint32).
     *
     * Counterpart to Solidity's `uint32` operator.
     *
     * Requirements:
     *
     * - input must fit into 32 bits
     */
    function toUint32(uint256 value) internal pure returns (uint32) {
        require(value <= type(uint32).max, "SafeCast: value doesn't fit in 32 bits");
        return uint32(value);
    }

    /**
     * @dev Returns the downcasted uint16 from uint256, reverting on
     * overflow (when the input is greater than largest uint16).
     *
     * Counterpart to Solidity's `uint16` operator.
     *
     * Requirements:
     *
     * - input must fit into 16 bits
     */
    function toUint16(uint256 value) internal pure returns (uint16) {
        require(value <= type(uint16).max, "SafeCast: value doesn't fit in 16 bits");
        return uint16(value);
    }

    /**
     * @dev Returns the downcasted uint8 from uint256, reverting on
     * overflow (when the input is greater than largest uint8).
     *
     * Counterpart to Solidity's `uint8` operator.
     *
     * Requirements:
     *
     * - input must fit into 8 bits.
     */
    function toUint8(uint256 value) internal pure returns (uint8) {
        require(value <= type(uint8).max, "SafeCast: value doesn't fit in 8 bits");
        return uint8(value);
    }

    /**
     * @dev Converts a signed int256 into an unsigned uint256.
     *
     * Requirements:
     *
     * - input must be greater than or equal to 0.
     */
    function toUint256(int256 value) internal pure returns (uint256) {
        require(value >= 0, "SafeCast: value must be positive");
        return uint256(value);
    }

    /**
     * @dev Returns the downcasted int128 from int256, reverting on
     * overflow (when the input is less than smallest int128 or
     * greater than largest int128).
     *
     * Counterpart to Solidity's `int128` operator.
     *
     * Requirements:
     *
     * - input must fit into 128 bits
     *
     * _Available since v3.1._
     */
    function toInt128(int256 value) internal pure returns (int128) {
        require(value >= type(int128).min && value <= type(int128).max, "SafeCast: value doesn't fit in 128 bits");
        return int128(value);
    }

    /**
     * @dev Returns the downcasted int64 from int256, reverting on
     * overflow (when the input is less than smallest int64 or
     * greater than largest int64).
     *
     * Counterpart to Solidity's `int64` operator.
     *
     * Requirements:
     *
     * - input must fit into 64 bits
     *
     * _Available since v3.1._
     */
    function toInt64(int256 value) internal pure returns (int64) {
        require(value >= type(int64).min && value <= type(int64).max, "SafeCast: value doesn't fit in 64 bits");
        return int64(value);
    }

    /**
     * @dev Returns the downcasted int32 from int256, reverting on
     * overflow (when the input is less than smallest int32 or
     * greater than largest int32).
     *
     * Counterpart to Solidity's `int32` operator.
     *
     * Requirements:
     *
     * - input must fit into 32 bits
     *
     * _Available since v3.1._
     */
    function toInt32(int256 value) internal pure returns (int32) {
        require(value >= type(int32).min && value <= type(int32).max, "SafeCast: value doesn't fit in 32 bits");
        return int32(value);
    }

    /**
     * @dev Returns the downcasted int16 from int256, reverting on
     * overflow (when the input is less than smallest int16 or
     * greater than largest int16).
     *
     * Counterpart to Solidity's `int16` operator.
     *
     * Requirements:
     *
     * - input must fit into 16 bits
     *
     * _Available since v3.1._
     */
    function toInt16(int256 value) internal pure returns (int16) {
        require(value >= type(int16).min && value <= type(int16).max, "SafeCast: value doesn't fit in 16 bits");
        return int16(value);
    }

    /**
     * @dev Returns the downcasted int8 from int256, reverting on
     * overflow (when the input is less than smallest int8 or
     * greater than largest int8).
     *
     * Counterpart to Solidity's `int8` operator.
     *
     * Requirements:
     *
     * - input must fit into 8 bits.
     *
     * _Available since v3.1._
     */
    function toInt8(int256 value) internal pure returns (int8) {
        require(value >= type(int8).min && value <= type(int8).max, "SafeCast: value doesn't fit in 8 bits");
        return int8(value);
    }

    /**
     * @dev Converts an unsigned uint256 into a signed int256.
     *
     * Requirements:
     *
     * - input must be less than or equal to maxInt256.
     */
    function toInt256(uint256 value) internal pure returns (int256) {
        // Note: Unsafe cast below is okay because `type(int256).max` is guaranteed to be positive
        require(value <= uint256(type(int256).max), "SafeCast: value doesn't fit in an int256");
        return int256(value);
    }
}

//  : MIT
library IterableMapping {
    // Iterable mapping from address to uint;
    struct Map {
        address[] keys;
        mapping(address => uint) values;
        mapping(address => uint) indexOf;
        mapping(address => bool) inserted;
    }

    function get(Map storage map, address key) public view returns (uint) {
        return map.values[key];
    }

    function getIndexOfKey(Map storage map, address key) public view returns (int) {
        if(!map.inserted[key]) {
            return -1;
        }
        return int(map.indexOf[key]);
    }

    function getKeyAtIndex(Map storage map, uint index) public view returns (address) {
        return map.keys[index];
    }

    function size(Map storage map) public view returns (uint) {
        return map.keys.length;
    }

    function set(Map storage map, address key, uint val) public {
        if (map.inserted[key]) {
            map.values[key] = val;
        } else {
            map.inserted[key] = true;
            map.values[key] = val;
            map.indexOf[key] = map.keys.length;
            map.keys.push(key);
        }
    }

    function remove(Map storage map, address key) public {
        if (!map.inserted[key]) {
            return;
        }

        delete map.inserted[key];
        delete map.values[key];

        uint index = map.indexOf[key];
        uint lastIndex = map.keys.length - 1;
        address lastKey = map.keys[lastIndex];

        map.indexOf[lastKey] = index;
        delete map.indexOf[key];

        map.keys[index] = lastKey;
        map.keys.pop();
    }
}

// : Unlicense
contract MultiDividendTracker is Ownable {
    using SafeCast for uint256;
    using SafeCast for int256;
    using SafeERC20 for IERC20;
    using IterableMapping for IterableMapping.Map;

    uint256 constant internal MAGNITUDE = 2**128;

    struct CurrencyDividends {
        uint256 magnifiedDividendPerShare;
        mapping(address => int256) magnifiedDividendCorrections;
        mapping(address => uint256) withdrawnDividends;
    }

    mapping(address => CurrencyDividends) internal _dividends;

    address[] public supportedCurrencies;

    mapping(address => uint256) public balances;

    uint256 public totalBalance;

    uint256 public minBalanceForDividends;

    mapping(address => bool) public isExcludedFromDividend;

    IterableMapping.Map private tokenHoldersMap;

    mapping (address => uint256) public lastClaimTimes;

    uint256 public claimWait;

    uint256 public lastProcessedIndex;

    // CONSTRUCTOR

    constructor(
        address[] memory supportedCurrencies_,
        uint256 minBalanceForDividends_,
        uint256 claimWait_
    ) Ownable() {
        supportedCurrencies = supportedCurrencies_;
        minBalanceForDividends = minBalanceForDividends_;
        claimWait = claimWait_;
    }

    // RECEIVE FUNCTION

    receive() external payable onlyOwner {
        _distributeDividends(address(0), msg.value);
    }

    // PUBLIC FUNCTIONS

    function withdrawAllDividends() public {
        withdrawAllDividendsOf(msg.sender);
    }

    function withdrawAllDividendsOf(address account) public returns (bool) {
        bool withdrawn;
        for (uint8 i = 0; i < supportedCurrencies.length; i++) {
            bool result = withdrawDividendOf(supportedCurrencies[i], account);
            withdrawn = withdrawn || result;
        }
        return withdrawn;
    }

    function withdrawDividend(address currency) public {
        withdrawDividendOf(currency, msg.sender);
    }

    function withdrawDividendOf(address currency, address account) public returns (bool) {
        uint256 dividend = dividendOf(account, currency);
        if (dividend > 0) {
            _dividends[currency].withdrawnDividends[account] += dividend;
            lastClaimTimes[account] = block.timestamp;

            if (currency == address(0)) {
                payable(account).transfer(dividend);
            } else {
                IERC20(currency).safeTransfer(account, dividend);
            }

            return true;
        }
        return false;
    }

    function process(uint256 gas) public returns (uint256, uint256, uint256) {

    	uint256 numberOfTokenHolders = tokenHoldersMap.keys.length;
    	if (numberOfTokenHolders == 0) {
    		return (0, 0, lastProcessedIndex);
    	}

    	uint256 _lastProcessedIndex = lastProcessedIndex;
    	uint256 gasUsed = 0;
    	uint256 gasLeft = gasleft();
    	uint256 iterations = 0;
    	uint256 claims = 0;

    	while (gasUsed < gas && iterations < numberOfTokenHolders) {

    		_lastProcessedIndex++;
    		if (_lastProcessedIndex >= tokenHoldersMap.keys.length) {
    			_lastProcessedIndex = 0;
    		}

    		address account = tokenHoldersMap.keys[_lastProcessedIndex];
    		if (canAutoClaim(account) && withdrawAllDividendsOf(account)) {
    			claims++;
    		}

    		iterations++;

    		uint256 newGasLeft = gasleft();
    		if (gasLeft > newGasLeft) {
    			gasUsed += gasLeft - newGasLeft;
    		}
    		gasLeft = newGasLeft;
    	}

    	lastProcessedIndex = _lastProcessedIndex;

    	return (iterations, claims, lastProcessedIndex);
    }

    // RESTRICTED FUNCTIONS

    function distributeDividends(address currency, uint256 amount) external onlyOwner {
        _distributeDividends(currency, amount);
    }

    function distributeDividends() external payable onlyOwner {
        _distributeDividends(address(0), msg.value);
    }

    function setExcludedFromDividend(address account, bool excluded) external onlyOwner {
        isExcludedFromDividend[account] = excluded;
        if (excluded) {
            tokenHoldersMap.remove(account);
        } else {
            tokenHoldersMap.set(account, balances[account]);
        }
    }

    function setClaimWait(uint256 time) external onlyOwner {
        claimWait = time;
    }

    function setBalance(address account, uint256 balance) external onlyOwner {
        if (balance >= minBalanceForDividends && !isExcludedFromDividend[account]) {
            _setBalance(account, balance);
        } else {
            _setBalance(account, 0);
        }
    }

    // VIEW FUNCTIONS

    function dividendOf(address account, address currency) public view returns (uint256) {
        return accumulatedDividendOf(account, currency) - withdrawnDividendOf(account, currency);
    }

    function accumulatedDividendOf(address account, address currency) public view returns (uint256) {
        return (
            (_dividends[currency].magnifiedDividendPerShare * balances[account]).toInt256() +
            _dividends[currency].magnifiedDividendCorrections[account]
        ).toUint256() / MAGNITUDE;
    } 

    function withdrawnDividendOf(address account, address currency) public view returns (uint256) {
        return _dividends[currency].withdrawnDividends[account];
    }

    function canAutoClaim(address account) private view returns (bool) {
    	if (lastClaimTimes[account] > block.timestamp)  {
    		return false;
    	}
    	return (block.timestamp - lastClaimTimes[account]) >= claimWait;
    }

    // INTERNAL FUNCTIONS

    function _distributeDividends(address currency, uint256 amount) internal {
        if (amount > 0) {
            _dividends[currency].magnifiedDividendPerShare += (amount * MAGNITUDE / totalBalance);
        }
    }

    function _setBalance(address account, uint256 newBalance) internal {
        if (newBalance != balances[account]) {
            for (uint8 i = 0; i < supportedCurrencies.length; i++) {
                _dividends[supportedCurrencies[i]].magnifiedDividendCorrections[account] += (
                    balances[account].toInt256() - newBalance.toInt256()
                ) * _dividends[supportedCurrencies[i]].magnifiedDividendPerShare.toInt256();
            }

            if (balances[account] == 0) {
                tokenHoldersMap.set(account, newBalance);
            } else if (newBalance == 0) {
                tokenHoldersMap.remove(account);
            }
            totalBalance = totalBalance - balances[account] + newBalance;
            balances[account] = newBalance;
        }
    }
}

// : Unlicense
interface IUniswapV2Factory {
    event PairCreated(address indexed token0, address indexed token1, address pair, uint);
    function feeTo() external view returns (address);
    function feeToSetter() external view returns (address);
    function getPair(address tokenA, address tokenB) external view returns (address pair);
    function allPairs(uint) external view returns (address pair);
    function allPairsLength() external view returns (uint);
    function createPair(address tokenA, address tokenB) external returns (address pair);
    function setFeeTo(address) external;
    function setFeeToSetter(address) external;
}

interface IUniswapV2Pair {
    event Approval(address indexed owner, address indexed spender, uint value);
    event Transfer(address indexed from, address indexed to, uint value);
    function name() external pure returns (string memory);
    function symbol() external pure returns (string memory);
    function decimals() external pure returns (uint8);
    function totalSupply() external view returns (uint);
    function balanceOf(address owner) external view returns (uint);
    function allowance(address owner, address spender) external view returns (uint);
    function approve(address spender, uint value) external returns (bool);
    function transfer(address to, uint value) external returns (bool);
    function transferFrom(address from, address to, uint value) external returns (bool);
    function DOMAIN_SEPARATOR() external view returns (bytes32);
    function PERMIT_TYPEHASH() external pure returns (bytes32);
    function nonces(address owner) external view returns (uint);
    function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external;
    event Mint(address indexed sender, uint amount0, uint amount1);
    event Burn(address indexed sender, uint amount0, uint amount1, address indexed to);
    event Swap(
        address indexed sender,
        uint amount0In,
        uint amount1In,
        uint amount0Out,
        uint amount1Out,
        address indexed to
    );
    event Sync(uint112 reserve0, uint112 reserve1);
    function MINIMUM_LIQUIDITY() external pure returns (uint);
    function factory() external view returns (address);
    function token0() external view returns (address);
    function token1() external view returns (address);
    function getReserves() external view returns (uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast);
    function price0CumulativeLast() external view returns (uint);
    function price1CumulativeLast() external view returns (uint);
    function kLast() external view returns (uint);
    function mint(address to) external returns (uint liquidity);
    function burn(address to) external returns (uint amount0, uint amount1);
    function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data) external;
    function skim(address to) external;
    function sync() external;
    function initialize(address, address) external;
}

interface IUniswapV2Router01 {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
    function addLiquidity(
        address tokenA,
        address tokenB,
        uint amountADesired,
        uint amountBDesired,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB, uint liquidity);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETH(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountToken, uint amountETH);
    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETHWithPermit(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountToken, uint amountETH);
    function swapExactTokensForTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapTokensForExactTokens(
        uint amountOut,
        uint amountInMax,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);
    function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);

    function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB);
    function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut);
    function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn);
    function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts);
    function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts);
}

interface IUniswapV2Router02 is IUniswapV2Router01 {
    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountETH);
    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountETH);

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable;
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
}

// : Unlicense
contract HeroFloki is ERC20, Ownable {
    using SafeERC20 for IERC20;

    uint256 public constant MAX_TOTAL_FEE = 35;

    IUniswapV2Router02 public immutable router;
    address public immutable pair;

    IERC20 public busd;
    IERC20 public cake;

    MultiDividendTracker public tracker;

    mapping(address => bool) public isExcludedFromFee;

    uint256 public marketingFee;
    uint256 public busdFee;
    uint256 public cakeFee;
    uint256 public liquidityFee;

    uint256 public amountToSwap; 

    address public marketingWallet;

    bool public sellPaused;
    bool public buyPaused;
    bool public transferPaused;

    mapping(address => bool) isExcludedFromPause;

    uint256 public gasForProcessing;

    bool private inSwap;

    // EVENTS

    event ProcessedDividendTracker(
    	uint256 iterations,
    	uint256 claims,
        uint256 lastProcessedIndex,
    	uint256 gas,
    	address indexed processor
    );

    // CONSTRUCTOR

    constructor(
        /*IUniswapV2Router02 router_,
        IERC20 busd_,
        IERC20 cake_,
        address marketingWallet_*/
    ) ERC20("Hero Floki", "HERO") Ownable() {

        
        IUniswapV2Router02 router_ = IUniswapV2Router02(0x10ED43C718714eb63d5aA57B78B54704E256024E);
        IERC20 busd_ = IERC20(0xe9e7CEA3DedcA5984780Bafc599bD69ADd087D56);
        IERC20 cake_ = IERC20(0x0E09FaBB73Bd3Ade0a17ECC321fD13a19e81cE82);
        address marketingWallet_ = 0x1C083FFD428D58e11d089919abc67Ba73ae2cE1a;
        

        router = router_;
        address pair_ = IUniswapV2Factory(router_.factory()).createPair(address(this), router_.WETH());
        pair = pair_;

        busd = busd_;
        cake = cake_;

        address[] memory dividendCurrencies = new address[](2);
        dividendCurrencies[0] = address(busd);
        dividendCurrencies[1] = address(cake);
        tracker = new MultiDividendTracker(dividendCurrencies, 0, 12 hours);
        tracker.setExcludedFromDividend(address(this), true);
        tracker.setExcludedFromDividend(pair_, true);

        isExcludedFromFee[msg.sender] = true;
        isExcludedFromFee[address(this)] = true;

        amountToSwap = 1_000_000_000 * 10**18;

        marketingFee = 3;
        busdFee = 3;
        cakeFee = 3;
        liquidityFee = 3;

        marketingWallet = marketingWallet_;

        gasForProcessing = 300_000;

        _mint(msg.sender, 100_000_000_000 * 10**18);
    }

    // RECEIVE

    receive() external payable {}

    // PUBLIC FUNCTIONS

    function isExcludedFromDividend(address account) external view returns (bool) {
        return tracker.isExcludedFromDividend(account);
    }

    function cakeDividendOf(address account) external view returns (uint256) {
        return tracker.dividendOf(account, address(cake));
    }

    function busdDividendOf(address account) external view returns (uint256) {
        return tracker.dividendOf(account, address(busd));
    }

    function withdrawDividends() external {
        tracker.withdrawAllDividendsOf(msg.sender);
    }

    // RESTRICTED FUNCTIONS

    function setExcludedFromFee(address account, bool excluded) external onlyOwner {
        isExcludedFromFee[account] = excluded;
    } 

    function setExcludedFromDividend(address account, bool excluded) external onlyOwner {
        tracker.setExcludedFromDividend(account, excluded);
        tracker.setBalance(account, balanceOf(account));
    }

    function setMarketingFee(uint256 fee) external onlyOwner {
        require(fee + busdFee + cakeFee + liquidityFee <= MAX_TOTAL_FEE, "Total fees can not exceed MAX_TOTAL_FEE");
        marketingFee = fee;
    }

    function setBusdFee(uint256 fee) external onlyOwner {
        require(marketingFee + fee + cakeFee + liquidityFee <= MAX_TOTAL_FEE, "Total fees can not exceed MAX_TOTAL_FEE");
        busdFee = fee;
    }

    function setCakeFee(uint256 fee) external onlyOwner {
        require(marketingFee + busdFee + fee + liquidityFee <= MAX_TOTAL_FEE, "Total fees can not exceed MAX_TOTAL_FEE");
        cakeFee = fee;
    }

    function setLiquidityFee(uint256 fee) external onlyOwner {
        require(marketingFee + busdFee + cakeFee + fee <= MAX_TOTAL_FEE, "Total fees can not exceed MAX_TOTAL_FEE");
        liquidityFee = fee;
    }

    function setMarketingWallet(address wallet) external onlyOwner {
        require(wallet != address(0), "Marketing wallet can not be zero address");
        marketingWallet = wallet;
    }

    function setAmountToSwap(uint256 amount) external onlyOwner {
        amountToSwap = amount;
    }

    function setBuyPause(bool paused) external onlyOwner {
        buyPaused = paused;
    }

    function setSellPause(bool paused) external onlyOwner {
        sellPaused = paused;
    }

    function setTransferPause(bool paused) external onlyOwner {
        transferPaused = paused;
    }

    function setExcludedFromPause(address account, bool excluded) external onlyOwner {
        isExcludedFromPause[account] = excluded;
    }

    function setGasForProcessing(uint256 gas) external onlyOwner {
        require(gas <= 500_000, "gasForProcessing can not be higher than 500000");
        gasForProcessing = gas;
    }

    function setClaimWait(uint256 time) external onlyOwner {
        tracker.setClaimWait(time);
    }

    function mint(address to, uint256 amount) external onlyOwner {
        _mint(to, amount);
    }

    function burn(uint256 amount) external onlyOwner {
        _burn(msg.sender, amount);
        tracker.setBalance(msg.sender, balanceOf(msg.sender));
    }

    function transferAny(address token, address to, uint256 amount) external onlyOwner {
        require(token != address(this), "Can not withdraw this token");
        IERC20(token).transfer(to, amount);
    }

    function transferETH(address to, uint256 amount) external onlyOwner {
        payable(to).transfer(amount);
    }

    // INTERNAL FUNCTIONS

    function _transfer(address from, address to, uint256 amount) internal override {
        if (from == pair) {
            require(!buyPaused || isExcludedFromPause[to], "Can not buy during pause");
        } else if (to == pair) {
            require(!sellPaused || isExcludedFromPause[from], "Can not sell during pause");
        } else {
            require(!transferPaused || isExcludedFromPause[from], "Can not transfer during pause");
        }

        if (isExcludedFromFee[from] || isExcludedFromFee[to]) {
            super._transfer(from, to, amount);
        } else {
            uint256 totalFeeAmount = amount * (marketingFee + busdFee + cakeFee + liquidityFee) / 100;
            super._transfer(from, address(this), totalFeeAmount);
            super._transfer(from, to, amount - totalFeeAmount);
        }

        if (balanceOf(address(this)) >= amountToSwap && !inSwap && from != pair) {
            _swapAndDistribute();
        }

        if (!inSwap) {
	    	uint256 gas = gasForProcessing;
	    	try tracker.process(gas) returns (uint256 iterations, uint256 claims, uint256 lastProcessedIndex) {
	    		emit ProcessedDividendTracker(iterations, claims, lastProcessedIndex, gas, tx.origin);
	    	} catch {}
        }

        try tracker.setBalance(from, balanceOf(from)) {} catch {}
        try tracker.setBalance(to, balanceOf(to)) {} catch {}
    }

    function _mint(address to, uint256 amount) internal override {
        super._mint(to, amount);
        tracker.setBalance(to, balanceOf(to));
    }

    function _swapAndDistribute() internal lockTheSwap {
        uint256 totalFees = liquidityFee + marketingFee + busdFee + cakeFee;
        uint256 amountForLiquidity = balanceOf(address(this)) * liquidityFee / totalFees;
        uint256 amountForMarketing = balanceOf(address(this)) * marketingFee / totalFees;
        uint256 amountForBusd = balanceOf(address(this)) * busdFee / totalFees;
        uint256 amountForCake = balanceOf(address(this)) - amountForLiquidity - amountForMarketing - amountForBusd;

        uint256 leaveForLiquidity = amountForLiquidity / 2;
        uint256 totalToSwap = balanceOf(address(this)) - leaveForLiquidity;
        _swapTokensForETH(totalToSwap);

        uint256 totalBalance = payable(address(this)).balance;
        uint256 marketingAmountEth = totalBalance * amountForMarketing / totalToSwap;
        uint256 busdAmountEth = totalBalance * amountForBusd / totalToSwap;
        uint256 cakeAmountEth = totalBalance * amountForCake / totalToSwap;
        uint256 liquidityAmountEth = totalBalance - marketingAmountEth - busdAmountEth - cakeAmountEth;

        payable(marketingWallet).transfer(marketingAmountEth);

        _swapETHForTokens(address(busd), busdAmountEth);
        uint256 busdBalance = busd.balanceOf(address(this));
        busd.safeTransfer(address(tracker), busdBalance);
        tracker.distributeDividends(address(busd), busdBalance);

        _swapETHForTokens(address(cake), cakeAmountEth);
        uint256 cakeBalance = cake.balanceOf(address(this));
        cake.safeTransfer(address(tracker), cakeBalance);
        tracker.distributeDividends(address(cake), cakeBalance);

        _addLiquidity(leaveForLiquidity, liquidityAmountEth);
    }

    function _swapETHForTokens(address to, uint256 amount) internal {
        address[] memory path = new address[](2);
        path[0] = router.WETH();
        path[1] = to;
        router.swapExactETHForTokensSupportingFeeOnTransferTokens{value: amount}(
            0,
            path,
            address(this),
            block.timestamp
        );
    }

    function _swapTokensForETH(uint256 amount) internal {
        _approve(address(this), address(router), type(uint256).max);
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = router.WETH();
        router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            amount,
            0,
            path,
            address(this),
            block.timestamp
        );
    }

    function _addLiquidity(uint256 tokenAmount, uint256 ethAmount) internal {
        router.addLiquidityETH{value: ethAmount}(
            address(this),
            tokenAmount,
            0,
            0,
            address(this),
            block.timestamp
        );
    }

    // MODIFIERS

    modifier lockTheSwap {
        require(!inSwap, "Can not lock the swap");
        inSwap = true;
        _;
        inSwap = false;
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"iterations","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"claims","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"lastProcessedIndex","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"gas","type":"uint256"},{"indexed":true,"internalType":"address","name":"processor","type":"address"}],"name":"ProcessedDividendTracker","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"MAX_TOTAL_FEE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"amountToSwap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"busd","outputs":[{"internalType":"contract IERC20","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"busdDividendOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"busdFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyPaused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"cake","outputs":[{"internalType":"contract IERC20","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"cakeDividendOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"cakeFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"gasForProcessing","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromDividend","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isExcludedFromFee","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"liquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"marketingFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"marketingWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"mint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellPaused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"setAmountToSwap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"fee","type":"uint256"}],"name":"setBusdFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"paused","type":"bool"}],"name":"setBuyPause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"fee","type":"uint256"}],"name":"setCakeFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"time","type":"uint256"}],"name":"setClaimWait","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"setExcludedFromDividend","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"setExcludedFromFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"setExcludedFromPause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"gas","type":"uint256"}],"name":"setGasForProcessing","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"fee","type":"uint256"}],"name":"setLiquidityFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"fee","type":"uint256"}],"name":"setMarketingFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"wallet","type":"address"}],"name":"setMarketingWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"paused","type":"bool"}],"name":"setSellPause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"paused","type":"bool"}],"name":"setTransferPause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tracker","outputs":[{"internalType":"contract MultiDividendTracker","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferAny","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferETH","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"transferPaused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdrawDividends","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

60c06040523480156200001157600080fd5b50604080518082018252600a8152694865726f20466c6f6b6960b01b6020808301918252835180850190945260048452634845524f60e01b908401528151919291620000609160039162000713565b5080516200007690600490602084019062000713565b505050620000936200008d6200052860201b60201c565b6200052c565b7f10ed43c718714eb63d5aa57b78b54704e256024e0000000000000000000000006080526040805163c45a015560e01b815290517310ed43c718714eb63d5aa57b78b54704e256024e9173e9e7cea3dedca5984780bafc599bd69add087d5691730e09fabb73bd3ade0a17ecc321fd13a19e81ce8291731c083ffd428d58e11d089919abc67ba73ae2ce1a91600091869163c45a015591600480820192602092909190829003018186803b1580156200014b57600080fd5b505afa15801562000160573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001869190620007c7565b6001600160a01b031663c9c6539630876001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015620001cf57600080fd5b505afa158015620001e4573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200020a9190620007c7565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b1580156200025357600080fd5b505af115801562000268573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200028e9190620007c7565b606081811b6001600160601b03191660a052600680546001600160a01b03199081166001600160a01b03898116919091179092556007805490911691871691909117905560408051600280825292810182529293506000929190602083019080368337505060065482519293506001600160a01b0316918391506000906200031a576200031a620008b5565b6001600160a01b0392831660209182029290920101526007548251911690829060019081106200034e576200034e620008b5565b60200260200101906001600160a01b031690816001600160a01b03168152505080600061a8c06040516200038290620007a2565b6200039093929190620007f9565b604051809103906000f080158015620003ad573d6000803e3d6000fd5b50600880546001600160a01b0319166001600160a01b0392909216918217905560405163622871ef60e11b81523060048201526001602482015263c450e3de90604401600060405180830381600087803b1580156200040b57600080fd5b505af115801562000420573d6000803e3d6000fd5b505060085460405163622871ef60e11b81526001600160a01b03868116600483015260016024830152909116925063c450e3de9150604401600060405180830381600087803b1580156200047357600080fd5b505af115801562000488573d6000803e3d6000fd5b5050336000818152600960205260408082208054600160ff19918216811790925530845291909220805490911690911790556b033b2e3c9fd0803ce8000000600e556003600a819055600b819055600c819055600d55600f80546001600160a01b0319166001600160a01b038816179055620493e06011556200051c925090506c01431e0fae6d7217caa00000006200057e565b505050505050620008cb565b3390565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6200059582826200062b60201b620017971760201c565b6008546001600160a01b031663e30443bc83620005c7816001600160a01b031660009081526020819052604090205490565b6040516001600160e01b031960e085901b1681526001600160a01b0390921660048301526024820152604401600060405180830381600087803b1580156200060e57600080fd5b505af115801562000623573d6000803e3d6000fd5b505050505050565b6001600160a01b038216620006865760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015260640160405180910390fd5b80600260008282546200069a919062000851565b90915550506001600160a01b03821660009081526020819052604081208054839290620006c990849062000851565b90915550506040518181526001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b828054620007219062000878565b90600052602060002090601f01602090048101928262000745576000855562000790565b82601f106200076057805160ff191683800117855562000790565b8280016001018555821562000790579182015b828111156200079057825182559160200191906001019062000773565b506200079e929150620007b0565b5090565b6118658062003a9783390190565b5b808211156200079e5760008155600101620007b1565b600060208284031215620007da57600080fd5b81516001600160a01b0381168114620007f257600080fd5b9392505050565b606080825284519082018190526000906020906080840190828801845b828110156200083d5781516001600160a01b03168452928401929084019060010162000816565b505050908301949094525060400152919050565b600082198211156200087357634e487b7160e01b600052601160045260246000fd5b500190565b600181811c908216806200088d57607f821691505b60208210811415620008af57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052603260045260246000fd5b60805160601c60a05160601c61316162000936600039600081816107e50152818161199c01528181611a580152611c690152600081816109ad0152818161266a015281816126e8015281816127af015281816128120152818161290d0152612a0d01526131616000f3fe60806040526004361061031d5760003560e01c806375f0a874116101ab578063a9059cbb116100f7578063eac13e6111610095578063f43b78ff1161006f578063f43b78ff1461095a578063f52bccad1461097b578063f887ea401461099b578063fb2cb34e146109cf57600080fd5b8063eac13e6114610904578063ed07d3241461091a578063f2fde38b1461093a57600080fd5b8063c450e3de116100d1578063c450e3de1461085d578063dce174841461087d578063dd62ed3e1461089d578063e1017332146108e357600080fd5b8063a9059cbb14610807578063bbcfb50e14610827578063c03669c41461084757600080fd5b806395d89b4111610164578063a34efa3e1161013e578063a34efa3e14610773578063a3c9bb5514610793578063a457c2d7146107b3578063a8aa1b31146107d357600080fd5b806395d89b411461073257806398118cb4146107475780639c1b8af51461075d57600080fd5b806375f0a8741461067f5780637b1a49091461069f5780637f635cc0146106bf5780638da5cb5b146106d457806391732cd2146106f25780639358037a1461071257600080fd5b80633d2dea631161026a5780635aef4a78116102235780636612e66f116101fd5780636612e66f146106145780636b67c4df1461063457806370a082311461064a578063715018a61461066a57600080fd5b80635aef4a78146105b45780635d098b38146105d4578063625e764c146105f457600080fd5b80633d2dea63146104ee5780633d2f29ee1461050e57806340c10f191461052457806342966c68146105445780635342acb4146105645780635960e46d1461059457600080fd5b80632e92abdd116102d75780633399462e116102b15780633399462e14610456578063357bf15c1461047657806339509351146104965780633ca5b234146104b657600080fd5b80632e92abdd146104055780632fc402b91461041a578063313ce5671461043a57600080fd5b80621860ab1461032957806306fdde031461034b578063095ea7b3146103765780630bc22944146103a657806318160ddd146103c657806323b872dd146103e557600080fd5b3661032457005b600080fd5b34801561033557600080fd5b50610349610344366004612e25565b6109f0565b005b34801561035757600080fd5b50610360610a70565b60405161036d9190612f1a565b60405180910390f35b34801561038257600080fd5b50610396610391366004612dbf565b610b02565b604051901515815260200161036d565b3480156103b257600080fd5b506103496103c1366004612e25565b610b18565b3480156103d257600080fd5b506002545b60405190815260200161036d565b3480156103f157600080fd5b50610396610400366004612d50565b610ba4565b34801561041157600080fd5b50610349610c50565b34801561042657600080fd5b50610396610435366004612cdd565b610cd0565b34801561044657600080fd5b506040516012815260200161036d565b34801561046257600080fd5b506103d7610471366004612cdd565b610d54565b34801561048257600080fd5b50610349610491366004612e25565b610de1565b3480156104a257600080fd5b506103966104b1366004612dbf565b610e58565b3480156104c257600080fd5b506006546104d6906001600160a01b031681565b6040516001600160a01b03909116815260200161036d565b3480156104fa57600080fd5b50610349610509366004612d50565b610e94565b34801561051a57600080fd5b506103d7600b5481565b34801561053057600080fd5b5061034961053f366004612dbf565b610f9f565b34801561055057600080fd5b5061034961055f366004612e25565b610fd7565b34801561057057600080fd5b5061039661057f366004612cdd565b60096020526000908152604090205460ff1681565b3480156105a057600080fd5b506103496105af366004612e25565b611057565b3480156105c057600080fd5b506103496105cf366004612deb565b6110f0565b3480156105e057600080fd5b506103496105ef366004612cdd565b611138565b34801561060057600080fd5b5061034961060f366004612e25565b6111eb565b34801561062057600080fd5b5061034961062f366004612d91565b611262565b34801561064057600080fd5b506103d7600a5481565b34801561065657600080fd5b506103d7610665366004612cdd565b6112b7565b34801561067657600080fd5b506103496112d2565b34801561068b57600080fd5b50600f546104d6906001600160a01b031681565b3480156106ab57600080fd5b506103496106ba366004612dbf565b611308565b3480156106cb57600080fd5b506103d7602381565b3480156106e057600080fd5b506005546001600160a01b03166104d6565b3480156106fe57600080fd5b5061034961070d366004612d91565b61136d565b34801561071e57600080fd5b5061034961072d366004612deb565b6113c2565b34801561073e57600080fd5b5061036061140a565b34801561075357600080fd5b506103d7600d5481565b34801561076957600080fd5b506103d760115481565b34801561077f57600080fd5b5061034961078e366004612e25565b611419565b34801561079f57600080fd5b506103496107ae366004612e25565b611448565b3480156107bf57600080fd5b506103966107ce366004612dbf565b6114bf565b3480156107df57600080fd5b506104d67f000000000000000000000000000000000000000000000000000000000000000081565b34801561081357600080fd5b50610396610822366004612dbf565b611558565b34801561083357600080fd5b50610349610842366004612deb565b611565565b34801561085357600080fd5b506103d7600c5481565b34801561086957600080fd5b50610349610878366004612d91565b6115ad565b34801561088957600080fd5b506007546104d6906001600160a01b031681565b3480156108a957600080fd5b506103d76108b8366004612d17565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b3480156108ef57600080fd5b50600f5461039690600160a01b900460ff1681565b34801561091057600080fd5b506103d7600e5481565b34801561092657600080fd5b506103d7610935366004612cdd565b6116be565b34801561094657600080fd5b50610349610955366004612cdd565b6116ff565b34801561096657600080fd5b50600f5461039690600160a81b900460ff1681565b34801561098757600080fd5b506008546104d6906001600160a01b031681565b3480156109a757600080fd5b506104d67f000000000000000000000000000000000000000000000000000000000000000081565b3480156109db57600080fd5b50600f5461039690600160b01b900460ff1681565b6005546001600160a01b03163314610a235760405162461bcd60e51b8152600401610a1a90612f4d565b60405180910390fd5b6023600d54600c5483600a54610a399190613005565b610a439190613005565b610a4d9190613005565b1115610a6b5760405162461bcd60e51b8152600401610a1a90612f82565b600b55565b606060038054610a7f906130a1565b80601f0160208091040260200160405190810160405280929190818152602001828054610aab906130a1565b8015610af85780601f10610acd57610100808354040283529160200191610af8565b820191906000526020600020905b815481529060010190602001808311610adb57829003601f168201915b5050505050905090565b6000610b0f338484611876565b50600192915050565b6005546001600160a01b03163314610b425760405162461bcd60e51b8152600401610a1a90612f4d565b6008546040516302f08a5160e21b8152600481018390526001600160a01b0390911690630bc22944906024015b600060405180830381600087803b158015610b8957600080fd5b505af1158015610b9d573d6000803e3d6000fd5b5050505050565b6000610bb184848461199a565b6001600160a01b038416600090815260016020908152604080832033845290915290205482811015610c365760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b6064820152608401610a1a565b610c438533858403611876565b60019150505b9392505050565b6008546040516362969c1360e01b81523360048201526001600160a01b03909116906362969c1390602401602060405180830381600087803b158015610c9557600080fd5b505af1158015610ca9573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ccd9190612e08565b50565b600854604051632fc402b960e01b81526001600160a01b0383811660048301526000921690632fc402b99060240160206040518083038186803b158015610d1657600080fd5b505afa158015610d2a573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d4e9190612e08565b92915050565b6008546007546040516365c1de6b60e11b81526001600160a01b0384811660048301529182166024820152600092919091169063cb83bcd6906044015b60206040518083038186803b158015610da957600080fd5b505afa158015610dbd573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d4e9190612e3e565b6005546001600160a01b03163314610e0b5760405162461bcd60e51b8152600401610a1a90612f4d565b602381600c54600b54600a54610e219190613005565b610e2b9190613005565b610e359190613005565b1115610e535760405162461bcd60e51b8152600401610a1a90612f82565b600d55565b3360008181526001602090815260408083206001600160a01b03871684529091528120549091610b0f918590610e8f908690613005565b611876565b6005546001600160a01b03163314610ebe5760405162461bcd60e51b8152600401610a1a90612f4d565b6001600160a01b038316301415610f175760405162461bcd60e51b815260206004820152601b60248201527f43616e206e6f74207769746864726177207468697320746f6b656e00000000006044820152606401610a1a565b60405163a9059cbb60e01b81526001600160a01b0383811660048301526024820183905284169063a9059cbb90604401602060405180830381600087803b158015610f6157600080fd5b505af1158015610f75573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f999190612e08565b50505050565b6005546001600160a01b03163314610fc95760405162461bcd60e51b8152600401610a1a90612f4d565b610fd38282611e78565b5050565b6005546001600160a01b031633146110015760405162461bcd60e51b8152600401610a1a90612f4d565b61100b3382611e9d565b6008546001600160a01b031663e30443bc33611026816112b7565b6040516001600160e01b031960e085901b1681526001600160a01b0390921660048301526024820152604401610b6f565b6005546001600160a01b031633146110815760405162461bcd60e51b8152600401610a1a90612f4d565b6207a1208111156110eb5760405162461bcd60e51b815260206004820152602e60248201527f676173466f7250726f63657373696e672063616e206e6f74206265206869676860448201526d06572207468616e203530303030360941b6064820152608401610a1a565b601155565b6005546001600160a01b0316331461111a5760405162461bcd60e51b8152600401610a1a90612f4d565b600f8054911515600160a81b0260ff60a81b19909216919091179055565b6005546001600160a01b031633146111625760405162461bcd60e51b8152600401610a1a90612f4d565b6001600160a01b0381166111c95760405162461bcd60e51b815260206004820152602860248201527f4d61726b6574696e672077616c6c65742063616e206e6f74206265207a65726f604482015267206164647265737360c01b6064820152608401610a1a565b600f80546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b031633146112155760405162461bcd60e51b8152600401610a1a90612f4d565b6023600d54600c54600b548461122b9190613005565b6112359190613005565b61123f9190613005565b111561125d5760405162461bcd60e51b8152600401610a1a90612f82565b600a55565b6005546001600160a01b0316331461128c5760405162461bcd60e51b8152600401610a1a90612f4d565b6001600160a01b03919091166000908152600960205260409020805460ff1916911515919091179055565b6001600160a01b031660009081526020819052604090205490565b6005546001600160a01b031633146112fc5760405162461bcd60e51b8152600401610a1a90612f4d565b6113066000611feb565b565b6005546001600160a01b031633146113325760405162461bcd60e51b8152600401610a1a90612f4d565b6040516001600160a01b0383169082156108fc029083906000818181858888f19350505050158015611368573d6000803e3d6000fd5b505050565b6005546001600160a01b031633146113975760405162461bcd60e51b8152600401610a1a90612f4d565b6001600160a01b03919091166000908152601060205260409020805460ff1916911515919091179055565b6005546001600160a01b031633146113ec5760405162461bcd60e51b8152600401610a1a90612f4d565b600f8054911515600160b01b0260ff60b01b19909216919091179055565b606060048054610a7f906130a1565b6005546001600160a01b031633146114435760405162461bcd60e51b8152600401610a1a90612f4d565b600e55565b6005546001600160a01b031633146114725760405162461bcd60e51b8152600401610a1a90612f4d565b6023600d5482600b54600a546114889190613005565b6114929190613005565b61149c9190613005565b11156114ba5760405162461bcd60e51b8152600401610a1a90612f82565b600c55565b3360009081526001602090815260408083206001600160a01b0386168452909152812054828110156115415760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610a1a565b61154e3385858403611876565b5060019392505050565b6000610b0f33848461199a565b6005546001600160a01b0316331461158f5760405162461bcd60e51b8152600401610a1a90612f4d565b600f8054911515600160a01b0260ff60a01b19909216919091179055565b6005546001600160a01b031633146115d75760405162461bcd60e51b8152600401610a1a90612f4d565b60085460405163622871ef60e11b81526001600160a01b03848116600483015283151560248301529091169063c450e3de90604401600060405180830381600087803b15801561162657600080fd5b505af115801561163a573d6000803e3d6000fd5b50506008546001600160a01b0316915063e30443bc90508361165b816112b7565b6040516001600160e01b031960e085901b1681526001600160a01b03909216600483015260248201526044015b600060405180830381600087803b1580156116a257600080fd5b505af11580156116b6573d6000803e3d6000fd5b505050505050565b6008546006546040516365c1de6b60e11b81526001600160a01b0384811660048301529182166024820152600092919091169063cb83bcd690604401610d91565b6005546001600160a01b031633146117295760405162461bcd60e51b8152600401610a1a90612f4d565b6001600160a01b03811661178e5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610a1a565b610ccd81611feb565b6001600160a01b0382166117ed5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401610a1a565b80600260008282546117ff9190613005565b90915550506001600160a01b0382166000908152602081905260408120805483929061182c908490613005565b90915550506040518181526001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b6001600160a01b0383166118d85760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610a1a565b6001600160a01b0382166119395760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610a1a565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316836001600160a01b03161415611a5657600f54600160a81b900460ff161580611a0557506001600160a01b03821660009081526010602052604090205460ff165b611a515760405162461bcd60e51b815260206004820152601860248201527f43616e206e6f742062757920647572696e6720706175736500000000000000006044820152606401610a1a565b611b8a565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b03161415611b0d57600f54600160a01b900460ff161580611ac157506001600160a01b03831660009081526010602052604090205460ff165b611a515760405162461bcd60e51b815260206004820152601960248201527f43616e206e6f742073656c6c20647572696e67207061757365000000000000006044820152606401610a1a565b600f54600160b01b900460ff161580611b3e57506001600160a01b03831660009081526010602052604090205460ff165b611b8a5760405162461bcd60e51b815260206004820152601d60248201527f43616e206e6f74207472616e7366657220647572696e672070617573650000006044820152606401610a1a565b6001600160a01b03831660009081526009602052604090205460ff1680611bc957506001600160a01b03821660009081526009602052604090205460ff165b15611bde57611bd983838361203d565b611c43565b60006064600d54600c54600b54600a54611bf89190613005565b611c029190613005565b611c0c9190613005565b611c16908461303f565b611c20919061301d565b9050611c2d84308361203d565b611c418484611c3c848661305e565b61203d565b505b600e54611c4f306112b7565b10158015611c60575060125460ff16155b8015611c9e57507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316836001600160a01b031614155b15611cab57611cab61220b565b60125460ff16611d8a576011546008546040516001624d3b8760e01b03198152600481018390526001600160a01b039091169063ffb2c47990602401606060405180830381600087803b158015611d0157600080fd5b505af1925050508015611d31575060408051601f3d908101601f19168201909252611d2e91810190612e57565b60015b611d3a57611d88565b60408051848152602081018490529081018290526060810185905232907ff8bf74042f2c0047c9f029f0062bc93f63d378a5f5c847777d0538076fa8ead89060800160405180910390a25050505b505b6008546001600160a01b031663e30443bc84611da5816112b7565b6040516001600160e01b031960e085901b1681526001600160a01b0390921660048301526024820152604401600060405180830381600087803b158015611deb57600080fd5b505af1925050508015611dfc575060015b506008546001600160a01b031663e30443bc83611e18816112b7565b6040516001600160e01b031960e085901b1681526001600160a01b0390921660048301526024820152604401600060405180830381600087803b158015611e5e57600080fd5b505af1925050508015611e6f575060015b61136857505050565b611e828282611797565b6008546001600160a01b031663e30443bc8361165b816112b7565b6001600160a01b038216611efd5760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610a1a565b6001600160a01b03821660009081526020819052604090205481811015611f715760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b6064820152608401610a1a565b6001600160a01b0383166000908152602081905260408120838303905560028054849290611fa090849061305e565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a3505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b0383166120a15760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610a1a565b6001600160a01b0382166121035760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610a1a565b6001600160a01b0383166000908152602081905260409020548181101561217b5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610a1a565b6001600160a01b038085166000908152602081905260408082208585039055918516815290812080548492906121b2908490613005565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040516121fe91815260200190565b60405180910390a3610f99565b60125460ff16156122565760405162461bcd60e51b8152602060048201526015602482015274043616e206e6f74206c6f636b20746865207377617605c1b6044820152606401610a1a565b6012805460ff19166001179055600c54600b54600a54600d54600093929161227d91613005565b6122879190613005565b6122919190613005565b9050600081600d546122a2306112b7565b6122ac919061303f565b6122b6919061301d565b9050600082600a546122c7306112b7565b6122d1919061303f565b6122db919061301d565b9050600083600b546122ec306112b7565b6122f6919061303f565b612300919061301d565b90506000818385612310306112b7565b61231a919061305e565b612324919061305e565b61232e919061305e565b9050600061233d60028661301d565b905060008161234b306112b7565b612355919061305e565b905061236081612664565b303160008261236f888461303f565b612379919061301d565b9050600083612388888561303f565b612392919061301d565b90506000846123a1888661303f565b6123ab919061301d565b9050600081836123bb868861305e565b6123c5919061305e565b6123cf919061305e565b600f546040519192506001600160a01b03169085156108fc029086906000818181858888f1935050505015801561240a573d6000803e3d6000fd5b50600654612421906001600160a01b0316846127ef565b6006546040516370a0823160e01b81523060048201526000916001600160a01b0316906370a082319060240160206040518083038186803b15801561246557600080fd5b505afa158015612479573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061249d9190612e3e565b6008546006549192506124bd916001600160a01b03908116911683612984565b6008546006546040516364b7571f60e01b81526001600160a01b039182166004820152602481018490529116906364b7571f90604401600060405180830381600087803b15801561250d57600080fd5b505af1158015612521573d6000803e3d6000fd5b505060075461253c92506001600160a01b03169050846127ef565b6007546040516370a0823160e01b81523060048201526000916001600160a01b0316906370a082319060240160206040518083038186803b15801561258057600080fd5b505afa158015612594573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906125b89190612e3e565b6008546007549192506125d8916001600160a01b03908116911683612984565b6008546007546040516364b7571f60e01b81526001600160a01b039182166004820152602481018490529116906364b7571f90604401600060405180830381600087803b15801561262857600080fd5b505af115801561263c573d6000803e3d6000fd5b5050505061264a89846129d6565b50506012805460ff19169055505050505050505050505050565b612691307f0000000000000000000000000000000000000000000000000000000000000000600019611876565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106126c6576126c66130f2565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b15801561273f57600080fd5b505afa158015612753573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906127779190612cfa565b8160018151811061278a5761278a6130f2565b6001600160a01b03928316602091820292909201015260405163791ac94760e01b81527f00000000000000000000000000000000000000000000000000000000000000009091169063791ac94790611688908590600090869030904290600401612fc9565b6040805160028082526060820183526000926020830190803683370190505090507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b15801561286957600080fd5b505afa15801561287d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906128a19190612cfa565b816000815181106128b4576128b46130f2565b60200260200101906001600160a01b031690816001600160a01b03168152505082816001815181106128e8576128e86130f2565b6001600160a01b03928316602091820292909201015260405163b6f9de9560e01b81527f00000000000000000000000000000000000000000000000000000000000000009091169063b6f9de9590849061294d90600090869030904290600401612ee5565b6000604051808303818588803b15801561296657600080fd5b505af115801561297a573d6000803e3d6000fd5b5050505050505050565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b179052611368908490612a93565b60405163f305d71960e01b8152306004820181905260248201849052600060448301819052606483015260848201524260a48201527f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03169063f305d71990839060c4016060604051808303818588803b158015612a5a57600080fd5b505af1158015612a6e573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610b9d9190612e57565b6000612ae8826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b0316612b659092919063ffffffff16565b8051909150156113685780806020019051810190612b069190612e08565b6113685760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401610a1a565b6060612b748484600085612b7c565b949350505050565b606082471015612bdd5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b6064820152608401610a1a565b843b612c2b5760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610a1a565b600080866001600160a01b03168587604051612c479190612ec9565b60006040518083038185875af1925050503d8060008114612c84576040519150601f19603f3d011682016040523d82523d6000602084013e612c89565b606091505b5091509150612c99828286612ca4565b979650505050505050565b60608315612cb3575081610c49565b825115612cc35782518084602001fd5b8160405162461bcd60e51b8152600401610a1a9190612f1a565b600060208284031215612cef57600080fd5b8135610c4981613108565b600060208284031215612d0c57600080fd5b8151610c4981613108565b60008060408385031215612d2a57600080fd5b8235612d3581613108565b91506020830135612d4581613108565b809150509250929050565b600080600060608486031215612d6557600080fd5b8335612d7081613108565b92506020840135612d8081613108565b929592945050506040919091013590565b60008060408385031215612da457600080fd5b8235612daf81613108565b91506020830135612d458161311d565b60008060408385031215612dd257600080fd5b8235612ddd81613108565b946020939093013593505050565b600060208284031215612dfd57600080fd5b8135610c498161311d565b600060208284031215612e1a57600080fd5b8151610c498161311d565b600060208284031215612e3757600080fd5b5035919050565b600060208284031215612e5057600080fd5b5051919050565b600080600060608486031215612e6c57600080fd5b8351925060208401519150604084015190509250925092565b600081518084526020808501945080840160005b83811015612ebe5781516001600160a01b031687529582019590820190600101612e99565b509495945050505050565b60008251612edb818460208701613075565b9190910192915050565b848152608060208201526000612efe6080830186612e85565b6001600160a01b03949094166040830152506060015292915050565b6020815260008251806020840152612f39816040850160208701613075565b601f01601f19169190910160400192915050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526027908201527f546f74616c20666565732063616e206e6f7420657863656564204d41585f544f60408201526654414c5f46454560c81b606082015260800190565b85815284602082015260a060408201526000612fe860a0830186612e85565b6001600160a01b0394909416606083015250608001529392505050565b60008219821115613018576130186130dc565b500190565b60008261303a57634e487b7160e01b600052601260045260246000fd5b500490565b6000816000190483118215151615613059576130596130dc565b500290565b600082821015613070576130706130dc565b500390565b60005b83811015613090578181015183820152602001613078565b83811115610f995750506000910152565b600181811c908216806130b557607f821691505b602082108114156130d657634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b6001600160a01b0381168114610ccd57600080fd5b8015158114610ccd57600080fdfea264697066735822122016aae4027b7a56bb0415e9e20152e7da445738766042502fffdf12b1c8cef0ab64736f6c6343000807003360806040523480156200001157600080fd5b506040516200186538038062001865833981016040819052620000349162000153565b6200003f3362000065565b825162000054906002906020860190620000b5565b50600591909155600c555062000255565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b8280548282559060005260206000209081019282156200010d579160200282015b828111156200010d57825182546001600160a01b0319166001600160a01b03909116178255602090920191600190910190620000d6565b506200011b9291506200011f565b5090565b5b808211156200011b576000815560010162000120565b80516001600160a01b03811681146200014e57600080fd5b919050565b6000806000606084860312156200016957600080fd5b83516001600160401b03808211156200018157600080fd5b818601915086601f8301126200019657600080fd5b8151602082821115620001ad57620001ad6200023f565b8160051b604051601f19603f83011681018181108682111715620001d557620001d56200023f565b604052838152828101945085830182870184018c1015620001f557600080fd5b600096505b8487101562000223576200020e8162000136565b865260019690960195948301948301620001fa565b5091890151604090990151919a98995090979650505050505050565b634e487b7160e01b600052604160045260246000fd5b61160080620002656000396000f3fe60806040526004361061014f5760003560e01c8063715018a6116100b6578063c450e3de1161006f578063c450e3de146103e2578063cb83bcd614610402578063e30443bc14610422578063e6f083f414610442578063f2fde38b1461048d578063ffb2c479146104ad57600080fd5b8063715018a61461032f5780638da5cb5b1461034457806396e0eb951461037657806397bf79351461038c5780639c53c0ca146103ac578063ad7a672f146103cc57600080fd5b80633122d242116101085780633122d24214610284578063535c4d701461029957806362969c13146102b957806362a03cf9146102d957806364b7571f146102f95780636f2789ec1461031957600080fd5b806303c83302146101995780630bc22944146101a1578063226cfa3d146101c157806327e235e3146102015780632fc402b91461022e5780633009a6091461026e57600080fd5b36610194576000546001600160a01b031633146101875760405162461bcd60e51b815260040161017e9061137b565b60405180910390fd5b6101926000346104e8565b005b600080fd5b61019261053b565b3480156101ad57600080fd5b506101926101bc366004611313565b610572565b3480156101cd57600080fd5b506101ee6101dc366004611247565b600b6020526000908152604090205481565b6040519081526020015b60405180910390f35b34801561020d57600080fd5b506101ee61021c366004611247565b60036020526000908152604090205481565b34801561023a57600080fd5b5061025e610249366004611247565b60066020526000908152604090205460ff1681565b60405190151581526020016101f8565b34801561027a57600080fd5b506101ee600d5481565b34801561029057600080fd5b506101926105a1565b3480156102a557600080fd5b506101ee6102b4366004611262565b6105ad565b3480156102c557600080fd5b5061025e6102d4366004611247565b610627565b3480156102e557600080fd5b5061025e6102f4366004611262565b610698565b34801561030557600080fd5b506101926103143660046112cc565b610773565b34801561032557600080fd5b506101ee600c5481565b34801561033b57600080fd5b506101926107a7565b34801561035057600080fd5b506000546001600160a01b03165b6040516001600160a01b0390911681526020016101f8565b34801561038257600080fd5b506101ee60055481565b34801561039857600080fd5b5061035e6103a7366004611313565b6107db565b3480156103b857600080fd5b506101926103c7366004611247565b610805565b3480156103d857600080fd5b506101ee60045481565b3480156103ee57600080fd5b506101926103fd366004611295565b61080f565b34801561040e57600080fd5b506101ee61041d366004611262565b61093c565b34801561042e57600080fd5b5061019261043d3660046112cc565b61097c565b34801561044e57600080fd5b506101ee61045d366004611262565b6001600160a01b038082166000908152600160209081526040808320938616835260029093019052205492915050565b34801561049957600080fd5b506101926104a8366004611247565b6109eb565b3480156104b957600080fd5b506104cd6104c8366004611313565b610a83565b604080519384526020840192909252908201526060016101f8565b8015610537576004546104ff600160801b836114b0565b6105099190611409565b6001600160a01b038316600090815260016020526040812080549091906105319084906113f1565b90915550505b5050565b6000546001600160a01b031633146105655760405162461bcd60e51b815260040161017e9061137b565b6105706000346104e8565b565b6000546001600160a01b0316331461059c5760405162461bcd60e51b815260040161017e9061137b565b600c55565b6105aa33610627565b50565b6001600160a01b0380821660008181526001602081815260408084209588168452858301825280842054600383529084205494845291905292549092600160801b926106149261060591610600916114b0565b610b8d565b61060f91906113b0565b610bfb565b61061e9190611409565b90505b92915050565b60008060005b60025460ff8216101561069157600061067060028360ff1681548110610655576106556115a6565b6000918252602090912001546001600160a01b031686610698565b9050828061067b5750805b925050808061068990611570565b91505061062d565b5092915050565b6000806106a5838561093c565b90508015610769576001600160a01b03808516600090815260016020908152604080832093871683526002909301905290812080548392906106e89084906113f1565b90915550506001600160a01b038084166000908152600b60205260409020429055841661074b576040516001600160a01b0384169082156108fc029083906000818181858888f19350505050158015610745573d6000803e3d6000fd5b5061075f565b61075f6001600160a01b0385168483610c4d565b6001915050610621565b5060009392505050565b6000546001600160a01b0316331461079d5760405162461bcd60e51b815260040161017e9061137b565b61053782826104e8565b6000546001600160a01b031633146107d15760405162461bcd60e51b815260040161017e9061137b565b6105706000610ca4565b600281815481106107eb57600080fd5b6000918252602090912001546001600160a01b0316905081565b6105378133610698565b6000546001600160a01b031633146108395760405162461bcd60e51b815260040161017e9061137b565b6001600160a01b0382166000908152600660205260409020805460ff191682158015919091179091556108dd5760405163131836e760e21b8152600760048201526001600160a01b03831660248201527328aa90e708b1c26798f91309b745df50ca2cb15d90634c60db9c906044015b60006040518083038186803b1580156108c157600080fd5b505af41580156108d5573d6000803e3d6000fd5b505050505050565b6001600160a01b03821660008181526003602052604090819020549051632f0ad01760e21b815260076004820152602481019290925260448201527328aa90e708b1c26798f91309b745df50ca2cb15d9063bc2b405c906064016108a9565b6001600160a01b0380821660009081526001602090815260408083209386168352600290930190529081205461097284846105ad565b61061e919061150e565b6000546001600160a01b031633146109a65760405162461bcd60e51b815260040161017e9061137b565b60055481101580156109d157506001600160a01b03821660009081526006602052604090205460ff16155b156109e0576105378282610cf4565b610537826000610cf4565b6000546001600160a01b03163314610a155760405162461bcd60e51b815260040161017e9061137b565b6001600160a01b038116610a7a5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161017e565b6105aa81610ca4565b6007546000908190819080610aa3575050600d5460009250829150610b86565b600d546000805a90506000805b8984108015610abe57508582105b15610b755784610acd81611555565b60075490965086109050610ae057600094505b600060076000018681548110610af857610af86115a6565b6000918252602090912001546001600160a01b03169050610b1881610f89565b8015610b285750610b2881610627565b15610b3b5781610b3781611555565b9250505b82610b4581611555565b93505060005a905080851115610b6c57610b5f818661150e565b610b6990876113f1565b95505b9350610ab09050565b600d85905590975095509193505050505b9193909250565b60006001600160ff1b03821115610bf75760405162461bcd60e51b815260206004820152602860248201527f53616665436173743a2076616c756520646f65736e27742066697420696e2061604482015267371034b73a191a9b60c11b606482015260840161017e565b5090565b600080821215610bf75760405162461bcd60e51b815260206004820181905260248201527f53616665436173743a2076616c7565206d75737420626520706f736974697665604482015260640161017e565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b179052610c9f908490610fdf565b505050565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6001600160a01b03821660009081526003602052604090205481146105375760005b60025460ff82161015610e2457610d6a6001600060028460ff1681548110610d4057610d406115a6565b60009182526020808320909101546001600160a01b03168352820192909252604001902054610b8d565b610d7383610b8d565b6001600160a01b038516600090815260036020526040902054610d9590610b8d565b610d9f91906114cf565b610da9919061142b565b6001600060028460ff1681548110610dc357610dc36115a6565b60009182526020808320909101546001600160a01b0390811684528382019490945260409283018220938816825260019390930190925281208054909190610e0c9084906113b0565b90915550819050610e1c81611570565b915050610d16565b506001600160a01b038216600090815260036020526040902054610ec057604051632f0ad01760e21b8152600760048201526001600160a01b0383166024820152604481018290527328aa90e708b1c26798f91309b745df50ca2cb15d9063bc2b405c9060640160006040518083038186803b158015610ea357600080fd5b505af4158015610eb7573d6000803e3d6000fd5b50505050610f38565b80610f385760405163131836e760e21b8152600760048201526001600160a01b03831660248201527328aa90e708b1c26798f91309b745df50ca2cb15d90634c60db9c9060440160006040518083038186803b158015610f1f57600080fd5b505af4158015610f33573d6000803e3d6000fd5b505050505b6001600160a01b0382166000908152600360205260409020546004548291610f5f9161150e565b610f6991906113f1565b6004556001600160a01b0391909116600090815260036020526040902055565b6001600160a01b0381166000908152600b6020526040812054421015610fb157506000919050565b600c546001600160a01b0383166000908152600b6020526040902054610fd7904261150e565b101592915050565b6000611034826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b03166110b19092919063ffffffff16565b805190915015610c9f578080602001905181019061105291906112f6565b610c9f5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b606482015260840161017e565b60606110c084846000856110ca565b90505b9392505050565b60608247101561112b5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b606482015260840161017e565b843b6111795760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015260640161017e565b600080866001600160a01b03168587604051611195919061132c565b60006040518083038185875af1925050503d80600081146111d2576040519150601f19603f3d011682016040523d82523d6000602084013e6111d7565b606091505b50915091506111e78282866111f2565b979650505050505050565b606083156112015750816110c3565b8251156112115782518084602001fd5b8160405162461bcd60e51b815260040161017e9190611348565b80356001600160a01b038116811461124257600080fd5b919050565b60006020828403121561125957600080fd5b61061e8261122b565b6000806040838503121561127557600080fd5b61127e8361122b565b915061128c6020840161122b565b90509250929050565b600080604083850312156112a857600080fd5b6112b18361122b565b915060208301356112c1816115bc565b809150509250929050565b600080604083850312156112df57600080fd5b6112e88361122b565b946020939093013593505050565b60006020828403121561130857600080fd5b81516110c3816115bc565b60006020828403121561132557600080fd5b5035919050565b6000825161133e818460208701611525565b9190910192915050565b6020815260008251806020840152611367816040850160208701611525565b601f01601f19169190910160400192915050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600080821280156001600160ff1b03849003851316156113d2576113d2611590565b600160ff1b83900384128116156113eb576113eb611590565b50500190565b6000821982111561140457611404611590565b500190565b60008261142657634e487b7160e01b600052601260045260246000fd5b500490565b60006001600160ff1b038184138284138082168684048611161561145157611451611590565b600160ff1b600087128281168783058912161561147057611470611590565b6000871292508782058712848416161561148c5761148c611590565b878505871281841616156114a2576114a2611590565b505050929093029392505050565b60008160001904831182151516156114ca576114ca611590565b500290565b60008083128015600160ff1b8501841216156114ed576114ed611590565b6001600160ff1b038401831381161561150857611508611590565b50500390565b60008282101561152057611520611590565b500390565b60005b83811015611540578181015183820152602001611528565b8381111561154f576000848401525b50505050565b600060001982141561156957611569611590565b5060010190565b600060ff821660ff81141561158757611587611590565b60010192915050565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b80151581146105aa57600080fdfea2646970667358221220e0336d14d8a9b6155802cadd0161a354663f238b5896be6d12f57f21582262b364736f6c63430008070033

Library Used


Deployed ByteCode Sourcemap

54987:10714:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;58755:207;;;;;;;;;;-1:-1:-1;58755:207:0;;;;;:::i;:::-;;:::i;:::-;;6653:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;8820:169;;;;;;;;;;-1:-1:-1;8820:169:0;;;;;:::i;:::-;;:::i;:::-;;;5871:14:1;;5864:22;5846:41;;5834:2;5819:18;8820:169:0;5706:187:1;60358:100:0;;;;;;;;;;-1:-1:-1;60358:100:0;;;;;:::i;:::-;;:::i;7773:108::-;;;;;;;;;;-1:-1:-1;7861:12:0;;7773:108;;;16600:25:1;;;16588:2;16573:18;7773:108:0;16454:177:1;9471:492:0;;;;;;;;;;-1:-1:-1;9471:492:0;;;;;:::i;:::-;;:::i;58034:99::-;;;;;;;;;;;;;:::i;57585:143::-;;;;;;;;;;-1:-1:-1;57585:143:0;;;;;:::i;:::-;;:::i;7615:93::-;;;;;;;;;;-1:-1:-1;7615:93:0;;7698:2;17761:36:1;;17749:2;17734:18;7615:93:0;17619:184:1;57736:141:0;;;;;;;;;;-1:-1:-1;57736:141:0;;;;;:::i;:::-;;:::i;59185:212::-;;;;;;;;;;-1:-1:-1;59185:212:0;;;;;:::i;:::-;;:::i;10372:215::-;;;;;;;;;;-1:-1:-1;10372:215:0;;;;;:::i;:::-;;:::i;55204:18::-;;;;;;;;;;-1:-1:-1;55204:18:0;;;;-1:-1:-1;;;;;55204:18:0;;;;;;-1:-1:-1;;;;;4173:32:1;;;4155:51;;4143:2;4128:18;55204::0;4009:203:1;60736:209:0;;;;;;;;;;-1:-1:-1;60736:209:0;;;;;:::i;:::-;;:::i;55392:22::-;;;;;;;;;;;;;;;;60466:97;;;;;;;;;;-1:-1:-1;60466:97:0;;;;;:::i;:::-;;:::i;60571:157::-;;;;;;;;;;-1:-1:-1;60571:157:0;;;;;:::i;:::-;;:::i;55300:49::-;;;;;;;;;;-1:-1:-1;55300:49:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;60164:186;;;;;;;;;;-1:-1:-1;60164:186:0;;;;;:::i;:::-;;:::i;59711:90::-;;;;;;;;;;-1:-1:-1;59711:90:0;;;;;:::i;:::-;;:::i;59405:190::-;;;;;;;;;;-1:-1:-1;59405:190:0;;;;;:::i;:::-;;:::i;58535:212::-;;;;;;;;;;-1:-1:-1;58535:212:0;;;;;:::i;:::-;;:::i;58172:135::-;;;;;;;;;;-1:-1:-1;58172:135:0;;;;;:::i;:::-;;:::i;55358:27::-;;;;;;;;;;;;;;;;7944:127;;;;;;;;;;-1:-1:-1;7944:127:0;;;;;:::i;:::-;;:::i;30042:94::-;;;;;;;;;;;;;:::i;55523:30::-;;;;;;;;;;-1:-1:-1;55523:30:0;;;;-1:-1:-1;;;;;55523:30:0;;;60953:115;;;;;;;;;;-1:-1:-1;60953:115:0;;;;;:::i;:::-;;:::i;55066:42::-;;;;;;;;;;;;55106:2;55066:42;;29391:87;;;;;;;;;;-1:-1:-1;29464:6:0;;-1:-1:-1;;;;;29464:6:0;29391:87;;60017:139;;;;;;;;;;-1:-1:-1;60017:139:0;;;;;:::i;:::-;;:::i;59909:100::-;;;;;;;;;;-1:-1:-1;59909:100:0;;;;;:::i;:::-;;:::i;6872:104::-;;;;;;;;;;;;;:::i;55450:27::-;;;;;;;;;;;;;;;;55707:31;;;;;;;;;;;;;;;;59603:100;;;;;;;;;;-1:-1:-1;59603:100:0;;;;;:::i;:::-;;:::i;58970:207::-;;;;;;;;;;-1:-1:-1;58970:207:0;;;;;:::i;:::-;;:::i;11090:413::-;;;;;;;;;;-1:-1:-1;11090:413:0;;;;;:::i;:::-;;:::i;55166:29::-;;;;;;;;;;;;;;;8284:175;;;;;;;;;;-1:-1:-1;8284:175:0;;;;;:::i;:::-;;:::i;59809:92::-;;;;;;;;;;-1:-1:-1;59809:92:0;;;;;:::i;:::-;;:::i;55421:22::-;;;;;;;;;;;;;;;;58316:211;;;;;;;;;;-1:-1:-1;58316:211:0;;;;;:::i;:::-;;:::i;55229:18::-;;;;;;;;;;-1:-1:-1;55229:18:0;;;;-1:-1:-1;;;;;55229:18:0;;;8522:151;;;;;;;;;;-1:-1:-1;8522:151:0;;;;;:::i;:::-;-1:-1:-1;;;;;8638:18:0;;;8611:7;8638:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;8522:151;55562:22;;;;;;;;;;-1:-1:-1;55562:22:0;;;;-1:-1:-1;;;55562:22:0;;;;;;55486:27;;;;;;;;;;;;;;;;57885:141;;;;;;;;;;-1:-1:-1;57885:141:0;;;;;:::i;:::-;;:::i;30291:192::-;;;;;;;;;;-1:-1:-1;30291:192:0;;;;;:::i;:::-;;:::i;55591:21::-;;;;;;;;;;-1:-1:-1;55591:21:0;;;;-1:-1:-1;;;55591:21:0;;;;;;55256:35;;;;;;;;;;-1:-1:-1;55256:35:0;;;;-1:-1:-1;;;;;55256:35:0;;;55117:42;;;;;;;;;;;;;;;55619:26;;;;;;;;;;-1:-1:-1;55619:26:0;;;;-1:-1:-1;;;55619:26:0;;;;;;58755:207;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;;;;;;;;;55106:2:::1;58857:12;;58847:7;;58841:3;58826:12;;:18;;;;:::i;:::-;:28;;;;:::i;:::-;:43;;;;:::i;:::-;:60;;58818:112;;;;-1:-1:-1::0;;;58818:112:0::1;;;;;;;:::i;:::-;58941:7;:13:::0;58755:207::o;6653:100::-;6707:13;6740:5;6733:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6653:100;:::o;8820:169::-;8903:4;8920:39;4530:10;8943:7;8952:6;8920:8;:39::i;:::-;-1:-1:-1;8977:4:0;8820:169;;;;:::o;60358:100::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;60424:7:::1;::::0;:26:::1;::::0;-1:-1:-1;;;60424:26:0;;::::1;::::0;::::1;16600:25:1::0;;;-1:-1:-1;;;;;60424:7:0;;::::1;::::0;:20:::1;::::0;16573:18:1;;60424:26:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;60358:100:::0;:::o;9471:492::-;9611:4;9628:36;9638:6;9646:9;9657:6;9628:9;:36::i;:::-;-1:-1:-1;;;;;9704:19:0;;9677:24;9704:19;;;:11;:19;;;;;;;;4530:10;9704:33;;;;;;;;9756:26;;;;9748:79;;;;-1:-1:-1;;;9748:79:0;;11548:2:1;9748:79:0;;;11530:21:1;11587:2;11567:18;;;11560:30;11626:34;11606:18;;;11599:62;-1:-1:-1;;;11677:18:1;;;11670:38;11725:19;;9748:79:0;11346:404:1;9748:79:0;9863:57;9872:6;4530:10;9913:6;9894:16;:25;9863:8;:57::i;:::-;9951:4;9944:11;;;9471:492;;;;;;:::o;58034:99::-;58083:7;;:42;;-1:-1:-1;;;58083:42:0;;58114:10;58083:42;;;4155:51:1;-1:-1:-1;;;;;58083:7:0;;;;:30;;4128:18:1;;58083:42:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;58034:99::o;57585:143::-;57681:7;;:39;;-1:-1:-1;;;57681:39:0;;-1:-1:-1;;;;;4173:32:1;;;57681:39:0;;;4155:51:1;57657:4:0;;57681:7;;:30;;4128:18:1;;57681:39:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;57674:46;57585:143;-1:-1:-1;;57585:143:0:o;57736:141::-;57827:7;;57863:4;;57827:42;;-1:-1:-1;;;57827:42:0;;-1:-1:-1;;;;;4447:15:1;;;57827:42:0;;;4429:34:1;57863:4:0;;;4479:18:1;;;4472:43;57800:7:0;;57827;;;;;:18;;4364::1;;57827:42:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;59185:212::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;55106:2:::1;59296:3;59286:7;;59276;;59261:12;;:22;;;;:::i;:::-;:32;;;;:::i;:::-;:38;;;;:::i;:::-;:55;;59253:107;;;;-1:-1:-1::0;;;59253:107:0::1;;;;;;;:::i;:::-;59371:12;:18:::0;59185:212::o;10372:215::-;4530:10;10460:4;10509:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;10509:34:0;;;;;;;;;;10460:4;;10477:80;;10500:7;;10509:47;;10546:10;;10509:47;:::i;:::-;10477:8;:80::i;60736:209::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;60838:22:0;::::1;60855:4;60838:22;;60830:62;;;::::0;-1:-1:-1;;;60830:62:0;;9321:2:1;60830:62:0::1;::::0;::::1;9303:21:1::0;9360:2;9340:18;;;9333:30;9399:29;9379:18;;;9372:57;9446:18;;60830:62:0::1;9119:351:1::0;60830:62:0::1;60903:34;::::0;-1:-1:-1;;;60903:34:0;;-1:-1:-1;;;;;5007:32:1;;;60903:34:0::1;::::0;::::1;4989:51:1::0;5056:18;;;5049:34;;;60903:22:0;::::1;::::0;::::1;::::0;4962:18:1;;60903:34:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;60736:209:::0;;;:::o;60466:97::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;60538:17:::1;60544:2;60548:6;60538:5;:17::i;:::-;60466:97:::0;;:::o;60571:157::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;60631:25:::1;60637:10;60649:6;60631:5;:25::i;:::-;60667:7;::::0;-1:-1:-1;;;;;60667:7:0::1;:18;60686:10;60698:21;60686:10:::0;60698:9:::1;:21::i;:::-;60667:53;::::0;-1:-1:-1;;;;;;60667:53:0::1;::::0;;;;;;-1:-1:-1;;;;;5007:32:1;;;60667:53:0::1;::::0;::::1;4989:51:1::0;5056:18;;;5049:34;4962:18;;60667:53:0::1;4815:274:1::0;60164:186:0;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;60251:7:::1;60244:3;:14;;60236:73;;;::::0;-1:-1:-1;;;60236:73:0;;13128:2:1;60236:73:0::1;::::0;::::1;13110:21:1::0;13167:2;13147:18;;;13140:30;13206:34;13186:18;;;13179:62;-1:-1:-1;;;13257:18:1;;;13250:44;13311:19;;60236:73:0::1;12926:410:1::0;60236:73:0::1;60320:16;:22:::0;60164:186::o;59711:90::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;59775:9:::1;:18:::0;;;::::1;;-1:-1:-1::0;;;59775:18:0::1;-1:-1:-1::0;;;;59775:18:0;;::::1;::::0;;;::::1;::::0;;59711:90::o;59405:190::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;59487:20:0;::::1;59479:73;;;::::0;-1:-1:-1;;;59479:73:0;;15123:2:1;59479:73:0::1;::::0;::::1;15105:21:1::0;15162:2;15142:18;;;15135:30;15201:34;15181:18;;;15174:62;-1:-1:-1;;;15252:18:1;;;15245:38;15300:19;;59479:73:0::1;14921:404:1::0;59479:73:0::1;59563:15;:24:::0;;-1:-1:-1;;;;;;59563:24:0::1;-1:-1:-1::0;;;;;59563:24:0;;;::::1;::::0;;;::::1;::::0;;59405:190::o;58535:212::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;55106:2:::1;58637:12;;58627:7;;58617;;58611:3;:13;;;;:::i;:::-;:23;;;;:::i;:::-;:38;;;;:::i;:::-;:55;;58603:107;;;;-1:-1:-1::0;;;58603:107:0::1;;;;;;;:::i;:::-;58721:12;:18:::0;58535:212::o;58172:135::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;58262:26:0;;;::::1;;::::0;;;:17:::1;:26;::::0;;;;:37;;-1:-1:-1;;58262:37:0::1;::::0;::::1;;::::0;;;::::1;::::0;;58172:135::o;7944:127::-;-1:-1:-1;;;;;8045:18:0;8018:7;8045:18;;;;;;;;;;;;7944:127::o;30042:94::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;30107:21:::1;30125:1;30107:9;:21::i;:::-;30042:94::o:0;60953:115::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;61032:28:::1;::::0;-1:-1:-1;;;;;61032:20:0;::::1;::::0;:28;::::1;;;::::0;61053:6;;61032:28:::1;::::0;;;61053:6;61032:20;:28;::::1;;;;;;;;;;;;;::::0;::::1;;;;;;60953:115:::0;;:::o;60017:139::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;60109:28:0;;;::::1;;::::0;;;:19:::1;:28;::::0;;;;:39;;-1:-1:-1;;60109:39:0::1;::::0;::::1;;::::0;;;::::1;::::0;;60017:139::o;59909:100::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;59978:14:::1;:23:::0;;;::::1;;-1:-1:-1::0;;;59978:23:0::1;-1:-1:-1::0;;;;59978:23:0;;::::1;::::0;;;::::1;::::0;;59909:100::o;6872:104::-;6928:13;6961:7;6954:14;;;;;:::i;59603:100::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;59674:12:::1;:21:::0;59603:100::o;58970:207::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;55106:2:::1;59072:12;;59066:3;59056:7;;59041:12;;:22;;;;:::i;:::-;:28;;;;:::i;:::-;:43;;;;:::i;:::-;:60;;59033:112;;;;-1:-1:-1::0;;;59033:112:0::1;;;;;;;:::i;:::-;59156:7;:13:::0;58970:207::o;11090:413::-;4530:10;11183:4;11227:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11227:34:0;;;;;;;;;;11280:35;;;;11272:85;;;;-1:-1:-1;;;11272:85:0;;15890:2:1;11272:85:0;;;15872:21:1;15929:2;15909:18;;;15902:30;15968:34;15948:18;;;15941:62;-1:-1:-1;;;16019:18:1;;;16012:35;16064:19;;11272:85:0;15688:401:1;11272:85:0;11393:67;4530:10;11416:7;11444:15;11425:16;:34;11393:8;:67::i;:::-;-1:-1:-1;11491:4:0;;11090:413;-1:-1:-1;;;11090:413:0:o;8284:175::-;8370:4;8387:42;4530:10;8411:9;8422:6;8387:9;:42::i;59809:92::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;59874:10:::1;:19:::0;;;::::1;;-1:-1:-1::0;;;59874:19:0::1;-1:-1:-1::0;;;;59874:19:0;;::::1;::::0;;;::::1;::::0;;59809:92::o;58316:211::-;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;58411:7:::1;::::0;:50:::1;::::0;-1:-1:-1;;;58411:50:0;;-1:-1:-1;;;;;4712:32:1;;;58411:50:0::1;::::0;::::1;4694:51:1::0;4788:14;;4781:22;4761:18;;;4754:50;58411:7:0;;::::1;::::0;:31:::1;::::0;4667:18:1;;58411:50:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;;58472:7:0::1;::::0;-1:-1:-1;;;;;58472:7:0::1;::::0;-1:-1:-1;58472:18:0::1;::::0;-1:-1:-1;58491:7:0;58500:18:::1;58491:7:::0;58500:9:::1;:18::i;:::-;58472:47;::::0;-1:-1:-1;;;;;;58472:47:0::1;::::0;;;;;;-1:-1:-1;;;;;5007:32:1;;;58472:47:0::1;::::0;::::1;4989:51:1::0;5056:18;;;5049:34;4962:18;;58472:47:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;58316:211:::0;;:::o;57885:141::-;57976:7;;58012:4;;57976:42;;-1:-1:-1;;;57976:42:0;;-1:-1:-1;;;;;4447:15:1;;;57976:42:0;;;4429:34:1;58012:4:0;;;4479:18:1;;;4472:43;57949:7:0;;57976;;;;;:18;;4364::1;;57976:42:0;4217:304:1;30291:192:0;29464:6;;-1:-1:-1;;;;;29464:6:0;4530:10;29611:23;29603:68;;;;-1:-1:-1;;;29603:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;30380:22:0;::::1;30372:73;;;::::0;-1:-1:-1;;;30372:73:0;;8511:2:1;30372:73:0::1;::::0;::::1;8493:21:1::0;8550:2;8530:18;;;8523:30;8589:34;8569:18;;;8562:62;-1:-1:-1;;;8640:18:1;;;8633:36;8686:19;;30372:73:0::1;8309:402:1::0;30372:73:0::1;30456:19;30466:8;30456:9;:19::i;13013:399::-:0;-1:-1:-1;;;;;13097:21:0;;13089:65;;;;-1:-1:-1;;;13089:65:0;;16296:2:1;13089:65:0;;;16278:21:1;16335:2;16315:18;;;16308:30;16374:33;16354:18;;;16347:61;16425:18;;13089:65:0;16094:355:1;13089:65:0;13245:6;13229:12;;:22;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;;;13262:18:0;;:9;:18;;;;;;;;;;:28;;13284:6;;13262:9;:28;;13284:6;;13262:28;:::i;:::-;;;;-1:-1:-1;;13306:37:0;;16600:25:1;;;-1:-1:-1;;;;;13306:37:0;;;13323:1;;13306:37;;16588:2:1;16573:18;13306:37:0;;;;;;;60466:97;;:::o;14774:380::-;-1:-1:-1;;;;;14910:19:0;;14902:68;;;;-1:-1:-1;;;14902:68:0;;13949:2:1;14902:68:0;;;13931:21:1;13988:2;13968:18;;;13961:30;14027:34;14007:18;;;14000:62;-1:-1:-1;;;14078:18:1;;;14071:34;14122:19;;14902:68:0;13747:400:1;14902:68:0;-1:-1:-1;;;;;14989:21:0;;14981:68;;;;-1:-1:-1;;;14981:68:0;;8918:2:1;14981:68:0;;;8900:21:1;8957:2;8937:18;;;8930:30;8996:34;8976:18;;;8969:62;-1:-1:-1;;;9047:18:1;;;9040:32;9089:19;;14981:68:0;8716:398:1;14981:68:0;-1:-1:-1;;;;;15062:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;15114:32;;16600:25:1;;;15114:32:0;;16573:18:1;15114:32:0;;;;;;;14774:380;;;:::o;61105:1402::-;61207:4;-1:-1:-1;;;;;61199:12:0;:4;-1:-1:-1;;;;;61199:12:0;;61195:365;;;61237:9;;-1:-1:-1;;;61237:9:0;;;;61236:10;;:37;;-1:-1:-1;;;;;;61250:23:0;;;;;;:19;:23;;;;;;;;61236:37;61228:74;;;;-1:-1:-1;;;61228:74:0;;11195:2:1;61228:74:0;;;11177:21:1;11234:2;11214:18;;;11207:30;11273:26;11253:18;;;11246:54;11317:18;;61228:74:0;10993:348:1;61228:74:0;61195:365;;;61330:4;-1:-1:-1;;;;;61324:10:0;:2;-1:-1:-1;;;;;61324:10:0;;61320:240;;;61360:10;;-1:-1:-1;;;61360:10:0;;;;61359:11;;:40;;-1:-1:-1;;;;;;61374:25:0;;;;;;:19;:25;;;;;;;;61359:40;61351:78;;;;-1:-1:-1;;;61351:78:0;;10491:2:1;61351:78:0;;;10473:21:1;10530:2;10510:18;;;10503:30;10569:27;10549:18;;;10542:55;10614:18;;61351:78:0;10289:349:1;61320:240:0;61471:14;;-1:-1:-1;;;61471:14:0;;;;61470:15;;:44;;-1:-1:-1;;;;;;61489:25:0;;;;;;:19;:25;;;;;;;;61470:44;61462:86;;;;-1:-1:-1;;;61462:86:0;;15532:2:1;61462:86:0;;;15514:21:1;15571:2;15551:18;;;15544:30;15610:31;15590:18;;;15583:59;15659:18;;61462:86:0;15330:353:1;61462:86:0;-1:-1:-1;;;;;61576:23:0;;;;;;:17;:23;;;;;;;;;:48;;-1:-1:-1;;;;;;61603:21:0;;;;;;:17;:21;;;;;;;;61576:48;61572:368;;;61641:33;61657:4;61663:2;61667:6;61641:15;:33::i;:::-;61572:368;;;61707:22;61793:3;61777:12;;61767:7;;61757;;61742:12;;:22;;;;:::i;:::-;:32;;;;:::i;:::-;:47;;;;:::i;:::-;61732:58;;:6;:58;:::i;:::-;:64;;;;:::i;:::-;61707:89;;61811:52;61827:4;61841;61848:14;61811:15;:52::i;:::-;61878:50;61894:4;61900:2;61904:23;61913:14;61904:6;:23;:::i;:::-;61878:15;:50::i;:::-;61692:248;61572:368;61984:12;;61956:24;61974:4;61956:9;:24::i;:::-;:40;;:51;;;;-1:-1:-1;62001:6:0;;;;62000:7;61956:51;:67;;;;;62019:4;-1:-1:-1;;;;;62011:12:0;:4;-1:-1:-1;;;;;62011:12:0;;;61956:67;61952:120;;;62040:20;:18;:20::i;:::-;62089:6;;;;62084:284;;62120:16;;62149:7;;:20;;-1:-1:-1;;;;;;62149:20:0;;;;;16600:25:1;;;-1:-1:-1;;;;;62149:7:0;;;;:15;;16573:18:1;;62149:20:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;62149:20:0;;;;;;;;-1:-1:-1;;62149:20:0;;;;;;;;;;;;:::i;:::-;;;62145:212;;;;;62258:80;;;17454:25:1;;;17510:2;17495:18;;17488:34;;;17538:18;;;17531:34;;;17596:2;17581:18;;17574:34;;;62328:9:0;;62258:80;;17441:3:1;17426:19;62258:80:0;;;;;;;62170:178;;;62145:212;62097:271;62084:284;62384:7;;-1:-1:-1;;;;;62384:7:0;:18;62403:4;62409:15;62403:4;62409:9;:15::i;:::-;62384:41;;-1:-1:-1;;;;;;62384:41:0;;;;;;;-1:-1:-1;;;;;5007:32:1;;;62384:41:0;;;4989:51:1;5056:18;;;5049:34;4962:18;;62384:41:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;62380:57;62451:7;;-1:-1:-1;;;;;62451:7:0;:18;62470:2;62474:13;62470:2;62474:9;:13::i;:::-;62451:37;;-1:-1:-1;;;;;;62451:37:0;;;;;;;-1:-1:-1;;;;;5007:32:1;;;62451:37:0;;;4989:51:1;5056:18;;;5049:34;4962:18;;62451:37:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;62447:53;;61032:28:::1;60953:115:::0;;:::o;62515:151::-;62587:23;62599:2;62603:6;62587:11;:23::i;:::-;62621:7;;-1:-1:-1;;;;;62621:7:0;:18;62640:2;62644:13;62640:2;62644:9;:13::i;13745:591::-;-1:-1:-1;;;;;13829:21:0;;13821:67;;;;-1:-1:-1;;;13821:67:0;;12318:2:1;13821:67:0;;;12300:21:1;12357:2;12337:18;;;12330:30;12396:34;12376:18;;;12369:62;-1:-1:-1;;;12447:18:1;;;12440:31;12488:19;;13821:67:0;12116:397:1;13821:67:0;-1:-1:-1;;;;;13988:18:0;;13963:22;13988:18;;;;;;;;;;;14025:24;;;;14017:71;;;;-1:-1:-1;;;14017:71:0;;8108:2:1;14017:71:0;;;8090:21:1;8147:2;8127:18;;;8120:30;8186:34;8166:18;;;8159:62;-1:-1:-1;;;8237:18:1;;;8230:32;8279:19;;14017:71:0;7906:398:1;14017:71:0;-1:-1:-1;;;;;14124:18:0;;:9;:18;;;;;;;;;;14145:23;;;14124:44;;14190:12;:22;;14162:6;;14124:9;14190:22;;14162:6;;14190:22;:::i;:::-;;;;-1:-1:-1;;14230:37:0;;16600:25:1;;;14256:1:0;;-1:-1:-1;;;;;14230:37:0;;;;;16588:2:1;16573:18;14230:37:0;;;;;;;61032:28:::1;60953:115:::0;;:::o;30491:173::-;30566:6;;;-1:-1:-1;;;;;30583:17:0;;;-1:-1:-1;;;;;;30583:17:0;;;;;;;30616:40;;30566:6;;;30583:17;30566:6;;30616:40;;30547:16;;30616:40;30536:128;30491:173;:::o;11993:733::-;-1:-1:-1;;;;;12133:20:0;;12125:70;;;;-1:-1:-1;;;12125:70:0;;13543:2:1;12125:70:0;;;13525:21:1;13582:2;13562:18;;;13555:30;13621:34;13601:18;;;13594:62;-1:-1:-1;;;13672:18:1;;;13665:35;13717:19;;12125:70:0;13341:401:1;12125:70:0;-1:-1:-1;;;;;12214:23:0;;12206:71;;;;-1:-1:-1;;;12206:71:0;;7704:2:1;12206:71:0;;;7686:21:1;7743:2;7723:18;;;7716:30;7782:34;7762:18;;;7755:62;-1:-1:-1;;;7833:18:1;;;7826:33;7876:19;;12206:71:0;7502:399:1;12206:71:0;-1:-1:-1;;;;;12374:17:0;;12350:21;12374:17;;;;;;;;;;;12410:23;;;;12402:74;;;;-1:-1:-1;;;12402:74:0;;9677:2:1;12402:74:0;;;9659:21:1;9716:2;9696:18;;;9689:30;9755:34;9735:18;;;9728:62;-1:-1:-1;;;9806:18:1;;;9799:36;9852:19;;12402:74:0;9475:402:1;12402:74:0;-1:-1:-1;;;;;12512:17:0;;;:9;:17;;;;;;;;;;;12532:22;;;12512:42;;12576:20;;;;;;;;:30;;12548:6;;12512:9;12576:30;;12548:6;;12576:30;:::i;:::-;;;;;;;;12641:9;-1:-1:-1;;;;;12624:35:0;12633:6;-1:-1:-1;;;;;12624:35:0;;12652:6;12624:35;;;;16600:25:1;;16588:2;16573:18;;16454:177;12624:35:0;;;;;;;;12672:46;60953:115;62674:1735;65597:6;;;;65596:7;65588:41;;;;-1:-1:-1;;;65588:41:0;;10845:2:1;65588:41:0;;;10827:21:1;10884:2;10864:18;;;10857:30;-1:-1:-1;;;10903:18:1;;;10896:51;10964:18;;65588:41:0;10643:345:1;65588:41:0;65640:6;:13;;-1:-1:-1;;65640:13:0;65649:4;65640:13;;;62796:7:::1;::::0;62786::::1;::::0;62771:12:::1;::::0;62756::::1;::::0;65640:6;;62796:7;62786;62756:27:::1;::::0;::::1;:::i;:::-;:37;;;;:::i;:::-;:47;;;;:::i;:::-;62736:67;;62814:26;62885:9;62870:12;;62843:24;62861:4;62843:9;:24::i;:::-;:39;;;;:::i;:::-;:51;;;;:::i;:::-;62814:80;;62905:26;62976:9;62961:12;;62934:24;62952:4;62934:9;:24::i;:::-;:39;;;;:::i;:::-;:51;;;;:::i;:::-;62905:80;;62996:21;63057:9;63047:7;;63020:24;63038:4;63020:9;:24::i;:::-;:34;;;;:::i;:::-;:46;;;;:::i;:::-;62996:70;;63077:21;63170:13;63149:18;63128;63101:24;63119:4;63101:9;:24::i;:::-;:45;;;;:::i;:::-;:66;;;;:::i;:::-;:82;;;;:::i;:::-;63077:106:::0;-1:-1:-1;63196:25:0::1;63224:22;63245:1;63224:18:::0;:22:::1;:::i;:::-;63196:50;;63257:19;63306:17;63279:24;63297:4;63279:9;:24::i;:::-;:44;;;;:::i;:::-;63257:66;;63334:30;63352:11;63334:17;:30::i;:::-;63416:4;63400:30;63377:20;63506:11:::0;63470:33:::1;63485:18:::0;63400:30;63470:33:::1;:::i;:::-;:47;;;;:::i;:::-;63441:76:::0;-1:-1:-1;63528:21:0::1;63583:11:::0;63552:28:::1;63567:13:::0;63552:12;:28:::1;:::i;:::-;:42;;;;:::i;:::-;63528:66:::0;-1:-1:-1;63605:21:0::1;63660:11:::0;63629:28:::1;63644:13:::0;63629:12;:28:::1;:::i;:::-;:42;;;;:::i;:::-;63605:66:::0;-1:-1:-1;63682:26:0::1;63605:66:::0;63747:13;63711:33:::1;63726:18:::0;63711:12;:33:::1;:::i;:::-;:49;;;;:::i;:::-;:65;;;;:::i;:::-;63797:15;::::0;63789:53:::1;::::0;63682:94;;-1:-1:-1;;;;;;63797:15:0::1;::::0;63789:53;::::1;;;::::0;63823:18;;63797:15:::1;63789:53:::0;63797:15;63789:53;63823:18;63797:15;63789:53;::::1;;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;63881:4:0::1;::::0;63855:47:::1;::::0;-1:-1:-1;;;;;63881:4:0::1;63888:13:::0;63855:17:::1;:47::i;:::-;63935:4;::::0;:29:::1;::::0;-1:-1:-1;;;63935:29:0;;63958:4:::1;63935:29;::::0;::::1;4155:51:1::0;63913:19:0::1;::::0;-1:-1:-1;;;;;63935:4:0::1;::::0;:14:::1;::::0;4128:18:1;;63935:29:0::1;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;64001:7;::::0;63975:4:::1;::::0;63913:51;;-1:-1:-1;63975:48:0::1;::::0;-1:-1:-1;;;;;63975:4:0;;::::1;::::0;64001:7:::1;63913:51:::0;63975:17:::1;:48::i;:::-;64034:7;::::0;64070:4:::1;::::0;64034:55:::1;::::0;-1:-1:-1;;;64034:55:0;;-1:-1:-1;;;;;64070:4:0;;::::1;64034:55;::::0;::::1;4989:51:1::0;5056:18;;;5049:34;;;64034:7:0;::::1;::::0;:27:::1;::::0;4962:18:1;;64034:55:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;;64128:4:0::1;::::0;64102:47:::1;::::0;-1:-1:-1;;;;;;64128:4:0::1;::::0;-1:-1:-1;64135:13:0;64102:17:::1;:47::i;:::-;64182:4;::::0;:29:::1;::::0;-1:-1:-1;;;64182:29:0;;64205:4:::1;64182:29;::::0;::::1;4155:51:1::0;64160:19:0::1;::::0;-1:-1:-1;;;;;64182:4:0::1;::::0;:14:::1;::::0;4128:18:1;;64182:29:0::1;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;64248:7;::::0;64222:4:::1;::::0;64160:51;;-1:-1:-1;64222:48:0::1;::::0;-1:-1:-1;;;;;64222:4:0;;::::1;::::0;64248:7:::1;64160:51:::0;64222:17:::1;:48::i;:::-;64281:7;::::0;64317:4:::1;::::0;64281:55:::1;::::0;-1:-1:-1;;;64281:55:0;;-1:-1:-1;;;;;64317:4:0;;::::1;64281:55;::::0;::::1;4989:51:1::0;5056:18;;;5049:34;;;64281:7:0;::::1;::::0;:27:::1;::::0;4962:18:1;;64281:55:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;64349:52;64363:17;64382:18;64349:13;:52::i;:::-;-1:-1:-1::0;;65676:6:0;:14;;-1:-1:-1;;65676:14:0;;;-1:-1:-1;;;;;;;;;;;;62674:1735:0:o;64792:442::-;64855:59;64872:4;64887:6;-1:-1:-1;;64855:8:0;:59::i;:::-;64949:16;;;64963:1;64949:16;;;;;;;;64925:21;;64949:16;;;;;;;;;;-1:-1:-1;64949:16:0;64925:40;;64994:4;64976;64981:1;64976:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;64976:23:0;;;-1:-1:-1;;;;;64976:23:0;;;;;65020:6;-1:-1:-1;;;;;65020:11:0;;:13;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;65010:4;65015:1;65010:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;65010:23:0;;;:7;;;;;;;;;:23;65044:182;;-1:-1:-1;;;65044:182:0;;:6;:57;;;;;;:182;;65116:6;;65137:1;;65153:4;;65180;;65200:15;;65044:182;;;:::i;64417:367::-;64516:16;;;64530:1;64516:16;;;;;;;;64492:21;;64516:16;;;;;;;;;;-1:-1:-1;64516:16:0;64492:40;;64553:6;-1:-1:-1;;;;;64553:11:0;;:13;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;64543:4;64548:1;64543:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;64543:23:0;;;-1:-1:-1;;;;;64543:23:0;;;;;64587:2;64577:4;64582:1;64577:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;64577:12:0;;;:7;;;;;;;;;:12;64600:176;;-1:-1:-1;;;64600:176:0;;:6;:57;;;;;;64665:6;;64600:176;;64687:1;;64703:4;;64730;;64750:15;;64600:176;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;64481:303;64417:367;;:::o;25174:211::-;25318:58;;;-1:-1:-1;;;;;5007:32:1;;25318:58:0;;;4989:51:1;5056:18;;;;5049:34;;;25318:58:0;;;;;;;;;;4962:18:1;;;;25318:58:0;;;;;;;;-1:-1:-1;;;;;25318:58:0;-1:-1:-1;;;25318:58:0;;;25291:86;;25311:5;;25291:19;:86::i;65242:286::-;65325:195;;-1:-1:-1;;;65325:195:0;;65388:4;65325:195;;;5435:34:1;;;5485:18;;;5478:34;;;65434:1:0;5528:18:1;;;5521:34;;;5571:18;;;5564:34;5614:19;;;5607:44;65494:15:0;5667:19:1;;;5660:35;65325:6:0;-1:-1:-1;;;;;65325:22:0;;;;65355:9;;5369:19:1;;65325:195:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;27747:716::-;28171:23;28197:69;28225:4;28197:69;;;;;;;;;;;;;;;;;28205:5;-1:-1:-1;;;;;28197:27:0;;;:69;;;;;:::i;:::-;28281:17;;28171:95;;-1:-1:-1;28281:21:0;28277:179;;28378:10;28367:30;;;;;;;;;;;;:::i;:::-;28359:85;;;;-1:-1:-1;;;28359:85:0;;14712:2:1;28359:85:0;;;14694:21:1;14751:2;14731:18;;;14724:30;14790:34;14770:18;;;14763:62;-1:-1:-1;;;14841:18:1;;;14834:40;14891:19;;28359:85:0;14510:406:1;20112:229:0;20249:12;20281:52;20303:6;20311:4;20317:1;20320:12;20281:21;:52::i;:::-;20274:59;20112:229;-1:-1:-1;;;;20112:229:0:o;21232:510::-;21402:12;21460:5;21435:21;:30;;21427:81;;;;-1:-1:-1;;;21427:81:0;;10084:2:1;21427:81:0;;;10066:21:1;10123:2;10103:18;;;10096:30;10162:34;10142:18;;;10135:62;-1:-1:-1;;;10213:18:1;;;10206:36;10259:19;;21427:81:0;9882:402:1;21427:81:0;17629:20;;21519:60;;;;-1:-1:-1;;;21519:60:0;;14354:2:1;21519:60:0;;;14336:21:1;14393:2;14373:18;;;14366:30;14432:31;14412:18;;;14405:59;14481:18;;21519:60:0;14152:353:1;21519:60:0;21593:12;21607:23;21634:6;-1:-1:-1;;;;;21634:11:0;21653:5;21660:4;21634:31;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;21592:73;;;;21683:51;21700:7;21709:10;21721:12;21683:16;:51::i;:::-;21676:58;21232:510;-1:-1:-1;;;;;;;21232:510:0:o;23918:712::-;24068:12;24097:7;24093:530;;;-1:-1:-1;24128:10:0;24121:17;;24093:530;24242:17;;:21;24238:374;;24440:10;24434:17;24501:15;24488:10;24484:2;24480:19;24473:44;24238:374;24583:12;24576:20;;-1:-1:-1;;;24576:20:0;;;;;;;;:::i;14:247:1:-;73:6;126:2;114:9;105:7;101:23;97:32;94:52;;;142:1;139;132:12;94:52;181:9;168:23;200:31;225:5;200:31;:::i;266:251::-;336:6;389:2;377:9;368:7;364:23;360:32;357:52;;;405:1;402;395:12;357:52;437:9;431:16;456:31;481:5;456:31;:::i;522:388::-;590:6;598;651:2;639:9;630:7;626:23;622:32;619:52;;;667:1;664;657:12;619:52;706:9;693:23;725:31;750:5;725:31;:::i;:::-;775:5;-1:-1:-1;832:2:1;817:18;;804:32;845:33;804:32;845:33;:::i;:::-;897:7;887:17;;;522:388;;;;;:::o;915:456::-;992:6;1000;1008;1061:2;1049:9;1040:7;1036:23;1032:32;1029:52;;;1077:1;1074;1067:12;1029:52;1116:9;1103:23;1135:31;1160:5;1135:31;:::i;:::-;1185:5;-1:-1:-1;1242:2:1;1227:18;;1214:32;1255:33;1214:32;1255:33;:::i;:::-;915:456;;1307:7;;-1:-1:-1;;;1361:2:1;1346:18;;;;1333:32;;915:456::o;1376:382::-;1441:6;1449;1502:2;1490:9;1481:7;1477:23;1473:32;1470:52;;;1518:1;1515;1508:12;1470:52;1557:9;1544:23;1576:31;1601:5;1576:31;:::i;:::-;1626:5;-1:-1:-1;1683:2:1;1668:18;;1655:32;1696:30;1655:32;1696:30;:::i;1763:315::-;1831:6;1839;1892:2;1880:9;1871:7;1867:23;1863:32;1860:52;;;1908:1;1905;1898:12;1860:52;1947:9;1934:23;1966:31;1991:5;1966:31;:::i;:::-;2016:5;2068:2;2053:18;;;;2040:32;;-1:-1:-1;;;1763:315:1:o;2083:241::-;2139:6;2192:2;2180:9;2171:7;2167:23;2163:32;2160:52;;;2208:1;2205;2198:12;2160:52;2247:9;2234:23;2266:28;2288:5;2266:28;:::i;2329:245::-;2396:6;2449:2;2437:9;2428:7;2424:23;2420:32;2417:52;;;2465:1;2462;2455:12;2417:52;2497:9;2491:16;2516:28;2538:5;2516:28;:::i;2579:180::-;2638:6;2691:2;2679:9;2670:7;2666:23;2662:32;2659:52;;;2707:1;2704;2697:12;2659:52;-1:-1:-1;2730:23:1;;2579:180;-1:-1:-1;2579:180:1:o;2764:184::-;2834:6;2887:2;2875:9;2866:7;2862:23;2858:32;2855:52;;;2903:1;2900;2893:12;2855:52;-1:-1:-1;2926:16:1;;2764:184;-1:-1:-1;2764:184:1:o;2953:306::-;3041:6;3049;3057;3110:2;3098:9;3089:7;3085:23;3081:32;3078:52;;;3126:1;3123;3116:12;3078:52;3155:9;3149:16;3139:26;;3205:2;3194:9;3190:18;3184:25;3174:35;;3249:2;3238:9;3234:18;3228:25;3218:35;;2953:306;;;;;:::o;3264:461::-;3317:3;3355:5;3349:12;3382:6;3377:3;3370:19;3408:4;3437:2;3432:3;3428:12;3421:19;;3474:2;3467:5;3463:14;3495:1;3505:195;3519:6;3516:1;3513:13;3505:195;;;3584:13;;-1:-1:-1;;;;;3580:39:1;3568:52;;3640:12;;;;3675:15;;;;3616:1;3534:9;3505:195;;;-1:-1:-1;3716:3:1;;3264:461;-1:-1:-1;;;;;3264:461:1:o;3730:274::-;3859:3;3897:6;3891:13;3913:53;3959:6;3954:3;3947:4;3939:6;3935:17;3913:53;:::i;:::-;3982:16;;;;;3730:274;-1:-1:-1;;3730:274:1:o;6599:510::-;6870:6;6859:9;6852:25;6913:3;6908:2;6897:9;6893:18;6886:31;6833:4;6934:57;6986:3;6975:9;6971:19;6963:6;6934:57;:::i;:::-;-1:-1:-1;;;;;7027:32:1;;;;7022:2;7007:18;;7000:60;-1:-1:-1;7091:2:1;7076:18;7069:34;6926:65;6599:510;-1:-1:-1;;6599:510:1:o;7114:383::-;7263:2;7252:9;7245:21;7226:4;7295:6;7289:13;7338:6;7333:2;7322:9;7318:18;7311:34;7354:66;7413:6;7408:2;7397:9;7393:18;7388:2;7380:6;7376:15;7354:66;:::i;:::-;7481:2;7460:15;-1:-1:-1;;7456:29:1;7441:45;;;;7488:2;7437:54;;7114:383;-1:-1:-1;;7114:383:1:o;11755:356::-;11957:2;11939:21;;;11976:18;;;11969:30;12035:34;12030:2;12015:18;;12008:62;12102:2;12087:18;;11755:356::o;12518:403::-;12720:2;12702:21;;;12759:2;12739:18;;;12732:30;12798:34;12793:2;12778:18;;12771:62;-1:-1:-1;;;12864:2:1;12849:18;;12842:37;12911:3;12896:19;;12518:403::o;16636:582::-;16935:6;16924:9;16917:25;16978:6;16973:2;16962:9;16958:18;16951:34;17021:3;17016:2;17005:9;17001:18;16994:31;16898:4;17042:57;17094:3;17083:9;17079:19;17071:6;17042:57;:::i;:::-;-1:-1:-1;;;;;17135:32:1;;;;17130:2;17115:18;;17108:60;-1:-1:-1;17199:3:1;17184:19;17177:35;17034:65;16636:582;-1:-1:-1;;;16636:582:1:o;17808:128::-;17848:3;17879:1;17875:6;17872:1;17869:13;17866:39;;;17885:18;;:::i;:::-;-1:-1:-1;17921:9:1;;17808:128::o;17941:217::-;17981:1;18007;17997:132;;18051:10;18046:3;18042:20;18039:1;18032:31;18086:4;18083:1;18076:15;18114:4;18111:1;18104:15;17997:132;-1:-1:-1;18143:9:1;;17941:217::o;18163:168::-;18203:7;18269:1;18265;18261:6;18257:14;18254:1;18251:21;18246:1;18239:9;18232:17;18228:45;18225:71;;;18276:18;;:::i;:::-;-1:-1:-1;18316:9:1;;18163:168::o;18336:125::-;18376:4;18404:1;18401;18398:8;18395:34;;;18409:18;;:::i;:::-;-1:-1:-1;18446:9:1;;18336:125::o;18466:258::-;18538:1;18548:113;18562:6;18559:1;18556:13;18548:113;;;18638:11;;;18632:18;18619:11;;;18612:39;18584:2;18577:10;18548:113;;;18679:6;18676:1;18673:13;18670:48;;;-1:-1:-1;;18714:1:1;18696:16;;18689:27;18466:258::o;18729:380::-;18808:1;18804:12;;;;18851;;;18872:61;;18926:4;18918:6;18914:17;18904:27;;18872:61;18979:2;18971:6;18968:14;18948:18;18945:38;18942:161;;;19025:10;19020:3;19016:20;19013:1;19006:31;19060:4;19057:1;19050:15;19088:4;19085:1;19078:15;18942:161;;18729:380;;;:::o;19114:127::-;19175:10;19170:3;19166:20;19163:1;19156:31;19206:4;19203:1;19196:15;19230:4;19227:1;19220:15;19246:127;19307:10;19302:3;19298:20;19295:1;19288:31;19338:4;19335:1;19328:15;19362:4;19359:1;19352:15;19510:131;-1:-1:-1;;;;;19585:31:1;;19575:42;;19565:70;;19631:1;19628;19621:12;19646:118;19732:5;19725:13;19718:21;19711:5;19708:32;19698:60;;19754:1;19751;19744:12

Swarm Source

ipfs://e0336d14d8a9b6155802cadd0161a354663f238b5896be6d12f57f21582262b3
Block Transaction Gas Used Reward
Age Block Fee Address BC Fee Address Voting Power Jailed Incoming
Block Uncle Number Difficulty Gas Used Reward
Loading
Loading
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.