ETH Price: $3,542.24 (+6.47%)

Token

Treat (Treat)
 

Overview

Max Total Supply

38,356.25 Treat

Holders

30

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
0.000190018285630514 Treat

Value
$0.00
0xb97947417608ed69e1e05a5b6aa55bdd72cc12ef
Loading...
Loading
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
TokenEth

Compiler Version
v0.8.17+commit.8df45f5f

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-09-04
*/

// SPDX-License-Identifier: MIT
// File: @openzeppelin/contracts/token/ERC20/IERC20.sol

// OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/IERC20.sol)

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @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 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 `to`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address to, 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 `from` to `to` 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 from, address to, uint256 amount) external returns (bool);
}

// File: @openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol

// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol)

pragma solidity ^0.8.0;

/**
 * @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);
}

// File: @openzeppelin/contracts/utils/Context.sol

// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)

pragma solidity ^0.8.0;

/**
 * @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;
    }
}

// File: @openzeppelin/contracts/token/ERC20/ERC20.sol

// OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/ERC20.sol)

pragma solidity ^0.8.0;



/**
 * @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.openzeppelin.com/t/how-to-implement-erc20-supply-mechanisms/226[How
 * to implement supply mechanisms].
 *
 * The default value of {decimals} is 18. To change this, you should override
 * this function so it returns a different value.
 *
 * 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}.
     *
     * 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 default value returned by this function, unless
     * it's 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:
     *
     * - `to` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address to, uint256 amount) public virtual override returns (bool) {
        address owner = _msgSender();
        _transfer(owner, to, 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}.
     *
     * NOTE: If `amount` is the maximum `uint256`, the allowance is not updated on
     * `transferFrom`. This is semantically equivalent to an infinite approval.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        address owner = _msgSender();
        _approve(owner, 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}.
     *
     * NOTE: Does not update the allowance if the current allowance
     * is the maximum `uint256`.
     *
     * Requirements:
     *
     * - `from` and `to` cannot be the zero address.
     * - `from` must have a balance of at least `amount`.
     * - the caller must have allowance for ``from``'s tokens of at least
     * `amount`.
     */
    function transferFrom(address from, address to, uint256 amount) public virtual override returns (bool) {
        address spender = _msgSender();
        _spendAllowance(from, spender, amount);
        _transfer(from, to, 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) {
        address owner = _msgSender();
        _approve(owner, spender, allowance(owner, 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) {
        address owner = _msgSender();
        uint256 currentAllowance = allowance(owner, spender);
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        unchecked {
            _approve(owner, spender, currentAllowance - subtractedValue);
        }

        return true;
    }

    /**
     * @dev Moves `amount` of tokens from `from` to `to`.
     *
     * 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:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `from` must have a balance of at least `amount`.
     */
    function _transfer(address from, address to, uint256 amount) internal virtual {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(from, to, amount);

        uint256 fromBalance = _balances[from];
        require(fromBalance >= amount, "ERC20: transfer amount exceeds balance");
        unchecked {
            _balances[from] = fromBalance - amount;
            // Overflow not possible: the sum of all balances is capped by totalSupply, and the sum is preserved by
            // decrementing then incrementing.
            _balances[to] += amount;
        }

        emit Transfer(from, to, amount);

        _afterTokenTransfer(from, to, 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;
        unchecked {
            // Overflow not possible: balance + amount is at most totalSupply + amount, which is checked above.
            _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;
            // Overflow not possible: amount <= accountBalance <= totalSupply.
            _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 Updates `owner` s allowance for `spender` based on spent `amount`.
     *
     * Does not update the allowance amount in case of infinite allowance.
     * Revert if not enough allowance is available.
     *
     * Might emit an {Approval} event.
     */
    function _spendAllowance(address owner, address spender, uint256 amount) internal virtual {
        uint256 currentAllowance = allowance(owner, spender);
        if (currentAllowance != type(uint256).max) {
            require(currentAllowance >= amount, "ERC20: insufficient allowance");
            unchecked {
                _approve(owner, spender, currentAllowance - 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 {}
}

// File: @openzeppelin/contracts/access/Ownable.sol

// OpenZeppelin Contracts (last updated v4.9.0) (access/Ownable.sol)

pragma solidity ^0.8.0;

/**
 * @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() {
        _transferOwnership(_msgSender());
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        _checkOwner();
        _;
    }

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

    /**
     * @dev Throws if the sender is not the owner.
     */
    function _checkOwner() internal view virtual {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby disabling any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(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");
        _transferOwnership(newOwner);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Internal function without access restriction.
     */
    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

// File: @openzeppelin/contracts/utils/math/SafeMath.sol

// OpenZeppelin Contracts (last updated v4.9.0) (utils/math/SafeMath.sol)

pragma solidity ^0.8.0;

// CAUTION
// This version of SafeMath should only be used with Solidity 0.8 or later,
// because it relies on the compiler's built in overflow checks.

/**
 * @dev Wrappers over Solidity's arithmetic operations.
 *
 * NOTE: `SafeMath` is generally not needed starting with Solidity 0.8, since the compiler
 * now has built in overflow checking.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            uint256 c = a + b;
            if (c < a) return (false, 0);
            return (true, c);
        }
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b > a) return (false, 0);
            return (true, a - b);
        }
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            // 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 (true, 0);
            uint256 c = a * b;
            if (c / a != b) return (false, 0);
            return (true, c);
        }
    }

    /**
     * @dev Returns the division of two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a / b);
        }
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

    /**
     * @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) {
        return a + b;
    }

    /**
     * @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 a - b;
    }

    /**
     * @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) {
        return a * b;
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator.
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return a / b;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting 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 a % b;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {trySub}.
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        unchecked {
            require(b <= a, errorMessage);
            return a - b;
        }
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting 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) {
        unchecked {
            require(b > 0, errorMessage);
            return a / b;
        }
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting with custom message when dividing by zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryMod}.
     *
     * 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) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }
}

// File: @uniswap/v2-core/contracts/interfaces/IUniswapV2Factory.sol

pragma solidity >=0.5.0;

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;
}

// File: @uniswap/v2-core/contracts/interfaces/IUniswapV2ERC20.sol

pragma solidity >=0.5.0;

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

// File: @uniswap/v2-periphery/contracts/interfaces/IUniswapV2Router01.sol

pragma solidity >=0.6.2;

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);
}

// File: @uniswap/v2-periphery/contracts/interfaces/IUniswapV2Router02.sol

pragma solidity >=0.6.2;

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;
}

// File: contracts/tokens/EthTreatToken.sol


pragma solidity ^0.8.0;






contract TokenEth is ERC20, Ownable {
    using SafeMath for uint256;

    IUniswapV2Router02 public uniswapV2Router;
    address public uniswapV2Pair;
    address public pancakeRouter;

    uint8 public feeDecimals;
    uint32 public feePercentage;
    uint128 private minTokensBeforeSwap;

    address public treatBridge;
    address payable public treatTreasuryAddress;

    bool inSwapAndLiquify;
    bool swapAndLiquifyEnabled;

    address[] public nontaxedFromContracts;
    mapping(address => bool) public isAddressNotTaxedFrom;
    address[] public nontaxedToContracts;
    mapping(address => bool) public isAddressNotTaxedTo;

    event FeeUpdated(uint8 feeDecimals, uint32 feePercentage);
    event MinTokensBeforeSwapUpdated(uint128 minTokensBeforeSwap);
    event SwapAndLiquifyEnabledUpdated(bool enabled);
    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiqudity
    );
    event RouterChanged(address newRouter);
    event Taxing(address from, address to, uint256 amount);

    modifier lockTheSwap {
        inSwapAndLiquify = true;
        _;
        inSwapAndLiquify = false;
    }

    modifier onlyBridge() {
        require(msg.sender == treatBridge, "Caller is not the bridge");
        _;
    }

    constructor(
        uint8 _feeDecimals,
        uint32 _feePercentage,
        uint128 _minTokensBeforeSwap,
        bool _swapAndLiquifyEnabled,
        address payable _treasuryAddress
    ) ERC20("Treat", "Treat") {        
        // Create a uniswap pair for this new token
        treatTreasuryAddress = _treasuryAddress;

        updateFee(_feeDecimals, _feePercentage);
        updateMinTokensBeforeSwap(_minTokensBeforeSwap);
        updateSwapAndLiquifyEnabled(_swapAndLiquifyEnabled);
    }

    function initializeUniswapFactory(IUniswapV2Router02 _uniswapV2Router, address _pancakeRouter) public onlyOwner {
        uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory())
            .createPair(address(this), _uniswapV2Router.WETH());

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

    }

    /*
        override the internal _transfer function so that we can
        take the fee, and conditionally do the swap + liquditiy
    */
    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        // is the token balance of this contract address over the min number of
        // tokens that we need to initiate a swap + liquidity lock?
        // also, don't get caught in a circular liquidity event.
        // also, don't swap & liquify if sender is uniswap pair.
        uint256 contractTokenBalance = balanceOf(address(this));
        bool overMinTokenBalance = contractTokenBalance >= minTokensBeforeSwap;
        if (
            overMinTokenBalance &&
            !inSwapAndLiquify &&
            msg.sender != uniswapV2Pair &&
            swapAndLiquifyEnabled
        ) {
            swapAndLiquify(contractTokenBalance);
        }

        // calculate the number of tokens to take as a fee
        uint256 tokensToLock = calculateTokenFee(
            amount,
            feeDecimals,
            feePercentage,
            from,
            to
        );

        // take the fee and send those tokens to this contract address
        // and then send the remainder of tokens to original recipient
        uint256 tokensToTransfer = amount.sub(tokensToLock);

        if(tokensToLock > 0) {
            super._transfer(from, address(this), tokensToLock.div(2));
            super._transfer(from, treatTreasuryAddress, tokensToLock.div(2));
        }
        super._transfer(from, to, tokensToTransfer);
    }

    function swapAndLiquify(uint256 contractTokenBalance) private lockTheSwap {
        // split the contract balance into halves
        uint256 half = contractTokenBalance.div(2);
        uint256 otherHalf = contractTokenBalance.sub(half);

        // capture the contract's current ETH balance.
        // this is so that we can capture exactly the amount of ETH that the
        // swap creates, and not make the liquidity event include any ETH that
        // has been manually sent to the contract
        uint256 initialBalance = address(this).balance;

        // swap tokens for ETH
        swapTokensForEth(half); // <- this breaks the ETH -> TreatDao swap when swap+liquify is triggered

        // how much ETH did we just swap into?
        uint256 newBalance = address(this).balance.sub(initialBalance);

        // add liquidity to pancakeswap
        addLiquidity(otherHalf, newBalance);

        emit SwapAndLiquify(half, newBalance, otherHalf);
    }

    function swapTokensForEth(uint256 tokenAmount) private {
        // generate the pancakeswap pair path of token -> weth
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();

        _approve(address(this), address(uniswapV2Router), tokenAmount);

        // make the swap
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(this),
            block.timestamp
        );
    }

    function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
        // approve token transfer to cover all possible scenarios
        _approve(address(this), address(uniswapV2Router), tokenAmount);

        // add the liquidity
        uniswapV2Router.addLiquidityETH{value: ethAmount}(
            address(this),
            tokenAmount,
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            address(this),
            block.timestamp
        );
    }

    function calculateTokenFee(
        uint256 _amount,
        uint8 _feeDecimals,
        uint32 _feePercentage,
        address _from,
        address _to
    ) public view returns (uint256 locked) {
        bool isTaxed = true;
        if(isAddressNotTaxedFrom[_from]) {
            isTaxed = false;
        }
        if(isAddressNotTaxedTo[_to]) {
            isTaxed = false;
        }
        if(!isTaxed) {
            return 0;
        }
        locked = _amount.mul(_feePercentage).div(
            10**(uint256(_feeDecimals) + 2)
        );
    }

    function addNonTaxedToContract(address nontaxed) public onlyOwner {
        bool isAddedAlready = false;
        for(uint i=0; i< nontaxedToContracts.length; i++) {
            if(nontaxedToContracts[i] == nontaxed) {
                isAddedAlready = true;
            }
        }
        require(!isAddedAlready, "Address is already not taxed when sending to");
        nontaxedToContracts.push(nontaxed);
        isAddressNotTaxedTo[nontaxed] = true;
    }

    function addNonTaxedFromContract(address nontaxed) public onlyOwner {
        bool isAddedAlready = false;
        for(uint i=0; i< nontaxedFromContracts.length; i++) {
            if(nontaxedFromContracts[i] == nontaxed) {
                isAddedAlready = true;
            }
        }
        require(!isAddedAlready, "Address is already not taxed when sending from");
        nontaxedFromContracts.push(nontaxed);
        isAddressNotTaxedFrom[nontaxed] = true;
    }

    function removeNonTaxedToContract(address taxed) public onlyOwner {
        for (uint256 i=0; i < nontaxedToContracts.length; i++) {
            if(nontaxedToContracts[i] == taxed) {
                nontaxedToContracts[i] = nontaxedToContracts[nontaxedToContracts.length - 1];
                nontaxedToContracts.pop();
                isAddressNotTaxedTo[taxed] = false;
            }
        }
    }

    function removeNonTaxedFromContract(address taxed) public onlyOwner {
        for (uint256 i=0; i < nontaxedFromContracts.length; i++) {
            if(nontaxedFromContracts[i] == taxed) {
                nontaxedFromContracts[i] = nontaxedFromContracts[nontaxedFromContracts.length - 1];
                nontaxedFromContracts.pop();
                isAddressNotTaxedFrom[taxed] = false;
            }
        }
    }

    receive() external payable {}

    /**
     *
     * @dev burn and mint functions
     */
    function mint(address account, uint256 amount) public onlyBridge {
        _mint(account, amount);
    }

    function burn(address account, uint256 amount) public onlyBridge {
        _burn(account, amount);
    }

    ///
    /// Ownership adjustments
    ///
    function setRouter(address _pancakeRouter) public onlyOwner {
        pancakeRouter = _pancakeRouter;
        uniswapV2Router = IUniswapV2Router02(pancakeRouter);
        emit RouterChanged(_pancakeRouter);
    }

    function setBridge(address _treatBridge) public onlyOwner {
        treatBridge = _treatBridge;
    }

    function updateFee(uint8 _feeDecimals, uint32 _feePercentage) public onlyOwner {
        feeDecimals = _feeDecimals;
        feePercentage = _feePercentage;
        emit FeeUpdated(_feeDecimals, _feePercentage);
    }

    function updateMinTokensBeforeSwap(uint128 _minTokensBeforeSwap) public onlyOwner {
        minTokensBeforeSwap = _minTokensBeforeSwap;
        emit MinTokensBeforeSwapUpdated(_minTokensBeforeSwap);
    }

    function updateSwapAndLiquifyEnabled(bool _enabled) public onlyOwner {
        swapAndLiquifyEnabled = _enabled;
        emit SwapAndLiquifyEnabledUpdated(_enabled);
    }
    
    function withdrawAll(address _tokenAddress, address payable _to) public onlyOwner {
        uint balance = IERC20(_tokenAddress).balanceOf(address(this));
        IERC20(_tokenAddress).transfer(_to, balance);
    }

    function withdrawTokens(address _token,address _to,uint256 _amount) public onlyOwner {
        IUniswapV2ERC20 token = IUniswapV2ERC20(_token);
        token.transfer(_to, _amount);
    }

    function withdrawEther(address payable _to, uint256 _amount) public onlyOwner {
        _to.transfer(_amount);
    }
    
    function harvestTreats(address payable _to) public onlyOwner {
        _to.transfer(address(this).balance);
    }

    function treasury(address payable _treatTreasuryAddress) public onlyOwner {
        require(_treatTreasuryAddress != address(0), "cannot switch treasury to the zero address");
        treatTreasuryAddress = _treatTreasuryAddress;
    }

    function setPair(address _pairAddress) public onlyOwner {
        uniswapV2Pair = _pairAddress;
    }


}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"uint8","name":"_feeDecimals","type":"uint8"},{"internalType":"uint32","name":"_feePercentage","type":"uint32"},{"internalType":"uint128","name":"_minTokensBeforeSwap","type":"uint128"},{"internalType":"bool","name":"_swapAndLiquifyEnabled","type":"bool"},{"internalType":"address payable","name":"_treasuryAddress","type":"address"}],"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":false,"internalType":"uint8","name":"feeDecimals","type":"uint8"},{"indexed":false,"internalType":"uint32","name":"feePercentage","type":"uint32"}],"name":"FeeUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint128","name":"minTokensBeforeSwap","type":"uint128"}],"name":"MinTokensBeforeSwapUpdated","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":"address","name":"newRouter","type":"address"}],"name":"RouterChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiqudity","type":"uint256"}],"name":"SwapAndLiquify","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bool","name":"enabled","type":"bool"}],"name":"SwapAndLiquifyEnabledUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Taxing","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":[{"internalType":"address","name":"nontaxed","type":"address"}],"name":"addNonTaxedFromContract","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"nontaxed","type":"address"}],"name":"addNonTaxedToContract","outputs":[],"stateMutability":"nonpayable","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"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"uint8","name":"_feeDecimals","type":"uint8"},{"internalType":"uint32","name":"_feePercentage","type":"uint32"},{"internalType":"address","name":"_from","type":"address"},{"internalType":"address","name":"_to","type":"address"}],"name":"calculateTokenFee","outputs":[{"internalType":"uint256","name":"locked","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":"feeDecimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"feePercentage","outputs":[{"internalType":"uint32","name":"","type":"uint32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address payable","name":"_to","type":"address"}],"name":"harvestTreats","outputs":[],"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":"contract IUniswapV2Router02","name":"_uniswapV2Router","type":"address"},{"internalType":"address","name":"_pancakeRouter","type":"address"}],"name":"initializeUniswapFactory","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isAddressNotTaxedFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isAddressNotTaxedTo","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","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":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"nontaxedFromContracts","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"nontaxedToContracts","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pancakeRouter","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"taxed","type":"address"}],"name":"removeNonTaxedFromContract","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"taxed","type":"address"}],"name":"removeNonTaxedToContract","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_treatBridge","type":"address"}],"name":"setBridge","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_pairAddress","type":"address"}],"name":"setPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_pancakeRouter","type":"address"}],"name":"setRouter","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":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","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 payable","name":"_treatTreasuryAddress","type":"address"}],"name":"treasury","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"treatBridge","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"treatTreasuryAddress","outputs":[{"internalType":"address payable","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint8","name":"_feeDecimals","type":"uint8"},{"internalType":"uint32","name":"_feePercentage","type":"uint32"}],"name":"updateFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint128","name":"_minTokensBeforeSwap","type":"uint128"}],"name":"updateMinTokensBeforeSwap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_enabled","type":"bool"}],"name":"updateSwapAndLiquifyEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_tokenAddress","type":"address"},{"internalType":"address payable","name":"_to","type":"address"}],"name":"withdrawAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address payable","name":"_to","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"withdrawEther","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_token","type":"address"},{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"withdrawTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

60806040523480156200001157600080fd5b5060405162002b1d38038062002b1d8339810160408190526200003491620002f7565b604080518082018252600580825264151c99585d60da1b602080840182905284518086019095529184529083015290600362000071838262000433565b50600462000080828262000433565b5050506200009d62000097620000e560201b60201c565b620000e9565b600b80546001600160a01b0319166001600160a01b038316179055620000c485856200013b565b620000cf83620001c2565b620000da8262000221565b5050505050620004ff565b3390565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6200014562000279565b6008805464ffffffffff60a01b1916600160a01b60ff851690810263ffffffff60a81b191691909117600160a81b63ffffffff8516908102919091179092556040805191825260208201929092527f460fa919625630f734b5d86356a2511f134b6df313c793ca09e0399de8d933a0910160405180910390a15050565b620001cc62000279565b600980546001600160801b0319166001600160801b0383169081179091556040519081527fb20e0f86438dbd4812cee7b24a6696d4dbaa9d3db89c677e731ab7dd738c8bbe906020015b60405180910390a150565b6200022b62000279565b600b8054821515600160a81b0260ff60a81b199091161790556040517f53726dfcaf90650aa7eb35524f4d3220f07413c8d6cb404cc8c18bf5591bc159906200021690831515815260200190565b6005546001600160a01b03163314620002d85760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640160405180910390fd5b565b80516001600160a01b0381168114620002f257600080fd5b919050565b600080600080600060a086880312156200031057600080fd5b855160ff811681146200032257600080fd5b602087015190955063ffffffff811681146200033d57600080fd5b60408701519094506001600160801b03811681146200035b57600080fd5b606087015190935080151581146200037257600080fd5b91506200038260808701620002da565b90509295509295909350565b634e487b7160e01b600052604160045260246000fd5b600181811c90821680620003b957607f821691505b602082108103620003da57634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200042e57600081815260208120601f850160051c81016020861015620004095750805b601f850160051c820191505b818110156200042a5782815560010162000415565b5050505b505050565b81516001600160401b038111156200044f576200044f6200038e565b6200046781620004608454620003a4565b84620003e0565b602080601f8311600181146200049f5760008415620004865750858301515b600019600386901b1c1916600185901b1785556200042a565b600085815260208120601f198616915b82811015620004d057888601518255948401946001909101908401620004af565b5085821015620004ef5787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b61260e806200050f6000396000f3fe60806040526004361061026b5760003560e01c80636061cd0911610144578063a41270f0116100b6578063c21ebd071161007a578063c21ebd07146107a4578063c47ad891146107c4578063cc0f1786146107e4578063dd62ed3e14610805578063eaa93e7814610825578063f2fde38b1461084557600080fd5b8063a41270f014610704578063a457c2d714610724578063a9059cbb14610744578063b6a3ed3114610764578063c0d786551461078457600080fd5b80638da5cb5b116101085780638da5cb5b146106385780638dd148021461065657806395d89b41146106765780639dc29fac1461068b5780639f9a4e7f146106ab578063a001ecdd146106cb57600080fd5b80636061cd091461058d5780636b99f4b2146105ad57806370a08231146105cd578063715018a6146106035780638187f5161461061857600080fd5b80632d809cb6116101dd57806340db75d6116101a157806340db75d6146104bd578063468b5a9a146104dd57806349bd5a5e1461050d578063522f68151461052d5780635a11ee021461054d5780635e35359e1461056d57600080fd5b80632d809cb61461041b578063313ce5671461043b578063395093511461045d5780633a27b7641461047d57806340c10f191461049d57600080fd5b80631694505e1161022f5780631694505e1461035c57806318160ddd1461037c5780631a5ea48c1461039b5780631ad82d16146103bb57806323b872dd146103db5780632a8ab3fc146103fb57600080fd5b806306fdde0314610277578063095ea7b3146102a257806309cae2c8146102d25780630f81f9f7146102f4578063129a81cf1461032c57600080fd5b3661027257005b600080fd5b34801561028357600080fd5b5061028c610865565b60405161029991906120ae565b60405180910390f35b3480156102ae57600080fd5b506102c26102bd366004612111565b6108f7565b6040519015158152602001610299565b3480156102de57600080fd5b506102f26102ed36600461213d565b610911565b005b34801561030057600080fd5b50600a54610314906001600160a01b031681565b6040516001600160a01b039091168152602001610299565b34801561033857600080fd5b506102c2610347366004612176565b600f6020526000908152604090205460ff1681565b34801561036857600080fd5b50600654610314906001600160a01b031681565b34801561038857600080fd5b506002545b604051908152602001610299565b3480156103a757600080fd5b506103146103b6366004612193565b610a01565b3480156103c757600080fd5b50600b54610314906001600160a01b031681565b3480156103e757600080fd5b506102c26103f63660046121ac565b610a2b565b34801561040757600080fd5b506102f261041636600461213d565b610a4f565b34801561042757600080fd5b506102f2610436366004612176565b610bd8565b34801561044757600080fd5b5060125b60405160ff9091168152602001610299565b34801561046957600080fd5b506102c2610478366004612111565b610c70565b34801561048957600080fd5b506102f26104983660046121ed565b610c92565b3480156104a957600080fd5b506102f26104b8366004612111565b610cf8565b3480156104c957600080fd5b506102f26104d8366004612176565b610d5b565b3480156104e957600080fd5b506102c26104f8366004612176565b600d6020526000908152604090205460ff1681565b34801561051957600080fd5b50600754610314906001600160a01b031681565b34801561053957600080fd5b506102f2610548366004612111565b610e87565b34801561055957600080fd5b506102f2610568366004612176565b610eca565b34801561057957600080fd5b506102f26105883660046121ac565b610ffc565b34801561059957600080fd5b5061038d6105a8366004612240565b611081565b3480156105b957600080fd5b506103146105c8366004612193565b61111f565b3480156105d957600080fd5b5061038d6105e8366004612176565b6001600160a01b031660009081526020819052604090205490565b34801561060f57600080fd5b506102f261112f565b34801561062457600080fd5b506102f2610633366004612176565b611143565b34801561064457600080fd5b506005546001600160a01b0316610314565b34801561066257600080fd5b506102f2610671366004612176565b61116d565b34801561068257600080fd5b5061028c611197565b34801561069757600080fd5b506102f26106a6366004612111565b6111a6565b3480156106b757600080fd5b506102f26106c63660046122b2565b611205565b3480156106d757600080fd5b506008546106ef90600160a81b900463ffffffff1681565b60405163ffffffff9091168152602001610299565b34801561071057600080fd5b506102f261071f366004612176565b61125a565b34801561073057600080fd5b506102c261073f366004612111565b611297565b34801561075057600080fd5b506102c261075f366004612111565b611312565b34801561077057600080fd5b506102f261077f366004612176565b611320565b34801561079057600080fd5b506102f261079f366004612176565b61144c565b3480156107b057600080fd5b50600854610314906001600160a01b031681565b3480156107d057600080fd5b506102f26107df366004612176565b6114ae565b3480156107f057600080fd5b5060085461044b90600160a01b900460ff1681565b34801561081157600080fd5b5061038d61082036600461213d565b6115de565b34801561083157600080fd5b506102f26108403660046122cf565b611609565b34801561085157600080fd5b506102f2610860366004612176565b61168e565b60606003805461087490612302565b80601f01602080910402602001604051908101604052809291908181526020018280546108a090612302565b80156108ed5780601f106108c2576101008083540402835291602001916108ed565b820191906000526020600020905b8154815290600101906020018083116108d057829003601f168201915b5050505050905090565b600033610905818585611707565b60019150505b92915050565b61091961182b565b6040516370a0823160e01b81523060048201526000906001600160a01b038416906370a0823190602401602060405180830381865afa158015610960573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610984919061233c565b60405163a9059cbb60e01b81526001600160a01b038481166004830152602482018390529192509084169063a9059cbb906044016020604051808303816000875af11580156109d7573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906109fb9190612355565b50505050565b600c8181548110610a1157600080fd5b6000918252602090912001546001600160a01b0316905081565b600033610a39858285611885565b610a448585856118f9565b506001949350505050565b610a5761182b565b816001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a95573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ab99190612372565b6001600160a01b031663c9c6539630846001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610b06573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b2a9190612372565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015610b77573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b9b9190612372565b600780546001600160a01b03199081166001600160a01b039384161790915560068054821694831694909417909355600880549093169116179055565b610be061182b565b6001600160a01b038116610c4e5760405162461bcd60e51b815260206004820152602a60248201527f63616e6e6f742073776974636820747265617375727920746f20746865207a65604482015269726f206164647265737360b01b60648201526084015b60405180910390fd5b600b80546001600160a01b0319166001600160a01b0392909216919091179055565b600033610905818585610c8383836115de565b610c8d91906123a5565b611707565b610c9a61182b565b600980546fffffffffffffffffffffffffffffffff19166001600160801b0383169081179091556040519081527fb20e0f86438dbd4812cee7b24a6696d4dbaa9d3db89c677e731ab7dd738c8bbe906020015b60405180910390a150565b600a546001600160a01b03163314610d4d5760405162461bcd60e51b815260206004820152601860248201527743616c6c6572206973206e6f74207468652062726964676560401b6044820152606401610c45565b610d5782826119f1565b5050565b610d6361182b565b60005b600e54811015610d5757816001600160a01b0316600e8281548110610d8d57610d8d6123b8565b6000918252602090912001546001600160a01b031603610e7557600e8054610db7906001906123ce565b81548110610dc757610dc76123b8565b600091825260209091200154600e80546001600160a01b039092169183908110610df357610df36123b8565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600e805480610e3257610e326123e1565b60008281526020808220830160001990810180546001600160a01b03191690559092019092556001600160a01b0384168252600f905260409020805460ff191690555b80610e7f816123f7565b915050610d66565b610e8f61182b565b6040516001600160a01b0383169082156108fc029083906000818181858888f19350505050158015610ec5573d6000803e3d6000fd5b505050565b610ed261182b565b6000805b600c54811015610f2e57826001600160a01b0316600c8281548110610efd57610efd6123b8565b6000918252602090912001546001600160a01b031603610f1c57600191505b80610f26816123f7565b915050610ed6565b508015610f945760405162461bcd60e51b815260206004820152602e60248201527f4164647265737320697320616c7265616479206e6f742074617865642077686560448201526d6e2073656e64696e672066726f6d60901b6064820152608401610c45565b50600c805460018181019092557fdf6966c971051c3d54ec59162606531493a51404a002842f56009d7e5cf4a8c70180546001600160a01b039093166001600160a01b0319909316831790556000918252600d6020526040909120805460ff19169091179055565b61100461182b565b60405163a9059cbb60e01b81526001600160a01b0383811660048301526024820183905284919082169063a9059cbb906044016020604051808303816000875af1158015611056573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061107a9190612355565b5050505050565b6001600160a01b0382166000908152600d602052604081205460019060ff16156110a9575060005b6001600160a01b0383166000908152600f602052604090205460ff16156110ce575060005b806110dd576000915050611116565b6111126110ee60ff881660026123a5565b6110f990600a6124f4565b61110c8963ffffffff808a1690611ab016565b90611ac3565b9150505b95945050505050565b600e8181548110610a1157600080fd5b61113761182b565b6111416000611acf565b565b61114b61182b565b600780546001600160a01b0319166001600160a01b0392909216919091179055565b61117561182b565b600a80546001600160a01b0319166001600160a01b0392909216919091179055565b60606004805461087490612302565b600a546001600160a01b031633146111fb5760405162461bcd60e51b815260206004820152601860248201527743616c6c6572206973206e6f74207468652062726964676560401b6044820152606401610c45565b610d578282611b21565b61120d61182b565b600b8054821515600160a81b0260ff60a81b199091161790556040517f53726dfcaf90650aa7eb35524f4d3220f07413c8d6cb404cc8c18bf5591bc15990610ced90831515815260200190565b61126261182b565b6040516001600160a01b038216904780156108fc02916000818181858888f19350505050158015610d57573d6000803e3d6000fd5b600033816112a582866115de565b9050838110156113055760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610c45565b610a448286868403611707565b6000336109058185856118f9565b61132861182b565b60005b600c54811015610d5757816001600160a01b0316600c8281548110611352576113526123b8565b6000918252602090912001546001600160a01b03160361143a57600c805461137c906001906123ce565b8154811061138c5761138c6123b8565b600091825260209091200154600c80546001600160a01b0390921691839081106113b8576113b86123b8565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600c8054806113f7576113f76123e1565b60008281526020808220830160001990810180546001600160a01b03191690559092019092556001600160a01b0384168252600d905260409020805460ff191690555b80611444816123f7565b91505061132b565b61145461182b565b600880546001600160a01b0383166001600160a01b0319918216811790925560068054909116821790556040519081527f1085cec9a5108943412475d298086ae4d0abf09cfad47b05436b89fe887a820c90602001610ced565b6114b661182b565b6000805b600e5481101561151257826001600160a01b0316600e82815481106114e1576114e16123b8565b6000918252602090912001546001600160a01b03160361150057600191505b8061150a816123f7565b9150506114ba565b5080156115765760405162461bcd60e51b815260206004820152602c60248201527f4164647265737320697320616c7265616479206e6f742074617865642077686560448201526b6e2073656e64696e6720746f60a01b6064820152608401610c45565b50600e805460018181019092557fbb7b4a454dc3493923482f07822329ed19e8244eff582cc204f8554c3620c3fd0180546001600160a01b039093166001600160a01b0319909316831790556000918252600f6020526040909120805460ff19169091179055565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b61161161182b565b6008805464ffffffffff60a01b1916600160a01b60ff851690810263ffffffff60a81b191691909117600160a81b63ffffffff8516908102919091179092556040805191825260208201929092527f460fa919625630f734b5d86356a2511f134b6df313c793ca09e0399de8d933a0910160405180910390a15050565b61169661182b565b6001600160a01b0381166116fb5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610c45565b61170481611acf565b50565b6001600160a01b0383166117695760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610c45565b6001600160a01b0382166117ca5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610c45565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6005546001600160a01b031633146111415760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610c45565b600061189184846115de565b905060001981146109fb57818110156118ec5760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610c45565b6109fb8484848403611707565b306000908152602081905260409020546009546001600160801b0316811080159081906119305750600b54600160a01b900460ff16155b801561194757506007546001600160a01b03163314155b801561195c5750600b54600160a81b900460ff165b1561196a5761196a82611c53565b600854600090611995908590600160a01b810460ff1690600160a81b900463ffffffff168989611081565b905060006119a38583611cfa565b905081156119dd576119c087306119bb856002611ac3565b611d06565b600b546119dd9088906001600160a01b03166119bb856002611ac3565b6119e8878783611d06565b50505050505050565b6001600160a01b038216611a475760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401610c45565b8060026000828254611a5991906123a5565b90915550506001600160a01b038216600081815260208181526040808320805486019055518481527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6000611abc8284612500565b9392505050565b6000611abc8284612517565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038216611b815760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610c45565b6001600160a01b03821660009081526020819052604090205481811015611bf55760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b6064820152608401610c45565b6001600160a01b0383166000818152602081815260408083208686039055600280548790039055518581529192917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a3505050565b600b805460ff60a01b1916600160a01b1790556000611c73826002611ac3565b90506000611c818383611cfa565b905047611c8d83611eaa565b6000611c994783611cfa565b9050611ca58382612004565b60408051858152602081018390529081018490527f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619060600160405180910390a15050600b805460ff60a01b19169055505050565b6000611abc82846123ce565b6001600160a01b038316611d6a5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610c45565b6001600160a01b038216611dcc5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610c45565b6001600160a01b03831660009081526020819052604090205481811015611e445760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610c45565b6001600160a01b03848116600081815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a36109fb565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611edf57611edf6123b8565b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611f38573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611f5c9190612372565b81600181518110611f6f57611f6f6123b8565b6001600160a01b039283166020918202929092010152600654611f959130911684611707565b60065460405163791ac94760e01b81526001600160a01b039091169063791ac94790611fce908590600090869030904290600401612539565b600060405180830381600087803b158015611fe857600080fd5b505af1158015611ffc573d6000803e3d6000fd5b505050505050565b60065461201c9030906001600160a01b031684611707565b60065460405163f305d71960e01b8152306004820181905260248201859052600060448301819052606483015260848201524260a48201526001600160a01b039091169063f305d71990839060c40160606040518083038185885af1158015612089573d6000803e3d6000fd5b50505050506040513d601f19601f8201168201806040525081019061107a91906125aa565b600060208083528351808285015260005b818110156120db578581018301518582016040015282016120bf565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461170457600080fd5b6000806040838503121561212457600080fd5b823561212f816120fc565b946020939093013593505050565b6000806040838503121561215057600080fd5b823561215b816120fc565b9150602083013561216b816120fc565b809150509250929050565b60006020828403121561218857600080fd5b8135611abc816120fc565b6000602082840312156121a557600080fd5b5035919050565b6000806000606084860312156121c157600080fd5b83356121cc816120fc565b925060208401356121dc816120fc565b929592945050506040919091013590565b6000602082840312156121ff57600080fd5b81356001600160801b0381168114611abc57600080fd5b803560ff8116811461222757600080fd5b919050565b803563ffffffff8116811461222757600080fd5b600080600080600060a0868803121561225857600080fd5b8535945061226860208701612216565b93506122766040870161222c565b92506060860135612286816120fc565b91506080860135612296816120fc565b809150509295509295909350565b801515811461170457600080fd5b6000602082840312156122c457600080fd5b8135611abc816122a4565b600080604083850312156122e257600080fd5b6122eb83612216565b91506122f96020840161222c565b90509250929050565b600181811c9082168061231657607f821691505b60208210810361233657634e487b7160e01b600052602260045260246000fd5b50919050565b60006020828403121561234e57600080fd5b5051919050565b60006020828403121561236757600080fd5b8151611abc816122a4565b60006020828403121561238457600080fd5b8151611abc816120fc565b634e487b7160e01b600052601160045260246000fd5b8082018082111561090b5761090b61238f565b634e487b7160e01b600052603260045260246000fd5b8181038181111561090b5761090b61238f565b634e487b7160e01b600052603160045260246000fd5b6000600182016124095761240961238f565b5060010190565b600181815b8085111561244b5781600019048211156124315761243161238f565b8085161561243e57918102915b93841c9390800290612415565b509250929050565b6000826124625750600161090b565b8161246f5750600061090b565b8160018114612485576002811461248f576124ab565b600191505061090b565b60ff8411156124a0576124a061238f565b50506001821b61090b565b5060208310610133831016604e8410600b84101617156124ce575081810a61090b565b6124d88383612410565b80600019048211156124ec576124ec61238f565b029392505050565b6000611abc8383612453565b808202811582820484141761090b5761090b61238f565b60008261253457634e487b7160e01b600052601260045260246000fd5b500490565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156125895784516001600160a01b031683529383019391830191600101612564565b50506001600160a01b03969096166060850152505050608001529392505050565b6000806000606084860312156125bf57600080fd5b835192506020840151915060408401519050925092509256fea26469706673582212209b955cb7fb2424400121316ff639839571efceb0476208f8106660b9e0fc1c0864736f6c634300081100330000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000000000000000000000000000000c6863e579710a16e916591aaa9b85487625885f4

Deployed Bytecode

0x60806040526004361061026b5760003560e01c80636061cd0911610144578063a41270f0116100b6578063c21ebd071161007a578063c21ebd07146107a4578063c47ad891146107c4578063cc0f1786146107e4578063dd62ed3e14610805578063eaa93e7814610825578063f2fde38b1461084557600080fd5b8063a41270f014610704578063a457c2d714610724578063a9059cbb14610744578063b6a3ed3114610764578063c0d786551461078457600080fd5b80638da5cb5b116101085780638da5cb5b146106385780638dd148021461065657806395d89b41146106765780639dc29fac1461068b5780639f9a4e7f146106ab578063a001ecdd146106cb57600080fd5b80636061cd091461058d5780636b99f4b2146105ad57806370a08231146105cd578063715018a6146106035780638187f5161461061857600080fd5b80632d809cb6116101dd57806340db75d6116101a157806340db75d6146104bd578063468b5a9a146104dd57806349bd5a5e1461050d578063522f68151461052d5780635a11ee021461054d5780635e35359e1461056d57600080fd5b80632d809cb61461041b578063313ce5671461043b578063395093511461045d5780633a27b7641461047d57806340c10f191461049d57600080fd5b80631694505e1161022f5780631694505e1461035c57806318160ddd1461037c5780631a5ea48c1461039b5780631ad82d16146103bb57806323b872dd146103db5780632a8ab3fc146103fb57600080fd5b806306fdde0314610277578063095ea7b3146102a257806309cae2c8146102d25780630f81f9f7146102f4578063129a81cf1461032c57600080fd5b3661027257005b600080fd5b34801561028357600080fd5b5061028c610865565b60405161029991906120ae565b60405180910390f35b3480156102ae57600080fd5b506102c26102bd366004612111565b6108f7565b6040519015158152602001610299565b3480156102de57600080fd5b506102f26102ed36600461213d565b610911565b005b34801561030057600080fd5b50600a54610314906001600160a01b031681565b6040516001600160a01b039091168152602001610299565b34801561033857600080fd5b506102c2610347366004612176565b600f6020526000908152604090205460ff1681565b34801561036857600080fd5b50600654610314906001600160a01b031681565b34801561038857600080fd5b506002545b604051908152602001610299565b3480156103a757600080fd5b506103146103b6366004612193565b610a01565b3480156103c757600080fd5b50600b54610314906001600160a01b031681565b3480156103e757600080fd5b506102c26103f63660046121ac565b610a2b565b34801561040757600080fd5b506102f261041636600461213d565b610a4f565b34801561042757600080fd5b506102f2610436366004612176565b610bd8565b34801561044757600080fd5b5060125b60405160ff9091168152602001610299565b34801561046957600080fd5b506102c2610478366004612111565b610c70565b34801561048957600080fd5b506102f26104983660046121ed565b610c92565b3480156104a957600080fd5b506102f26104b8366004612111565b610cf8565b3480156104c957600080fd5b506102f26104d8366004612176565b610d5b565b3480156104e957600080fd5b506102c26104f8366004612176565b600d6020526000908152604090205460ff1681565b34801561051957600080fd5b50600754610314906001600160a01b031681565b34801561053957600080fd5b506102f2610548366004612111565b610e87565b34801561055957600080fd5b506102f2610568366004612176565b610eca565b34801561057957600080fd5b506102f26105883660046121ac565b610ffc565b34801561059957600080fd5b5061038d6105a8366004612240565b611081565b3480156105b957600080fd5b506103146105c8366004612193565b61111f565b3480156105d957600080fd5b5061038d6105e8366004612176565b6001600160a01b031660009081526020819052604090205490565b34801561060f57600080fd5b506102f261112f565b34801561062457600080fd5b506102f2610633366004612176565b611143565b34801561064457600080fd5b506005546001600160a01b0316610314565b34801561066257600080fd5b506102f2610671366004612176565b61116d565b34801561068257600080fd5b5061028c611197565b34801561069757600080fd5b506102f26106a6366004612111565b6111a6565b3480156106b757600080fd5b506102f26106c63660046122b2565b611205565b3480156106d757600080fd5b506008546106ef90600160a81b900463ffffffff1681565b60405163ffffffff9091168152602001610299565b34801561071057600080fd5b506102f261071f366004612176565b61125a565b34801561073057600080fd5b506102c261073f366004612111565b611297565b34801561075057600080fd5b506102c261075f366004612111565b611312565b34801561077057600080fd5b506102f261077f366004612176565b611320565b34801561079057600080fd5b506102f261079f366004612176565b61144c565b3480156107b057600080fd5b50600854610314906001600160a01b031681565b3480156107d057600080fd5b506102f26107df366004612176565b6114ae565b3480156107f057600080fd5b5060085461044b90600160a01b900460ff1681565b34801561081157600080fd5b5061038d61082036600461213d565b6115de565b34801561083157600080fd5b506102f26108403660046122cf565b611609565b34801561085157600080fd5b506102f2610860366004612176565b61168e565b60606003805461087490612302565b80601f01602080910402602001604051908101604052809291908181526020018280546108a090612302565b80156108ed5780601f106108c2576101008083540402835291602001916108ed565b820191906000526020600020905b8154815290600101906020018083116108d057829003601f168201915b5050505050905090565b600033610905818585611707565b60019150505b92915050565b61091961182b565b6040516370a0823160e01b81523060048201526000906001600160a01b038416906370a0823190602401602060405180830381865afa158015610960573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610984919061233c565b60405163a9059cbb60e01b81526001600160a01b038481166004830152602482018390529192509084169063a9059cbb906044016020604051808303816000875af11580156109d7573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906109fb9190612355565b50505050565b600c8181548110610a1157600080fd5b6000918252602090912001546001600160a01b0316905081565b600033610a39858285611885565b610a448585856118f9565b506001949350505050565b610a5761182b565b816001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a95573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ab99190612372565b6001600160a01b031663c9c6539630846001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610b06573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b2a9190612372565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015610b77573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b9b9190612372565b600780546001600160a01b03199081166001600160a01b039384161790915560068054821694831694909417909355600880549093169116179055565b610be061182b565b6001600160a01b038116610c4e5760405162461bcd60e51b815260206004820152602a60248201527f63616e6e6f742073776974636820747265617375727920746f20746865207a65604482015269726f206164647265737360b01b60648201526084015b60405180910390fd5b600b80546001600160a01b0319166001600160a01b0392909216919091179055565b600033610905818585610c8383836115de565b610c8d91906123a5565b611707565b610c9a61182b565b600980546fffffffffffffffffffffffffffffffff19166001600160801b0383169081179091556040519081527fb20e0f86438dbd4812cee7b24a6696d4dbaa9d3db89c677e731ab7dd738c8bbe906020015b60405180910390a150565b600a546001600160a01b03163314610d4d5760405162461bcd60e51b815260206004820152601860248201527743616c6c6572206973206e6f74207468652062726964676560401b6044820152606401610c45565b610d5782826119f1565b5050565b610d6361182b565b60005b600e54811015610d5757816001600160a01b0316600e8281548110610d8d57610d8d6123b8565b6000918252602090912001546001600160a01b031603610e7557600e8054610db7906001906123ce565b81548110610dc757610dc76123b8565b600091825260209091200154600e80546001600160a01b039092169183908110610df357610df36123b8565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600e805480610e3257610e326123e1565b60008281526020808220830160001990810180546001600160a01b03191690559092019092556001600160a01b0384168252600f905260409020805460ff191690555b80610e7f816123f7565b915050610d66565b610e8f61182b565b6040516001600160a01b0383169082156108fc029083906000818181858888f19350505050158015610ec5573d6000803e3d6000fd5b505050565b610ed261182b565b6000805b600c54811015610f2e57826001600160a01b0316600c8281548110610efd57610efd6123b8565b6000918252602090912001546001600160a01b031603610f1c57600191505b80610f26816123f7565b915050610ed6565b508015610f945760405162461bcd60e51b815260206004820152602e60248201527f4164647265737320697320616c7265616479206e6f742074617865642077686560448201526d6e2073656e64696e672066726f6d60901b6064820152608401610c45565b50600c805460018181019092557fdf6966c971051c3d54ec59162606531493a51404a002842f56009d7e5cf4a8c70180546001600160a01b039093166001600160a01b0319909316831790556000918252600d6020526040909120805460ff19169091179055565b61100461182b565b60405163a9059cbb60e01b81526001600160a01b0383811660048301526024820183905284919082169063a9059cbb906044016020604051808303816000875af1158015611056573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061107a9190612355565b5050505050565b6001600160a01b0382166000908152600d602052604081205460019060ff16156110a9575060005b6001600160a01b0383166000908152600f602052604090205460ff16156110ce575060005b806110dd576000915050611116565b6111126110ee60ff881660026123a5565b6110f990600a6124f4565b61110c8963ffffffff808a1690611ab016565b90611ac3565b9150505b95945050505050565b600e8181548110610a1157600080fd5b61113761182b565b6111416000611acf565b565b61114b61182b565b600780546001600160a01b0319166001600160a01b0392909216919091179055565b61117561182b565b600a80546001600160a01b0319166001600160a01b0392909216919091179055565b60606004805461087490612302565b600a546001600160a01b031633146111fb5760405162461bcd60e51b815260206004820152601860248201527743616c6c6572206973206e6f74207468652062726964676560401b6044820152606401610c45565b610d578282611b21565b61120d61182b565b600b8054821515600160a81b0260ff60a81b199091161790556040517f53726dfcaf90650aa7eb35524f4d3220f07413c8d6cb404cc8c18bf5591bc15990610ced90831515815260200190565b61126261182b565b6040516001600160a01b038216904780156108fc02916000818181858888f19350505050158015610d57573d6000803e3d6000fd5b600033816112a582866115de565b9050838110156113055760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610c45565b610a448286868403611707565b6000336109058185856118f9565b61132861182b565b60005b600c54811015610d5757816001600160a01b0316600c8281548110611352576113526123b8565b6000918252602090912001546001600160a01b03160361143a57600c805461137c906001906123ce565b8154811061138c5761138c6123b8565b600091825260209091200154600c80546001600160a01b0390921691839081106113b8576113b86123b8565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600c8054806113f7576113f76123e1565b60008281526020808220830160001990810180546001600160a01b03191690559092019092556001600160a01b0384168252600d905260409020805460ff191690555b80611444816123f7565b91505061132b565b61145461182b565b600880546001600160a01b0383166001600160a01b0319918216811790925560068054909116821790556040519081527f1085cec9a5108943412475d298086ae4d0abf09cfad47b05436b89fe887a820c90602001610ced565b6114b661182b565b6000805b600e5481101561151257826001600160a01b0316600e82815481106114e1576114e16123b8565b6000918252602090912001546001600160a01b03160361150057600191505b8061150a816123f7565b9150506114ba565b5080156115765760405162461bcd60e51b815260206004820152602c60248201527f4164647265737320697320616c7265616479206e6f742074617865642077686560448201526b6e2073656e64696e6720746f60a01b6064820152608401610c45565b50600e805460018181019092557fbb7b4a454dc3493923482f07822329ed19e8244eff582cc204f8554c3620c3fd0180546001600160a01b039093166001600160a01b0319909316831790556000918252600f6020526040909120805460ff19169091179055565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b61161161182b565b6008805464ffffffffff60a01b1916600160a01b60ff851690810263ffffffff60a81b191691909117600160a81b63ffffffff8516908102919091179092556040805191825260208201929092527f460fa919625630f734b5d86356a2511f134b6df313c793ca09e0399de8d933a0910160405180910390a15050565b61169661182b565b6001600160a01b0381166116fb5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610c45565b61170481611acf565b50565b6001600160a01b0383166117695760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610c45565b6001600160a01b0382166117ca5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610c45565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6005546001600160a01b031633146111415760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610c45565b600061189184846115de565b905060001981146109fb57818110156118ec5760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610c45565b6109fb8484848403611707565b306000908152602081905260409020546009546001600160801b0316811080159081906119305750600b54600160a01b900460ff16155b801561194757506007546001600160a01b03163314155b801561195c5750600b54600160a81b900460ff165b1561196a5761196a82611c53565b600854600090611995908590600160a01b810460ff1690600160a81b900463ffffffff168989611081565b905060006119a38583611cfa565b905081156119dd576119c087306119bb856002611ac3565b611d06565b600b546119dd9088906001600160a01b03166119bb856002611ac3565b6119e8878783611d06565b50505050505050565b6001600160a01b038216611a475760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401610c45565b8060026000828254611a5991906123a5565b90915550506001600160a01b038216600081815260208181526040808320805486019055518481527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6000611abc8284612500565b9392505050565b6000611abc8284612517565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038216611b815760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610c45565b6001600160a01b03821660009081526020819052604090205481811015611bf55760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b6064820152608401610c45565b6001600160a01b0383166000818152602081815260408083208686039055600280548790039055518581529192917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a3505050565b600b805460ff60a01b1916600160a01b1790556000611c73826002611ac3565b90506000611c818383611cfa565b905047611c8d83611eaa565b6000611c994783611cfa565b9050611ca58382612004565b60408051858152602081018390529081018490527f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619060600160405180910390a15050600b805460ff60a01b19169055505050565b6000611abc82846123ce565b6001600160a01b038316611d6a5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610c45565b6001600160a01b038216611dcc5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610c45565b6001600160a01b03831660009081526020819052604090205481811015611e445760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610c45565b6001600160a01b03848116600081815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a36109fb565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611edf57611edf6123b8565b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611f38573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611f5c9190612372565b81600181518110611f6f57611f6f6123b8565b6001600160a01b039283166020918202929092010152600654611f959130911684611707565b60065460405163791ac94760e01b81526001600160a01b039091169063791ac94790611fce908590600090869030904290600401612539565b600060405180830381600087803b158015611fe857600080fd5b505af1158015611ffc573d6000803e3d6000fd5b505050505050565b60065461201c9030906001600160a01b031684611707565b60065460405163f305d71960e01b8152306004820181905260248201859052600060448301819052606483015260848201524260a48201526001600160a01b039091169063f305d71990839060c40160606040518083038185885af1158015612089573d6000803e3d6000fd5b50505050506040513d601f19601f8201168201806040525081019061107a91906125aa565b600060208083528351808285015260005b818110156120db578581018301518582016040015282016120bf565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461170457600080fd5b6000806040838503121561212457600080fd5b823561212f816120fc565b946020939093013593505050565b6000806040838503121561215057600080fd5b823561215b816120fc565b9150602083013561216b816120fc565b809150509250929050565b60006020828403121561218857600080fd5b8135611abc816120fc565b6000602082840312156121a557600080fd5b5035919050565b6000806000606084860312156121c157600080fd5b83356121cc816120fc565b925060208401356121dc816120fc565b929592945050506040919091013590565b6000602082840312156121ff57600080fd5b81356001600160801b0381168114611abc57600080fd5b803560ff8116811461222757600080fd5b919050565b803563ffffffff8116811461222757600080fd5b600080600080600060a0868803121561225857600080fd5b8535945061226860208701612216565b93506122766040870161222c565b92506060860135612286816120fc565b91506080860135612296816120fc565b809150509295509295909350565b801515811461170457600080fd5b6000602082840312156122c457600080fd5b8135611abc816122a4565b600080604083850312156122e257600080fd5b6122eb83612216565b91506122f96020840161222c565b90509250929050565b600181811c9082168061231657607f821691505b60208210810361233657634e487b7160e01b600052602260045260246000fd5b50919050565b60006020828403121561234e57600080fd5b5051919050565b60006020828403121561236757600080fd5b8151611abc816122a4565b60006020828403121561238457600080fd5b8151611abc816120fc565b634e487b7160e01b600052601160045260246000fd5b8082018082111561090b5761090b61238f565b634e487b7160e01b600052603260045260246000fd5b8181038181111561090b5761090b61238f565b634e487b7160e01b600052603160045260246000fd5b6000600182016124095761240961238f565b5060010190565b600181815b8085111561244b5781600019048211156124315761243161238f565b8085161561243e57918102915b93841c9390800290612415565b509250929050565b6000826124625750600161090b565b8161246f5750600061090b565b8160018114612485576002811461248f576124ab565b600191505061090b565b60ff8411156124a0576124a061238f565b50506001821b61090b565b5060208310610133831016604e8410600b84101617156124ce575081810a61090b565b6124d88383612410565b80600019048211156124ec576124ec61238f565b029392505050565b6000611abc8383612453565b808202811582820484141761090b5761090b61238f565b60008261253457634e487b7160e01b600052601260045260246000fd5b500490565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156125895784516001600160a01b031683529383019391830191600101612564565b50506001600160a01b03969096166060850152505050608001529392505050565b6000806000606084860312156125bf57600080fd5b835192506020840151915060408401519050925092509256fea26469706673582212209b955cb7fb2424400121316ff639839571efceb0476208f8106660b9e0fc1c0864736f6c63430008110033

Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)

0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000000000000000000000000000000c6863e579710a16e916591aaa9b85487625885f4

-----Decoded View---------------
Arg [0] : _feeDecimals (uint8): 0
Arg [1] : _feePercentage (uint32): 2
Arg [2] : _minTokensBeforeSwap (uint128): 100
Arg [3] : _swapAndLiquifyEnabled (bool): False
Arg [4] : _treasuryAddress (address): 0xC6863E579710A16e916591AAA9B85487625885F4

-----Encoded View---------------
5 Constructor Arguments found :
Arg [0] : 0000000000000000000000000000000000000000000000000000000000000000
Arg [1] : 0000000000000000000000000000000000000000000000000000000000000002
Arg [2] : 0000000000000000000000000000000000000000000000000000000000000064
Arg [3] : 0000000000000000000000000000000000000000000000000000000000000000
Arg [4] : 000000000000000000000000c6863e579710a16e916591aaa9b85487625885f4


Deployed Bytecode Sourcemap

34415:10787:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6642:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;9002:201;;;;;;;;;;-1:-1:-1;9002:201:0;;;;;:::i;:::-;;:::i;:::-;;;1188:14:1;;1181:22;1163:41;;1151:2;1136:18;9002:201:0;1023:187:1;44170:217:0;;;;;;;;;;-1:-1:-1;44170:217:0;;;;;:::i;:::-;;:::i;:::-;;34722:26;;;;;;;;;;-1:-1:-1;34722:26:0;;;;-1:-1:-1;;;;;34722:26:0;;;;;;-1:-1:-1;;;;;1780:32:1;;;1762:51;;1750:2;1735:18;34722:26:0;1616:203:1;35018:51:0;;;;;;;;;;-1:-1:-1;35018:51:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;34493:41;;;;;;;;;;-1:-1:-1;34493:41:0;;;;-1:-1:-1;;;;;34493:41:0;;;7771:108;;;;;;;;;;-1:-1:-1;7859:12:0;;7771:108;;;2457:25:1;;;2445:2;2430:18;7771:108:0;2311:177:1;34870:38:0;;;;;;;;;;-1:-1:-1;34870:38:0;;;;;:::i;:::-;;:::i;34755:43::-;;;;;;;;;;-1:-1:-1;34755:43:0;;;;-1:-1:-1;;;;;34755:43:0;;;9783:261;;;;;;;;;;-1:-1:-1;9783:261:0;;;;;:::i;:::-;;:::i;36270:398::-;;;;;;;;;;-1:-1:-1;36270:398:0;;;;;:::i;:::-;;:::i;44846:238::-;;;;;;;;;;-1:-1:-1;44846:238:0;;;;;:::i;:::-;;:::i;7613:93::-;;;;;;;;;;-1:-1:-1;7696:2:0;7613:93;;;4215:4:1;4203:17;;;4185:36;;4173:2;4158:18;7613:93:0;4043:184:1;10453:238:0;;;;;;;;;;-1:-1:-1;10453:238:0;;;;;:::i;:::-;;:::i;43769:207::-;;;;;;;;;;-1:-1:-1;43769:207:0;;;;;:::i;:::-;;:::i;42928:106::-;;;;;;;;;;-1:-1:-1;42928:106:0;;;;;:::i;:::-;;:::i;41978:409::-;;;;;;;;;;-1:-1:-1;41978:409:0;;;;;:::i;:::-;;:::i;34915:53::-;;;;;;;;;;-1:-1:-1;34915:53:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;34541:28;;;;;;;;;;-1:-1:-1;34541:28:0;;;;-1:-1:-1;;;;;34541:28:0;;;44593:118;;;;;;;;;;-1:-1:-1;44593:118:0;;;;;:::i;:::-;;:::i;41490:480::-;;;;;;;;;;-1:-1:-1;41490:480:0;;;;;:::i;:::-;;:::i;44395:190::-;;;;;;;;;;-1:-1:-1;44395:190:0;;;;;:::i;:::-;;:::i;40432:574::-;;;;;;;;;;-1:-1:-1;40432:574:0;;;;;:::i;:::-;;:::i;34975:36::-;;;;;;;;;;-1:-1:-1;34975:36:0;;;;;:::i;:::-;;:::i;7942:127::-;;;;;;;;;;-1:-1:-1;7942:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;8043:18:0;8016:7;8043:18;;;;;;;;;;;;7942:127;19507:103;;;;;;;;;;;;;:::i;45092:::-;;;;;;;;;;-1:-1:-1;45092:103:0;;;;;:::i;:::-;;:::i;18866:87::-;;;;;;;;;;-1:-1:-1;18939:6:0;;-1:-1:-1;;;;;18939:6:0;18866:87;;43429:103;;;;;;;;;;-1:-1:-1;43429:103:0;;;;;:::i;:::-;;:::i;6861:104::-;;;;;;;;;;;;;:::i;43042:106::-;;;;;;;;;;-1:-1:-1;43042:106:0;;;;;:::i;:::-;;:::i;43984:174::-;;;;;;;;;;-1:-1:-1;43984:174:0;;;;;:::i;:::-;;:::i;34644:27::-;;;;;;;;;;-1:-1:-1;34644:27:0;;;;-1:-1:-1;;;34644:27:0;;;;;;;;;6343:10:1;6331:23;;;6313:42;;6301:2;6286:18;34644:27:0;6169:192:1;44723:115:0;;;;;;;;;;-1:-1:-1;44723:115:0;;;;;:::i;:::-;;:::i;11194:436::-;;;;;;;;;;-1:-1:-1;11194:436:0;;;;;:::i;:::-;;:::i;8275:193::-;;;;;;;;;;-1:-1:-1;8275:193:0;;;;;:::i;:::-;;:::i;42395:425::-;;;;;;;;;;-1:-1:-1;42395:425:0;;;;;:::i;:::-;;:::i;43205:216::-;;;;;;;;;;-1:-1:-1;43205:216:0;;;;;:::i;:::-;;:::i;34576:28::-;;;;;;;;;;-1:-1:-1;34576:28:0;;;;-1:-1:-1;;;;;34576:28:0;;;41014:468;;;;;;;;;;-1:-1:-1;41014:468:0;;;;;:::i;:::-;;:::i;34613:24::-;;;;;;;;;;-1:-1:-1;34613:24:0;;;;-1:-1:-1;;;34613:24:0;;;;;;8531:151;;;;;;;;;;-1:-1:-1;8531:151:0;;;;;:::i;:::-;;:::i;43540:221::-;;;;;;;;;;-1:-1:-1;43540:221:0;;;;;:::i;:::-;;:::i;19765:201::-;;;;;;;;;;-1:-1:-1;19765:201:0;;;;;:::i;:::-;;:::i;6642:100::-;6696:13;6729:5;6722:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6642:100;:::o;9002:201::-;9085:4;4364:10;9141:32;4364:10;9157:7;9166:6;9141:8;:32::i;:::-;9191:4;9184:11;;;9002:201;;;;;:::o;44170:217::-;18752:13;:11;:13::i;:::-;44278:46:::1;::::0;-1:-1:-1;;;44278:46:0;;44318:4:::1;44278:46;::::0;::::1;1762:51:1::0;44263:12:0::1;::::0;-1:-1:-1;;;;;44278:31:0;::::1;::::0;::::1;::::0;1735:18:1;;44278:46:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;44335:44;::::0;-1:-1:-1;;;44335:44:0;;-1:-1:-1;;;;;7792:32:1;;;44335:44:0::1;::::0;::::1;7774:51:1::0;7841:18;;;7834:34;;;44263:61:0;;-1:-1:-1;44335:30:0;;::::1;::::0;::::1;::::0;7747:18:1;;44335:44:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;44252:135;44170:217:::0;;:::o;34870:38::-;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;34870:38:0;;-1:-1:-1;34870:38:0;:::o;9783:261::-;9880:4;4364:10;9938:38;9954:4;4364:10;9969:6;9938:15;:38::i;:::-;9987:27;9997:4;10003:2;10007:6;9987:9;:27::i;:::-;-1:-1:-1;10032:4:0;;9783:261;-1:-1:-1;;;;9783:261:0:o;36270:398::-;18752:13;:11;:13::i;:::-;36427:16:::1;-1:-1:-1::0;;;;;36427:24:0::1;;:26;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;36409:70:0::1;;36488:4;36495:16;-1:-1:-1::0;;;;;36495:21:0::1;;:23;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;36409:110;::::0;-1:-1:-1;;;;;;36409:110:0::1;::::0;;;;;;-1:-1:-1;;;;;8615:15:1;;;36409:110:0::1;::::0;::::1;8597:34:1::0;8667:15;;8647:18;;;8640:43;8532:18;;36409:110:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;36393:13;:126:::0;;-1:-1:-1;;;;;;36393:126:0;;::::1;-1:-1:-1::0;;;;;36393:126:0;;::::1;;::::0;;;36583:15:::1;:34:::0;;;::::1;::::0;;::::1;::::0;;;::::1;::::0;;;36628:13:::1;:30:::0;;;;::::1;::::0;::::1;;::::0;;36270:398::o;44846:238::-;18752:13;:11;:13::i;:::-;-1:-1:-1;;;;;44939:35:0;::::1;44931:90;;;::::0;-1:-1:-1;;;44931:90:0;;8896:2:1;44931:90:0::1;::::0;::::1;8878:21:1::0;8935:2;8915:18;;;8908:30;8974:34;8954:18;;;8947:62;-1:-1:-1;;;9025:18:1;;;9018:40;9075:19;;44931:90:0::1;;;;;;;;;45032:20;:44:::0;;-1:-1:-1;;;;;;45032:44:0::1;-1:-1:-1::0;;;;;45032:44:0;;;::::1;::::0;;;::::1;::::0;;44846:238::o;10453:::-;10541:4;4364:10;10597:64;4364:10;10613:7;10650:10;10622:25;4364:10;10613:7;10622:9;:25::i;:::-;:38;;;;:::i;:::-;10597:8;:64::i;43769:207::-;18752:13;:11;:13::i;:::-;43862:19:::1;:42:::0;;-1:-1:-1;;43862:42:0::1;-1:-1:-1::0;;;;;43862:42:0;::::1;::::0;;::::1;::::0;;;43920:48:::1;::::0;9513:66:1;;;43920:48:0::1;::::0;9501:2:1;9486:18;43920:48:0::1;;;;;;;;43769:207:::0;:::o;42928:106::-;35679:11;;-1:-1:-1;;;;;35679:11:0;35665:10;:25;35657:62;;;;-1:-1:-1;;;35657:62:0;;9792:2:1;35657:62:0;;;9774:21:1;9831:2;9811:18;;;9804:30;-1:-1:-1;;;9850:18:1;;;9843:54;9914:18;;35657:62:0;9590:348:1;35657:62:0;43004:22:::1;43010:7;43019:6;43004:5;:22::i;:::-;42928:106:::0;;:::o;41978:409::-;18752:13;:11;:13::i;:::-;42060:9:::1;42055:325;42077:19;:26:::0;42073:30;::::1;42055:325;;;42154:5;-1:-1:-1::0;;;;;42128:31:0::1;:19;42148:1;42128:22;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;::::1;::::0;-1:-1:-1;;;;;42128:22:0::1;:31:::0;42125:244:::1;;42205:19;42225:26:::0;;:30:::1;::::0;42254:1:::1;::::0;42225:30:::1;:::i;:::-;42205:51;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;::::1;::::0;42180:19:::1;:22:::0;;-1:-1:-1;;;;;42205:51:0;;::::1;::::0;42200:1;;42180:22;::::1;;;;;:::i;:::-;;;;;;;;;:76;;;;;-1:-1:-1::0;;;;;42180:76:0::1;;;;;-1:-1:-1::0;;;;;42180:76:0::1;;;;;;42275:19;:25;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;;;-1:-1:-1;;42275:25:0;;;;;-1:-1:-1;;;;;;42275:25:0::1;::::0;;;;;;;;-1:-1:-1;;;;;42319:26:0;::::1;::::0;;:19:::1;:26:::0;;;;;:34;;-1:-1:-1;;42319:34:0::1;::::0;;42125:244:::1;42105:3:::0;::::1;::::0;::::1;:::i;:::-;;;;42055:325;;44593:118:::0;18752:13;:11;:13::i;:::-;44682:21:::1;::::0;-1:-1:-1;;;;;44682:12:0;::::1;::::0;:21;::::1;;;::::0;44695:7;;44682:21:::1;::::0;;;44695:7;44682:12;:21;::::1;;;;;;;;;;;;;::::0;::::1;;;;;;44593:118:::0;;:::o;41490:480::-;18752:13;:11;:13::i;:::-;41569:19:::1;41611:6:::0;41607:175:::1;41624:21;:28:::0;41621:31;::::1;41607:175;;;41705:8;-1:-1:-1::0;;;;;41677:36:0::1;:21;41699:1;41677:24;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;::::1;::::0;-1:-1:-1;;;;;41677:24:0::1;:36:::0;41674:97:::1;;41751:4;41734:21;;41674:97;41654:3:::0;::::1;::::0;::::1;:::i;:::-;;;;41607:175;;;;41801:14;41800:15;41792:74;;;::::0;-1:-1:-1;;;41792:74:0;;10682:2:1;41792:74:0::1;::::0;::::1;10664:21:1::0;10721:2;10701:18;;;10694:30;10760:34;10740:18;;;10733:62;-1:-1:-1;;;10811:18:1;;;10804:44;10865:19;;41792:74:0::1;10480:410:1::0;41792:74:0::1;-1:-1:-1::0;41877:21:0::1;:36:::0;;::::1;::::0;;::::1;::::0;;;;::::1;::::0;;-1:-1:-1;;;;;41877:36:0;;::::1;-1:-1:-1::0;;;;;;41877:36:0;;::::1;::::0;::::1;::::0;;-1:-1:-1;41924:31:0;;;:21:::1;41877:36;41924:31:::0;;;;;:38;;-1:-1:-1;;41924:38:0::1;::::0;;::::1;::::0;;41490:480::o;44395:190::-;18752:13;:11;:13::i;:::-;44549:28:::1;::::0;-1:-1:-1;;;44549:28:0;;-1:-1:-1;;;;;7792:32:1;;;44549:28:0::1;::::0;::::1;7774:51:1::0;7841:18;;;7834:34;;;44531:6:0;;44549:14;;::::1;::::0;::::1;::::0;7747:18:1;;44549:28:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;44480:105;44395:190:::0;;;:::o;40432:574::-;-1:-1:-1;;;;;40680:28:0;;40620:14;40680:28;;;:21;:28;;;;;;40662:4;;40680:28;;40677:75;;;-1:-1:-1;40735:5:0;40677:75;-1:-1:-1;;;;;40765:24:0;;;;;;:19;:24;;;;;;;;40762:71;;;-1:-1:-1;40816:5:0;40762:71;40847:7;40843:48;;40878:1;40871:8;;;;;40843:48;40910:88;40961:25;:21;;;40985:1;40961:25;:::i;:::-;40956:31;;:2;:31;:::i;:::-;40910:27;:7;:27;;;;;:11;:27;:::i;:::-;:31;;:88::i;:::-;40901:97;;40636:370;40432:574;;;;;;;;:::o;34975:36::-;;;;;;;;;;;;19507:103;18752:13;:11;:13::i;:::-;19572:30:::1;19599:1;19572:18;:30::i;:::-;19507:103::o:0;45092:::-;18752:13;:11;:13::i;:::-;45159::::1;:28:::0;;-1:-1:-1;;;;;;45159:28:0::1;-1:-1:-1::0;;;;;45159:28:0;;;::::1;::::0;;;::::1;::::0;;45092:103::o;43429:::-;18752:13;:11;:13::i;:::-;43498:11:::1;:26:::0;;-1:-1:-1;;;;;;43498:26:0::1;-1:-1:-1::0;;;;;43498:26:0;;;::::1;::::0;;;::::1;::::0;;43429:103::o;6861:104::-;6917:13;6950:7;6943:14;;;;;:::i;43042:106::-;35679:11;;-1:-1:-1;;;;;35679:11:0;35665:10;:25;35657:62;;;;-1:-1:-1;;;35657:62:0;;9792:2:1;35657:62:0;;;9774:21:1;9831:2;9811:18;;;9804:30;-1:-1:-1;;;9850:18:1;;;9843:54;9914:18;;35657:62:0;9590:348:1;35657:62:0;43118:22:::1;43124:7;43133:6;43118:5;:22::i;43984:174::-:0;18752:13;:11;:13::i;:::-;44064:21:::1;:32:::0;;;::::1;;-1:-1:-1::0;;;44064:32:0::1;-1:-1:-1::0;;;;44064:32:0;;::::1;;::::0;;44112:38:::1;::::0;::::1;::::0;::::1;::::0;44088:8;1188:14:1;1181:22;1163:41;;1151:2;1136:18;;1023:187;44723:115:0;18752:13;:11;:13::i;:::-;44795:35:::1;::::0;-1:-1:-1;;;;;44795:12:0;::::1;::::0;44808:21:::1;44795:35:::0;::::1;;;::::0;::::1;::::0;;;44808:21;44795:12;:35;::::1;;;;;;;;;;;;;::::0;::::1;;;;11194:436:::0;11287:4;4364:10;11287:4;11370:25;4364:10;11387:7;11370:9;:25::i;:::-;11343:52;;11434:15;11414:16;:35;;11406:85;;;;-1:-1:-1;;;11406:85:0;;12750:2:1;11406:85:0;;;12732:21:1;12789:2;12769:18;;;12762:30;12828:34;12808:18;;;12801:62;-1:-1:-1;;;12879:18:1;;;12872:35;12924:19;;11406:85:0;12548:401:1;11406:85:0;11527:60;11536:5;11543:7;11571:15;11552:16;:34;11527:8;:60::i;8275:193::-;8354:4;4364:10;8410:28;4364:10;8427:2;8431:6;8410:9;:28::i;42395:425::-;18752:13;:11;:13::i;:::-;42479:9:::1;42474:339;42496:21;:28:::0;42492:32;::::1;42474:339;;;42577:5;-1:-1:-1::0;;;;;42549:33:0::1;:21;42571:1;42549:24;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;::::1;::::0;-1:-1:-1;;;;;42549:24:0::1;:33:::0;42546:256:::1;;42630:21;42652:28:::0;;:32:::1;::::0;42683:1:::1;::::0;42652:32:::1;:::i;:::-;42630:55;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;::::1;::::0;42603:21:::1;:24:::0;;-1:-1:-1;;;;;42630:55:0;;::::1;::::0;42625:1;;42603:24;::::1;;;;;:::i;:::-;;;;;;;;;:82;;;;;-1:-1:-1::0;;;;;42603:82:0::1;;;;;-1:-1:-1::0;;;;;42603:82:0::1;;;;;;42704:21;:27;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;;;-1:-1:-1;;42704:27:0;;;;;-1:-1:-1;;;;;;42704:27:0::1;::::0;;;;;;;;-1:-1:-1;;;;;42750:28:0;::::1;::::0;;:21:::1;:28:::0;;;;;:36;;-1:-1:-1;;42750:36:0::1;::::0;;42546:256:::1;42526:3:::0;::::1;::::0;::::1;:::i;:::-;;;;42474:339;;43205:216:::0;18752:13;:11;:13::i;:::-;43276::::1;:30:::0;;-1:-1:-1;;;;;43276:30:0;::::1;-1:-1:-1::0;;;;;;43276:30:0;;::::1;::::0;::::1;::::0;;;43317:15:::1;:51:::0;;;;::::1;::::0;::::1;::::0;;43384:29:::1;::::0;1762:51:1;;;43384:29:0::1;::::0;1750:2:1;1735:18;43384:29:0::1;1616:203:1::0;41014:468:0;18752:13;:11;:13::i;:::-;41091:19:::1;41133:6:::0;41129:171:::1;41146:19;:26:::0;41143:29;::::1;41129:171;;;41223:8;-1:-1:-1::0;;;;;41197:34:0::1;:19;41217:1;41197:22;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;::::1;::::0;-1:-1:-1;;;;;41197:22:0::1;:34:::0;41194:95:::1;;41269:4;41252:21;;41194:95;41174:3:::0;::::1;::::0;::::1;:::i;:::-;;;;41129:171;;;;41319:14;41318:15;41310:72;;;::::0;-1:-1:-1;;;41310:72:0;;13156:2:1;41310:72:0::1;::::0;::::1;13138:21:1::0;13195:2;13175:18;;;13168:30;13234:34;13214:18;;;13207:62;-1:-1:-1;;;13285:18:1;;;13278:42;13337:19;;41310:72:0::1;12954:408:1::0;41310:72:0::1;-1:-1:-1::0;41393:19:0::1;:34:::0;;::::1;::::0;;::::1;::::0;;;;::::1;::::0;;-1:-1:-1;;;;;41393:34:0;;::::1;-1:-1:-1::0;;;;;;41393:34:0;;::::1;::::0;::::1;::::0;;-1:-1:-1;41438:29:0;;;:19:::1;41393:34;41438:29:::0;;;;;:36;;-1:-1:-1;;41438:36:0::1;::::0;;::::1;::::0;;41014:468::o;8531:151::-;-1:-1:-1;;;;;8647:18:0;;;8620:7;8647:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;8531:151::o;43540:221::-;18752:13;:11;:13::i;:::-;43630:11:::1;:26:::0;;-1:-1:-1;;;;43667:30:0;-1:-1:-1;;;43630:26:0::1;::::0;::::1;::::0;;::::1;-1:-1:-1::0;;;;43667:30:0;;;;;-1:-1:-1;;;43667:30:0::1;::::0;::::1;::::0;;::::1;::::0;;;::::1;::::0;;;43713:40:::1;::::0;;13535:36:1;;;13602:2;13587:18;;13580:51;;;;43713:40:0::1;::::0;13508:18:1;43713:40:0::1;;;;;;;43540:221:::0;;:::o;19765:201::-;18752:13;:11;:13::i;:::-;-1:-1:-1;;;;;19854:22:0;::::1;19846:73;;;::::0;-1:-1:-1;;;19846:73:0;;13844:2:1;19846:73:0::1;::::0;::::1;13826:21:1::0;13883:2;13863:18;;;13856:30;13922:34;13902:18;;;13895:62;-1:-1:-1;;;13973:18:1;;;13966:36;14019:19;;19846:73:0::1;13642:402:1::0;19846:73:0::1;19930:28;19949:8;19930:18;:28::i;:::-;19765:201:::0;:::o;15187:346::-;-1:-1:-1;;;;;15289:19:0;;15281:68;;;;-1:-1:-1;;;15281:68:0;;14251:2:1;15281:68:0;;;14233:21:1;14290:2;14270:18;;;14263:30;14329:34;14309:18;;;14302:62;-1:-1:-1;;;14380:18:1;;;14373:34;14424:19;;15281:68:0;14049:400:1;15281:68:0;-1:-1:-1;;;;;15368:21:0;;15360:68;;;;-1:-1:-1;;;15360:68:0;;14656:2:1;15360:68:0;;;14638:21:1;14695:2;14675:18;;;14668:30;14734:34;14714:18;;;14707:62;-1:-1:-1;;;14785:18:1;;;14778:32;14827:19;;15360:68:0;14454:398:1;15360:68:0;-1:-1:-1;;;;;15441:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;15493:32;;2457:25:1;;;15493:32:0;;2430:18:1;15493:32:0;;;;;;;15187:346;;;:::o;19031:132::-;18939:6;;-1:-1:-1;;;;;18939:6:0;4364:10;19095:23;19087:68;;;;-1:-1:-1;;;19087:68:0;;15059:2:1;19087:68:0;;;15041:21:1;;;15078:18;;;15071:30;15137:34;15117:18;;;15110:62;15189:18;;19087:68:0;14857:356:1;15824:419:0;15925:24;15952:25;15962:5;15969:7;15952:9;:25::i;:::-;15925:52;;-1:-1:-1;;15992:16:0;:37;15988:248;;16074:6;16054:16;:26;;16046:68;;;;-1:-1:-1;;;16046:68:0;;15420:2:1;16046:68:0;;;15402:21:1;15459:2;15439:18;;;15432:30;15498:31;15478:18;;;15471:59;15547:18;;16046:68:0;15218:353:1;16046:68:0;16158:51;16167:5;16174:7;16202:6;16183:16;:25;16158:8;:51::i;36822:1481::-;37277:4;37228:28;8043:18;;;;;;;;;;;37345:19;;-1:-1:-1;;;;;37345:19:0;37321:43;;;;;;;37393:53;;-1:-1:-1;37430:16:0;;-1:-1:-1;;;37430:16:0;;;;37429:17;37393:53;:97;;;;-1:-1:-1;37477:13:0;;-1:-1:-1;;;;;37477:13:0;37463:10;:27;;37393:97;:135;;;;-1:-1:-1;37507:21:0;;-1:-1:-1;;;37507:21:0;;;;37393:135;37375:228;;;37555:36;37570:20;37555:14;:36::i;:::-;37751:11;;37675:20;;37698:139;;37730:6;;-1:-1:-1;;;37751:11:0;;;;;-1:-1:-1;;;37777:13:0;;;;37805:4;37824:2;37698:17;:139::i;:::-;37675:162;-1:-1:-1;37994:24:0;38021;:6;37675:162;38021:10;:24::i;:::-;37994:51;-1:-1:-1;38061:16:0;;38058:184;;38094:57;38110:4;38124;38131:19;:12;38148:1;38131:16;:19::i;:::-;38094:15;:57::i;:::-;38188:20;;38166:64;;38182:4;;-1:-1:-1;;;;;38188:20:0;38210:19;:12;38227:1;38210:16;:19::i;38166:64::-;38252:43;38268:4;38274:2;38278:16;38252:15;:43::i;:::-;36935:1368;;;;36822:1481;;;:::o;13193:548::-;-1:-1:-1;;;;;13277:21:0;;13269:65;;;;-1:-1:-1;;;13269:65:0;;15778:2:1;13269:65:0;;;15760:21:1;15817:2;15797:18;;;15790:30;15856:33;15836:18;;;15829:61;15907:18;;13269:65:0;15576:355:1;13269:65:0;13425:6;13409:12;;:22;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;;;13580:18:0;;:9;:18;;;;;;;;;;;:28;;;;;;13635:37;2457:25:1;;;13635:37:0;;2430:18:1;13635:37:0;;;;;;;42928:106;;:::o;23936:98::-;23994:7;24021:5;24025:1;24021;:5;:::i;:::-;24014:12;23936:98;-1:-1:-1;;;23936:98:0:o;24335:::-;24393:7;24420:5;24424:1;24420;:5;:::i;20126:191::-;20219:6;;;-1:-1:-1;;;;;20236:17:0;;;-1:-1:-1;;;;;;20236:17:0;;;;;;;20269:40;;20219:6;;;20236:17;20219:6;;20269:40;;20200:16;;20269:40;20189:128;20126:191;:::o;14074:675::-;-1:-1:-1;;;;;14158:21:0;;14150:67;;;;-1:-1:-1;;;14150:67:0;;16533:2:1;14150:67:0;;;16515:21:1;16572:2;16552:18;;;16545:30;16611:34;16591:18;;;16584:62;-1:-1:-1;;;16662:18:1;;;16655:31;16703:19;;14150:67:0;16331:397:1;14150:67:0;-1:-1:-1;;;;;14317:18:0;;14292:22;14317:18;;;;;;;;;;;14354:24;;;;14346:71;;;;-1:-1:-1;;;14346:71:0;;16935:2:1;14346:71:0;;;16917:21:1;16974:2;16954:18;;;16947:30;17013:34;16993:18;;;16986:62;-1:-1:-1;;;17064:18:1;;;17057:32;17106:19;;14346:71:0;16733:398:1;14346:71:0;-1:-1:-1;;;;;14453:18:0;;:9;:18;;;;;;;;;;;14474:23;;;14453:44;;14592:12;:22;;;;;;;14643:37;2457:25:1;;;14453:9:0;;:18;14643:37;;2430:18:1;14643:37:0;;;;;;;44682:21:::1;44593:118:::0;;:::o;38311:985::-;35538:16;:23;;-1:-1:-1;;;;35538:23:0;-1:-1:-1;;;35538:23:0;;;;38462:27:::1;:20:::0;38487:1:::1;38462:24;:27::i;:::-;38447:42:::0;-1:-1:-1;38500:17:0::1;38520:30;:20:::0;38447:42;38520:24:::1;:30::i;:::-;38500:50:::0;-1:-1:-1;38853:21:0::1;38919:22;38936:4:::0;38919:16:::1;:22::i;:::-;39076:18;39097:41;:21;39123:14:::0;39097:25:::1;:41::i;:::-;39076:62;;39192:35;39205:9;39216:10;39192:12;:35::i;:::-;39245:43;::::0;;17338:25:1;;;17394:2;17379:18;;17372:34;;;17422:18;;;17415:34;;;39245:43:0::1;::::0;17326:2:1;17311:18;39245:43:0::1;;;;;;;-1:-1:-1::0;;35584:16:0;:24;;-1:-1:-1;;;;35584:24:0;;;-1:-1:-1;;;38311:985:0:o;23579:98::-;23637:7;23664:5;23668:1;23664;:5;:::i;12100:806::-;-1:-1:-1;;;;;12197:18:0;;12189:68;;;;-1:-1:-1;;;12189:68:0;;17662:2:1;12189:68:0;;;17644:21:1;17701:2;17681:18;;;17674:30;17740:34;17720:18;;;17713:62;-1:-1:-1;;;17791:18:1;;;17784:35;17836:19;;12189:68:0;17460:401:1;12189:68:0;-1:-1:-1;;;;;12276:16:0;;12268:64;;;;-1:-1:-1;;;12268:64:0;;18068:2:1;12268:64:0;;;18050:21:1;18107:2;18087:18;;;18080:30;18146:34;18126:18;;;18119:62;-1:-1:-1;;;18197:18:1;;;18190:33;18240:19;;12268:64:0;17866:399:1;12268:64:0;-1:-1:-1;;;;;12418:15:0;;12396:19;12418:15;;;;;;;;;;;12452:21;;;;12444:72;;;;-1:-1:-1;;;12444:72:0;;18472:2:1;12444:72:0;;;18454:21:1;18511:2;18491:18;;;18484:30;18550:34;18530:18;;;18523:62;-1:-1:-1;;;18601:18:1;;;18594:36;18647:19;;12444:72:0;18270:402:1;12444:72:0;-1:-1:-1;;;;;12552:15:0;;;:9;:15;;;;;;;;;;;12570:20;;;12552:38;;12770:13;;;;;;;;;;:23;;;;;;12822:26;;2457:25:1;;;12770:13:0;;12822:26;;2430:18:1;12822:26:0;;;;;;;12861:37;44593:118;39304:593;39458:16;;;39472:1;39458:16;;;;;;;;39434:21;;39458:16;;;;;;;;;;-1:-1:-1;39458:16:0;39434:40;;39503:4;39485;39490:1;39485:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;39485:23:0;;;:7;;;;;;;;;;:23;;;;39529:15;;:22;;;-1:-1:-1;;;39529:22:0;;;;:15;;;;;:20;;:22;;;;;39485:7;;39529:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;39519:4;39524:1;39519:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;39519:32:0;;;:7;;;;;;;;;:32;39596:15;;39564:62;;39581:4;;39596:15;39614:11;39564:8;:62::i;:::-;39665:15;;:224;;-1:-1:-1;;;39665:224:0;;-1:-1:-1;;;;;39665:15:0;;;;:66;;:224;;39746:11;;39665:15;;39816:4;;39843;;39863:15;;39665:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;39359:538;39304:593;:::o;39905:519::-;40085:15;;40053:62;;40070:4;;-1:-1:-1;;;;;40085:15:0;40103:11;40053:8;:62::i;:::-;40158:15;;:258;;-1:-1:-1;;;40158:258:0;;40230:4;40158:258;;;20135:34:1;;;20185:18;;;20178:34;;;40158:15:0;20228:18:1;;;20221:34;;;20271:18;;;20264:34;20314:19;;;20307:44;40390:15:0;20367:19:1;;;20360:35;-1:-1:-1;;;;;40158:15:0;;;;:31;;40197:9;;20069:19:1;;40158:258:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;14:548:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;298:3;483:1;478:2;469:6;458:9;454:22;450:31;443:42;553:2;546;542:7;537:2;529:6;525:15;521:29;510:9;506:45;502:54;494:62;;;;14:548;;;;:::o;567:131::-;-1:-1:-1;;;;;642:31:1;;632:42;;622:70;;688:1;685;678:12;703:315;771:6;779;832:2;820:9;811:7;807:23;803:32;800:52;;;848:1;845;838:12;800:52;887:9;874:23;906:31;931:5;906:31;:::i;:::-;956:5;1008:2;993:18;;;;980:32;;-1:-1:-1;;;703:315:1:o;1215:396::-;1291:6;1299;1352:2;1340:9;1331:7;1327:23;1323:32;1320:52;;;1368:1;1365;1358:12;1320:52;1407:9;1394:23;1426:31;1451:5;1426:31;:::i;:::-;1476:5;-1:-1:-1;1533:2:1;1518:18;;1505:32;1546:33;1505:32;1546:33;:::i;:::-;1598:7;1588:17;;;1215:396;;;;;:::o;1824:247::-;1883:6;1936:2;1924:9;1915:7;1911:23;1907:32;1904:52;;;1952:1;1949;1942:12;1904:52;1991:9;1978:23;2010:31;2035:5;2010:31;:::i;2493:180::-;2552:6;2605:2;2593:9;2584:7;2580:23;2576:32;2573:52;;;2621:1;2618;2611:12;2573:52;-1:-1:-1;2644:23:1;;2493:180;-1:-1:-1;2493:180:1:o;2902:456::-;2979:6;2987;2995;3048:2;3036:9;3027:7;3023:23;3019:32;3016:52;;;3064:1;3061;3054:12;3016:52;3103:9;3090:23;3122:31;3147:5;3122:31;:::i;:::-;3172:5;-1:-1:-1;3229:2:1;3214:18;;3201:32;3242:33;3201:32;3242:33;:::i;:::-;2902:456;;3294:7;;-1:-1:-1;;;3348:2:1;3333:18;;;;3320:32;;2902:456::o;4232:301::-;4291:6;4344:2;4332:9;4323:7;4319:23;4315:32;4312:52;;;4360:1;4357;4350:12;4312:52;4399:9;4386:23;-1:-1:-1;;;;;4442:5:1;4438:46;4431:5;4428:57;4418:85;;4499:1;4496;4489:12;4866:156;4932:20;;4992:4;4981:16;;4971:27;;4961:55;;5012:1;5009;5002:12;4961:55;4866:156;;;:::o;5027:163::-;5094:20;;5154:10;5143:22;;5133:33;;5123:61;;5180:1;5177;5170:12;5195:600;5287:6;5295;5303;5311;5319;5372:3;5360:9;5351:7;5347:23;5343:33;5340:53;;;5389:1;5386;5379:12;5340:53;5425:9;5412:23;5402:33;;5454:36;5486:2;5475:9;5471:18;5454:36;:::i;:::-;5444:46;;5509:37;5542:2;5531:9;5527:18;5509:37;:::i;:::-;5499:47;;5596:2;5585:9;5581:18;5568:32;5609:31;5634:5;5609:31;:::i;:::-;5659:5;-1:-1:-1;5716:3:1;5701:19;;5688:33;5730;5688;5730;:::i;:::-;5782:7;5772:17;;;5195:600;;;;;;;;:::o;5800:118::-;5886:5;5879:13;5872:21;5865:5;5862:32;5852:60;;5908:1;5905;5898:12;5923:241;5979:6;6032:2;6020:9;6011:7;6007:23;6003:32;6000:52;;;6048:1;6045;6038:12;6000:52;6087:9;6074:23;6106:28;6128:5;6106:28;:::i;6759:254::-;6824:6;6832;6885:2;6873:9;6864:7;6860:23;6856:32;6853:52;;;6901:1;6898;6891:12;6853:52;6924:27;6941:9;6924:27;:::i;:::-;6914:37;;6970;7003:2;6992:9;6988:18;6970:37;:::i;:::-;6960:47;;6759:254;;;;;:::o;7018:380::-;7097:1;7093:12;;;;7140;;;7161:61;;7215:4;7207:6;7203:17;7193:27;;7161:61;7268:2;7260:6;7257:14;7237:18;7234:38;7231:161;;7314:10;7309:3;7305:20;7302:1;7295:31;7349:4;7346:1;7339:15;7377:4;7374:1;7367:15;7231:161;;7018:380;;;:::o;7403:184::-;7473:6;7526:2;7514:9;7505:7;7501:23;7497:32;7494:52;;;7542:1;7539;7532:12;7494:52;-1:-1:-1;7565:16:1;;7403:184;-1:-1:-1;7403:184:1:o;7879:245::-;7946:6;7999:2;7987:9;7978:7;7974:23;7970:32;7967:52;;;8015:1;8012;8005:12;7967:52;8047:9;8041:16;8066:28;8088:5;8066:28;:::i;8129:251::-;8199:6;8252:2;8240:9;8231:7;8227:23;8223:32;8220:52;;;8268:1;8265;8258:12;8220:52;8300:9;8294:16;8319:31;8344:5;8319:31;:::i;9105:127::-;9166:10;9161:3;9157:20;9154:1;9147:31;9197:4;9194:1;9187:15;9221:4;9218:1;9211:15;9237:125;9302:9;;;9323:10;;;9320:36;;;9336:18;;:::i;9943:127::-;10004:10;9999:3;9995:20;9992:1;9985:31;10035:4;10032:1;10025:15;10059:4;10056:1;10049:15;10075:128;10142:9;;;10163:11;;;10160:37;;;10177:18;;:::i;10208:127::-;10269:10;10264:3;10260:20;10257:1;10250:31;10300:4;10297:1;10290:15;10324:4;10321:1;10314:15;10340:135;10379:3;10400:17;;;10397:43;;10420:18;;:::i;:::-;-1:-1:-1;10467:1:1;10456:13;;10340:135::o;11174:422::-;11263:1;11306:5;11263:1;11320:270;11341:7;11331:8;11328:21;11320:270;;;11400:4;11396:1;11392:6;11388:17;11382:4;11379:27;11376:53;;;11409:18;;:::i;:::-;11459:7;11449:8;11445:22;11442:55;;;11479:16;;;;11442:55;11558:22;;;;11518:15;;;;11320:270;;;11324:3;11174:422;;;;;:::o;11601:806::-;11650:5;11680:8;11670:80;;-1:-1:-1;11721:1:1;11735:5;;11670:80;11769:4;11759:76;;-1:-1:-1;11806:1:1;11820:5;;11759:76;11851:4;11869:1;11864:59;;;;11937:1;11932:130;;;;11844:218;;11864:59;11894:1;11885:10;;11908:5;;;11932:130;11969:3;11959:8;11956:17;11953:43;;;11976:18;;:::i;:::-;-1:-1:-1;;12032:1:1;12018:16;;12047:5;;11844:218;;12146:2;12136:8;12133:16;12127:3;12121:4;12118:13;12114:36;12108:2;12098:8;12095:16;12090:2;12084:4;12081:12;12077:35;12074:77;12071:159;;;-1:-1:-1;12183:19:1;;;12215:5;;12071:159;12262:34;12287:8;12281:4;12262:34;:::i;:::-;12332:6;12328:1;12324:6;12320:19;12311:7;12308:32;12305:58;;;12343:18;;:::i;:::-;12381:20;;11601:806;-1:-1:-1;;;11601:806:1:o;12412:131::-;12472:5;12501:36;12528:8;12522:4;12501:36;:::i;15936:168::-;16009:9;;;16040;;16057:15;;;16051:22;;16037:37;16027:71;;16078:18;;:::i;16109:217::-;16149:1;16175;16165:132;;16219:10;16214:3;16210:20;16207:1;16200:31;16254:4;16251:1;16244:15;16282:4;16279:1;16272:15;16165:132;-1:-1:-1;16311:9:1;;16109:217::o;18809:980::-;19071:4;19119:3;19108:9;19104:19;19150:6;19139:9;19132:25;19176:2;19214:6;19209:2;19198:9;19194:18;19187:34;19257:3;19252:2;19241:9;19237:18;19230:31;19281:6;19316;19310:13;19347:6;19339;19332:22;19385:3;19374:9;19370:19;19363:26;;19424:2;19416:6;19412:15;19398:29;;19445:1;19455:195;19469:6;19466:1;19463:13;19455:195;;;19534:13;;-1:-1:-1;;;;;19530:39:1;19518:52;;19625:15;;;;19590:12;;;;19566:1;19484:9;19455:195;;;-1:-1:-1;;;;;;;19706:32:1;;;;19701:2;19686:18;;19679:60;-1:-1:-1;;;19770:3:1;19755:19;19748:35;19667:3;18809:980;-1:-1:-1;;;18809:980:1:o;20406:306::-;20494:6;20502;20510;20563:2;20551:9;20542:7;20538:23;20534:32;20531:52;;;20579:1;20576;20569:12;20531:52;20608:9;20602:16;20592:26;;20658:2;20647:9;20643:18;20637:25;20627:35;;20702:2;20691:9;20687:18;20681:25;20671:35;;20406:306;;;;;:::o

Swarm Source

ipfs://9b955cb7fb2424400121316ff639839571efceb0476208f8106660b9e0fc1c08
Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.