ETH Price: $3,338.72 (-0.10%)
Gas: 6.99 Gwei
 

Overview

Max Total Supply

100,000,000,000,000 PEDS

Holders

49

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 9 Decimals)

Filtered by Token Holder
Uniswap V2: PEDS
Balance
152,672,984,921.360029402 PEDS

Value
$0.00
0xd0bfc3e69a35e22c6adc3fa9371add5e9950d6be
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:
PEDS

Compiler Version
v0.8.9+commit.e5eed63a

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-07-22
*/

/**
// TG: t.me/PepeHeads
*/

/**
// SPDX-License-Identifier: NONE
*/

pragma solidity 0.8.9;
 
abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }
 
    function _msgData() internal view virtual returns (bytes calldata) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}
 
interface IUniswapV2Pair {
    event Approval(address indexed owner, address indexed spender, uint value);
    event Transfer(address indexed from, address indexed to, uint value);
 
    function name() external pure returns (string memory);
    function symbol() external pure returns (string memory);
    function decimals() external pure returns (uint8);
    function totalSupply() external view returns (uint);
    function balanceOf(address owner) external view returns (uint);
    function allowance(address owner, address spender) external view returns (uint);
 
    function approve(address spender, uint value) external returns (bool);
    function transfer(address to, uint value) external returns (bool);
    function transferFrom(address from, address to, uint value) external returns (bool);
 
    function DOMAIN_SEPARATOR() external view returns (bytes32);
    function PERMIT_TYPEHASH() external pure returns (bytes32);
    function nonces(address owner) external view returns (uint);
 
    function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external;
 
    event Mint(address indexed sender, uint amount0, uint amount1);
    event Swap(
        address indexed sender,
        uint amount0In,
        uint amount1In,
        uint amount0Out,
        uint amount1Out,
        address indexed to
    );
    event Sync(uint112 reserve0, uint112 reserve1);
 
    function MINIMUM_LIQUIDITY() external pure returns (uint);
    function factory() external view returns (address);
    function token0() external view returns (address);
    function token1() external view returns (address);
    function getReserves() external view returns (uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast);
    function price0CumulativeLast() external view returns (uint);
    function price1CumulativeLast() external view returns (uint);
    function kLast() external view returns (uint);
 
    function mint(address to) external returns (uint liquidity);
    function burn(address to) external returns (uint amount0, uint amount1);
    function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data) external;
    function skim(address to) external;
    function sync() external;
 
    function initialize(address, address) external;
}
 
interface IUniswapV2Factory {
    event PairCreated(address indexed token0, address indexed token1, address pair, uint);
 
    function feeTo() external view returns (address);
    function feeToSetter() external view returns (address);
 
    function getPair(address tokenA, address tokenB) external view returns (address pair);
    function allPairs(uint) external view returns (address pair);
    function allPairsLength() external view returns (uint);
 
    function createPair(address tokenA, address tokenB) external returns (address pair);
 
    function setFeeTo(address) external;
    function setFeeToSetter(address) external;
}
 
interface IERC20 {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);
 
    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);
 
    /**
     * @dev Moves `amount` tokens from the caller's account to `recipient`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address recipient, uint256 amount) external returns (bool);
 
    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(address owner, address spender) external view returns (uint256);
 
    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);
 
    /**
     * @dev Moves `amount` tokens from `sender` to `recipient` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);
 
    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);
 
    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(address indexed owner, address indexed spender, uint256 value);
}
 
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);
}
 
 
contract ERC20 is Context, IERC20, IERC20Metadata {
    using SafeMath for uint256;
 
    mapping(address => uint256) private _balances;
 
    mapping(address => mapping(address => uint256)) private _allowances;
 
    uint256 private _totalSupply;
 
    string private _name;
    string private _symbol;
 
    /**
     * @dev Sets the values for {name} and {symbol}.
     *
     * The default value of {decimals} is 18. To select a different value for
     * {decimals} you should overload it.
     *
     * All two of these values are immutable: they can only be set once during
     * construction.
     */
    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }
 
    /**
     * @dev Returns the name of the token.
     */
    function name() public view virtual override returns (string memory) {
        return _name;
    }
 
    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view virtual override returns (string memory) {
        return _symbol;
    }
 
    /**
     * @dev Returns the number of decimals used to get its user representation.
     * For example, if `decimals` equals `2`, a balance of `505` tokens should
     * be displayed to a user as `5,05` (`505 / 10 ** 2`).
     *
     * Tokens usually opt for a value of 18, imitating the relationship between
     * Ether and Wei. This is the value {ERC20} uses, unless this function is
     * overridden;
     *
     * NOTE: This information is only used for _display_ purposes: it in
     * no way affects any of the arithmetic of the contract, including
     * {IERC20-balanceOf} and {IERC20-transfer}.
     */
    function decimals() public view virtual override returns (uint8) {
        return 9;
    }
 
    /**
     * @dev See {IERC20-totalSupply}.
     */
    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;
    }
 
    /**
     * @dev See {IERC20-balanceOf}.
     */
    function balanceOf(address account) public view virtual override returns (uint256) {
        return _balances[account];
    }
 
    /**
     * @dev See {IERC20-transfer}.
     *
     * Requirements:
     *
     * - `recipient` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }
 
    /**
     * @dev See {IERC20-allowance}.
     */
    function allowance(address owner, address spender) public view virtual override returns (uint256) {
        return _allowances[owner][spender];
    }
 
    /**
     * @dev See {IERC20-approve}.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }
 
    /**
     * @dev See {IERC20-transferFrom}.
     *
     * Emits an {Approval} event indicating the updated allowance. This is not
     * required by the EIP. See the note at the beginning of {ERC20}.
     *
     * Requirements:
     *
     * - `sender` and `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     * - the caller must have allowance for ``sender``'s tokens of at least
     * `amount`.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance"));
        return true;
    }
 
    /**
     * @dev Atomically increases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(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) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "ERC20: decreased allowance below zero"));
        return true;
    }
 
    /**
     * @dev Moves tokens `amount` from `sender` to `recipient`.
     *
     * This is internal function is equivalent to {transfer}, and can be used to
     * e.g. implement automatic token fees, slashing mechanisms, etc.
     *
     * Emits a {Transfer} event.
     *
     * Requirements:
     *
     * - `sender` cannot be the zero address.
     * - `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     */
    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");
 
        _beforeTokenTransfer(sender, recipient, amount);
 
        _balances[sender] = _balances[sender].sub(amount, "ERC20: transfer amount exceeds balance");
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
    }
 
    /** @dev Creates `amount` tokens and assigns them to `account`, increasing
     * the total supply.
     *
     * Emits a {Transfer} event with `from` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     */
    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");
 
        _beforeTokenTransfer(address(0), account, amount);
 
        _totalSupply = _totalSupply.add(amount);
        _balances[account] = _balances[account].add(amount);
        emit Transfer(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);
 
        _balances[account] = _balances[account].sub(amount, "ERC20: burn amount exceeds balance");
        _totalSupply = _totalSupply.sub(amount);
        emit Transfer(account, address(0), amount);
    }
 
    /**
     * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
     *
     * This internal function is equivalent to `approve`, and can be used to
     * e.g. set automatic allowances for certain subsystems, etc.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `owner` cannot be the zero address.
     * - `spender` cannot be the zero address.
     */
    function _approve(
        address owner,
        address spender,
        uint256 amount
    ) internal virtual {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");
 
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }
 
    /**
     * @dev Hook that is called before any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * will be to 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 {}
}
 
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");
 
        return c;
    }
 
    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }
 
    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;
 
        return c;
    }
 
    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     *
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) {
            return 0;
        }
 
        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");
 
        return c;
    }
 
    /**
     * @dev Returns the integer division of two unsigned integers. Reverts on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }
 
    /**
     * @dev Returns the integer division of two unsigned integers. Reverts with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold
 
        return c;
    }
 
    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return mod(a, b, "SafeMath: modulo by zero");
    }
 
    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts with custom message when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }
}
 
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 () {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }
 
    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view returns (address) {
        return _owner;
    }
 
    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(_owner == _msgSender(), "Ownable: caller is not the owner");
        _;
    }
 
    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }
 

}
 
 
 
library SafeMathInt {
    int256 private constant MIN_INT256 = int256(1) << 255;
    int256 private constant MAX_INT256 = ~(int256(1) << 255);
 
    /**
     * @dev Multiplies two int256 variables and fails on overflow.
     */
    function mul(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a * b;
 
        // Detect overflow when multiplying MIN_INT256 with -1
        require(c != MIN_INT256 || (a & MIN_INT256) != (b & MIN_INT256));
        require((b == 0) || (c / b == a));
        return c;
    }
 
    /**
     * @dev Division of two int256 variables and fails on overflow.
     */
    function div(int256 a, int256 b) internal pure returns (int256) {
        // Prevent overflow when dividing MIN_INT256 by -1
        require(b != -1 || a != MIN_INT256);
 
        // Solidity already throws when dividing by 0.
        return a / b;
    }
 
    /**
     * @dev Subtracts two int256 variables and fails on overflow.
     */
    function sub(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a - b;
        require((b >= 0 && c <= a) || (b < 0 && c > a));
        return c;
    }
 
    /**
     * @dev Adds two int256 variables and fails on overflow.
     */
    function add(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a + b;
        require((b >= 0 && c >= a) || (b < 0 && c < a));
        return c;
    }
 
    /**
     * @dev Converts to absolute value, and fails on overflow.
     */
    function abs(int256 a) internal pure returns (int256) {
        require(a != MIN_INT256);
        return a < 0 ? -a : a;
    }
 
 
    function toUint256Safe(int256 a) internal pure returns (uint256) {
        require(a >= 0);
        return uint256(a);
    }
}
 
library SafeMathUint {
  function toInt256Safe(uint256 a) internal pure returns (int256) {
    int256 b = int256(a);
    require(b >= 0);
    return b;
  }
}
 
 
interface IUniswapV2Router01 {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
 
    function addLiquidity(
        address tokenA,
        address tokenB,
        uint amountADesired,
        uint amountBDesired,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB, uint liquidity);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETH(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountToken, uint amountETH);
    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETHWithPermit(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountToken, uint amountETH);
    function swapExactTokensForTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapTokensForExactTokens(
        uint amountOut,
        uint amountInMax,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);
    function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);
 
    function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB);
    function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut);
    function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn);
    function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts);
    function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts);
}
 
interface IUniswapV2Router02 is IUniswapV2Router01 {
    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountETH);
    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountETH);
 
    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable;
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
}
 
contract PEDS is ERC20, Ownable {
    using SafeMath for uint256;
 
    IUniswapV2Router02 public immutable uniswapV2Router;
    address public immutable uniswapV2Pair;
 
    bool private swapping;
 
    address private marketingWallet;
    address private developmentWallet;
    address private teamWallet;
 
    uint256 public maxTransactionAmount;
    uint256 public swapTokensAtAmount;
    uint256 public maxWallet;
 
    bool public limitsInEffect = true;
    bool public tradingActive = false;
    bool public swapEnabled = false;
 
     // Anti-bot and anti-whale mappings and variables
    mapping(address => uint256) private _holderLastTransferTimestamp; // to hold last Transfers temporarily during launch
 
    // Seller Map
    mapping (address => uint256) private _holderFirstBuyTimestamp;
  
    uint256 public buyTotalFees;
    uint256 private buyMarketingFee;
    uint256 private buyLiquidityFee;
    uint256 private buyDevelopmentFee;
    uint256 private buyTeamFee;

 
    uint256 public sellTotalFees;
    uint256 private sellMarketingFee;
    uint256 private sellLiquidityFee;
    uint256 private sellDevelopmentFee;
    uint256 private sellTeamFee;

 
    uint256 private tokensForMarketing;
    uint256 private tokensForLiquidity;
    uint256 private tokensForDevelopment;
    uint256 private tokensForTeam;

    // block number of opened trading
    uint256 launchedAt;
 
    /******************/
 
    // exclude from fees and max transaction amount
    mapping (address => bool) private _isExcludedFromFees;
    mapping (address => bool) public _isExcludedMaxTransactionAmount;
    mapping (address => bool) public _isExcludedMaxWalletAmount;

 
    // store addresses that a automatic market maker pairs. Any transfer *to* these addresses
    // could be subject to a maximum transfer amount
    mapping (address => bool) public automatedMarketMakerPairs;
 
    event UpdateUniswapV2Router(address indexed newAddress, address indexed oldAddress);
 
    event ExcludeFromFees(address indexed account, bool isExcluded);
 
    event SetAutomatedMarketMakerPair(address indexed pair, bool indexed value);
 
    event marketingWalletUpdated(address indexed newWallet, address indexed oldWallet);
 
    event developmentWalletUpdated(address indexed newWallet, address indexed oldWallet);

    event teamWalletUpdated(address indexed newWallet, address indexed oldWallet);

 
    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiquidity
    );
 
    event AutoNukeLP();
 
    event ManualNukeLP();
 
    constructor() ERC20("Pepe Heads", "PEDS") {
 
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
 
        excludeFromMaxTransaction(address(_uniswapV2Router), true);
        uniswapV2Router = _uniswapV2Router;
 
        uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());
        excludeFromMaxTransaction(address(uniswapV2Pair), true);
        _setAutomatedMarketMakerPair(address(uniswapV2Pair), true);
 
        uint256 _buyMarketingFee = 3;
        uint256 _buyLiquidityFee = 1;
        uint256 _buyDevelopmentFee = 1;
        uint256 _buyTeamFee = 0;

 
        uint256 _sellMarketingFee = 3;
        uint256 _sellLiquidityFee = 1;
        uint256 _sellDevelopmentFee = 1;
        uint256 _sellTeamFee = 0;

 
        uint256 totalSupply = 1 * 10**14 * 10**9;
 
        maxTransactionAmount = totalSupply * 20 / 1000; // 2.5%
        maxWallet = totalSupply * 20 / 1000; // 2.5% 
        swapTokensAtAmount = totalSupply * 20 / 10000; // 0.25%
 
        buyMarketingFee = _buyMarketingFee;
        buyLiquidityFee = _buyLiquidityFee;
        buyDevelopmentFee = _buyDevelopmentFee;
        buyTeamFee = _buyTeamFee;
        buyTotalFees = buyMarketingFee + buyLiquidityFee + buyDevelopmentFee + buyTeamFee;
 
        sellMarketingFee = _sellMarketingFee;
        sellLiquidityFee = _sellLiquidityFee;
        sellDevelopmentFee = _sellDevelopmentFee;
        sellTeamFee = _sellTeamFee;
        sellTotalFees = sellMarketingFee + sellLiquidityFee + sellDevelopmentFee + sellTeamFee;
 
        marketingWallet = msg.sender; //
        developmentWallet = msg.sender; //
        teamWallet = msg.sender; //
 
        // exclude from paying fees or having max transaction amount
        excludeFromFees(owner(), true);
        excludeFromFees(address(this), true);
        excludeFromFees(address(0xdead), true);
 
        excludeFromMaxTransaction(owner(), true);
        excludeFromMaxTransaction(address(this), true);
        excludeFromMaxTransaction(address(0xdead), true);
 
        /*
            _mint is an internal function in ERC20.sol that is only called here,
            and CANNOT be called ever again
        */
        _mint(msg.sender, totalSupply);
    }
 
    receive() external payable {
 
    }
 
    // once enabled, can never be turned off
    function enableTrading() external onlyOwner {
        tradingActive = true;
        swapEnabled = true;
        launchedAt = block.number;
    }

 
 
     // change the minimum amount of tokens to sell from fees
    function updateSwapTokensAtAmount(uint256 newAmount) external onlyOwner returns (bool){
        require(newAmount >= totalSupply() * 1 / 1000, "Swap amount cannot be lower than 0.1% total supply.");
        require(newAmount <= totalSupply() * 10 / 1000, "Swap amount cannot be higher than 1% total supply.");
        swapTokensAtAmount = newAmount;
        return true;
    }
 
    function excludeFromMaxTransaction(address updAds, bool isEx) public onlyOwner {
        _isExcludedMaxTransactionAmount[updAds] = isEx;
    }

    function updateBuyFees(
        uint256 _developmentFee,
        uint256 _teamFee,
        uint256 _liquidityFee,
        uint256 _marketingFee
    ) external onlyOwner {
        buyDevelopmentFee = _developmentFee;
        buyTeamFee = _teamFee;
        buyLiquidityFee = _liquidityFee;
        buyMarketingFee = _marketingFee;
        buyTotalFees = buyDevelopmentFee + buyTeamFee + buyLiquidityFee + buyMarketingFee;
        require(buyTotalFees <= 100);
    }

    function updateSellFees(
        uint256 _developmentFee,
        uint256 _teamFee,
        uint256 _liquidityFee,
        uint256 _marketingFee
    ) external onlyOwner {
        sellDevelopmentFee = _developmentFee;
        sellTeamFee = _teamFee;
        sellLiquidityFee = _liquidityFee;
        sellMarketingFee = _marketingFee;
        sellTotalFees = sellDevelopmentFee +  sellTeamFee + sellLiquidityFee + sellMarketingFee;
        require(sellTotalFees <= 100);
    }
 
    // only use to disable contract sales if absolutely necessary (emergency use only)
    function updateSwapEnabled(bool enabled) external onlyOwner(){
        swapEnabled = enabled;
    }
 
    function excludeFromFees(address account, bool excluded) public onlyOwner {
        _isExcludedFromFees[account] = excluded;
        emit ExcludeFromFees(account, excluded);
    }
 
    function setAutomatedMarketMakerPair(address pair, bool value) public onlyOwner {
        require(pair != uniswapV2Pair, "The pair cannot be removed from automatedMarketMakerPairs");
 
        _setAutomatedMarketMakerPair(pair, value);
    }
 
    function _setAutomatedMarketMakerPair(address pair, bool value) private {
        automatedMarketMakerPairs[pair] = value;
 
        emit SetAutomatedMarketMakerPair(pair, value);
    }
 
    function updateMarketingWallet(address newMarketingWallet) external onlyOwner {
        emit marketingWalletUpdated(newMarketingWallet, marketingWallet);
        marketingWallet = newMarketingWallet;
    }
 
    function updateDevelopmentWallet(address newWallet) external onlyOwner {
        emit developmentWalletUpdated(newWallet, developmentWallet);
        developmentWallet = newWallet;
    }
 
 
    function isExcludedFromFees(address account) public view returns(bool) {
        return _isExcludedFromFees[account];
    }
 
    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
         if(amount == 0) {
            super._transfer(from, to, 0);
            return;
        }
 
        if(limitsInEffect){
            if (
                from != owner() &&
                to != owner() &&
                to != address(0) &&
                to != address(0xdead) &&
                !swapping
            ){
                if(!tradingActive){
                    require(_isExcludedFromFees[from] || _isExcludedFromFees[to], "Trading is not active.");
                }
 
 
                //when buy
                if (automatedMarketMakerPairs[from] && !_isExcludedMaxTransactionAmount[to]) {
                        require(amount <= maxTransactionAmount, "Buy transfer amount exceeds the maxTransactionAmount.");
                        require(amount + balanceOf(to) <= maxWallet, "Max wallet exceeded");
                }
 
                //when sell
                else if (automatedMarketMakerPairs[to] && !_isExcludedMaxTransactionAmount[from]) {
                        require(amount <= maxTransactionAmount, "Sell transfer amount exceeds the maxTransactionAmount.");
                }
                else if(!_isExcludedMaxTransactionAmount[to]){
                    require(amount + balanceOf(to) <= maxWallet, "Max wallet exceeded");
                }
            }
        }
 
        uint256 contractTokenBalance = balanceOf(address(this));
 
        bool canSwap = contractTokenBalance >= swapTokensAtAmount;
 
        if( 
            canSwap &&
            swapEnabled &&
            !swapping &&
            !automatedMarketMakerPairs[from] &&
            !_isExcludedFromFees[from] &&
            !_isExcludedFromFees[to]
        ) {
            swapping = true;
 
            swapBack();
 
            swapping = false;
        }
 
        bool takeFee = !swapping;
 
        // if any account belongs to _isExcludedFromFee account then remove the fee
        if(_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;
        }
 
        uint256 fees = 0;
        // only take fees on buys/sells, do not take on wallet transfers
        if(takeFee){
            // on sell
            if (automatedMarketMakerPairs[to] && sellTotalFees > 0){
                fees = amount.mul(sellTotalFees).div(100);
                tokensForLiquidity += fees * sellLiquidityFee / sellTotalFees;
                tokensForDevelopment += fees * sellDevelopmentFee / sellTotalFees;
                tokensForTeam += fees * sellTeamFee / sellTotalFees;
                tokensForMarketing += fees * sellMarketingFee / sellTotalFees;
            }
            // on buy
            else if(automatedMarketMakerPairs[from] && buyTotalFees > 0) {
                fees = amount.mul(buyTotalFees).div(100);
                tokensForLiquidity += fees * buyLiquidityFee / buyTotalFees;
                tokensForDevelopment += fees * buyDevelopmentFee / buyTotalFees;
                tokensForTeam += fees * buyTeamFee / buyTotalFees;
                tokensForMarketing += fees * buyMarketingFee / buyTotalFees;
            }
 
            if(fees > 0){    
                super._transfer(from, address(this), fees);
            }
 
            amount -= fees;
        }
 
        super._transfer(from, to, amount);
    }
 
    function swapTokensForEth(uint256 tokenAmount) private {
 
        // generate the uniswap 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 swapBack() private {
        uint256 contractBalance = balanceOf(address(this));
        uint256 totalTokensToSwap = tokensForLiquidity + tokensForMarketing + tokensForDevelopment + tokensForTeam;
        bool success;
 
        if(contractBalance == 0 || totalTokensToSwap == 0) {return;}
 
        if(contractBalance > swapTokensAtAmount * 20){
          contractBalance = swapTokensAtAmount * 20;
        }
 
        // Halve the amount of liquidity tokens
        uint256 liquidityTokens = contractBalance * tokensForLiquidity / totalTokensToSwap / 2;
        uint256 amountToSwapForETH = contractBalance.sub(liquidityTokens);
 
        uint256 initialETHBalance = address(this).balance;
 
        swapTokensForEth(amountToSwapForETH); 
 
        uint256 ethBalance = address(this).balance.sub(initialETHBalance);
 
        uint256 ethForMarketing = ethBalance.mul(tokensForMarketing).div(totalTokensToSwap);
        uint256 ethForDevelopment = ethBalance.mul(tokensForDevelopment).div(totalTokensToSwap);
        uint256 ethForTeam = ethBalance.mul(tokensForTeam).div(totalTokensToSwap);
        uint256 ethForLiquidity = ethBalance - ethForMarketing - ethForDevelopment - ethForTeam;
 
 
        tokensForLiquidity = 0;
        tokensForMarketing = 0;
        tokensForDevelopment = 0;
        tokensForTeam = 0;
 
        (success,) = address(developmentWallet).call{value: ethForDevelopment}("");
        (success,) = address(teamWallet).call{value: ethForTeam}("");

 
        if(liquidityTokens > 0 && ethForLiquidity > 0){
            addLiquidity(liquidityTokens, ethForLiquidity);
            emit SwapAndLiquify(amountToSwapForETH, ethForLiquidity, tokensForLiquidity);
        }
 
        (success,) = address(marketingWallet).call{value: address(this).balance}("");
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[],"name":"AutoNukeLP","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludeFromFees","type":"event"},{"anonymous":false,"inputs":[],"name":"ManualNukeLP","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pair","type":"address"},{"indexed":true,"internalType":"bool","name":"value","type":"bool"}],"name":"SetAutomatedMarketMakerPair","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":"tokensIntoLiquidity","type":"uint256"}],"name":"SwapAndLiquify","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"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"},{"indexed":true,"internalType":"address","name":"oldAddress","type":"address"}],"name":"UpdateUniswapV2Router","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newWallet","type":"address"},{"indexed":true,"internalType":"address","name":"oldWallet","type":"address"}],"name":"developmentWalletUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newWallet","type":"address"},{"indexed":true,"internalType":"address","name":"oldWallet","type":"address"}],"name":"marketingWalletUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newWallet","type":"address"},{"indexed":true,"internalType":"address","name":"oldWallet","type":"address"}],"name":"teamWalletUpdated","type":"event"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxTransactionAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxWalletAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"automatedMarketMakerPairs","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"enableTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"excludeFromMaxTransaction","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":"address","name":"account","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"limitsInEffect","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxTransactionAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWallet","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"sellTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapTokensAtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingActive","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"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":"uint256","name":"_developmentFee","type":"uint256"},{"internalType":"uint256","name":"_teamFee","type":"uint256"},{"internalType":"uint256","name":"_liquidityFee","type":"uint256"},{"internalType":"uint256","name":"_marketingFee","type":"uint256"}],"name":"updateBuyFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newWallet","type":"address"}],"name":"updateDevelopmentWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newMarketingWallet","type":"address"}],"name":"updateMarketingWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_developmentFee","type":"uint256"},{"internalType":"uint256","name":"_teamFee","type":"uint256"},{"internalType":"uint256","name":"_liquidityFee","type":"uint256"},{"internalType":"uint256","name":"_marketingFee","type":"uint256"}],"name":"updateSellFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"enabled","type":"bool"}],"name":"updateSwapEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newAmount","type":"uint256"}],"name":"updateSwapTokensAtAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

60c0604052600c805462ffffff191660011790553480156200002057600080fd5b50604080518082018252600a8152695065706520486561647360b01b6020808301918252835180850190945260048452635045445360e01b9084015281519192916200006f916003916200074b565b508051620000859060049060208401906200074b565b50505060006200009a6200046960201b60201c565b600580546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350737a250d5630b4cf539739df2c5dacb4c659f2488d6200010a8160016200046d565b6001600160a01b03811660808190526040805163c45a015560e01b8152905163c45a015591600480820192602092909190829003018186803b1580156200015057600080fd5b505afa15801562000165573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200018b9190620007f1565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015620001d457600080fd5b505afa158015620001e9573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200020f9190620007f1565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b1580156200025857600080fd5b505af11580156200026d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002939190620007f1565b6001600160a01b031660a0819052620002ae9060016200046d565b60a051620002be906001620004e7565b600360018060008382808369152d02c7e14af68000006103e8620002e482601462000832565b620002f0919062000854565b6009556103e86200030382601462000832565b6200030f919062000854565b600b556127106200032282601462000832565b6200032e919062000854565b600a5560108990556011889055601287905560138690558587620003538a8c62000877565b6200035f919062000877565b6200036b919062000877565b600f556015859055601684905560178390556018829055818362000390868862000877565b6200039c919062000877565b620003a8919062000877565b60145560068054336001600160a01b0319918216811790925560078054821683179055600880549091169091179055620003f6620003ee6005546001600160a01b031690565b60016200053b565b620004033060016200053b565b6200041261dead60016200053b565b62000431620004296005546001600160a01b031690565b60016200046d565b6200043e3060016200046d565b6200044d61dead60016200046d565b620004593382620005e5565b50505050505050505050620008cf565b3390565b6005546001600160a01b03163314620004bc5760405162461bcd60e51b8152602060048201819052602482015260008051602062002e4083398151915260448201526064015b60405180910390fd5b6001600160a01b03919091166000908152601f60205260409020805460ff1916911515919091179055565b6001600160a01b038216600081815260216020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6005546001600160a01b03163314620005865760405162461bcd60e51b8152602060048201819052602482015260008051602062002e408339815191526044820152606401620004b3565b6001600160a01b0382166000818152601e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6001600160a01b0382166200063d5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401620004b3565b6200065981600254620006e160201b62000f051790919060201c565b6002556001600160a01b038216600090815260208181526040909120546200068c91839062000f05620006e1821b17901c565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b600080620006f0838562000877565b905083811015620007445760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401620004b3565b9392505050565b828054620007599062000892565b90600052602060002090601f0160209004810192826200077d5760008555620007c8565b82601f106200079857805160ff1916838001178555620007c8565b82800160010185558215620007c8579182015b82811115620007c8578251825591602001919060010190620007ab565b50620007d6929150620007da565b5090565b5b80821115620007d65760008155600101620007db565b6000602082840312156200080457600080fd5b81516001600160a01b03811681146200074457600080fd5b634e487b7160e01b600052601160045260246000fd5b60008160001904831182151516156200084f576200084f6200081c565b500290565b6000826200087257634e487b7160e01b600052601260045260246000fd5b500490565b600082198211156200088d576200088d6200081c565b500190565b600181811c90821680620008a757607f821691505b60208210811415620008c957634e487b7160e01b600052602260045260246000fd5b50919050565b60805160a0516125216200091f600039600081816103b00152610a9c0152600081816102c701528181611db801528181611e8001528181611ebc01528181611f360152611f9201526125216000f3fe60806040526004361061021e5760003560e01c80638da5cb5b11610123578063bbc0c742116100ab578063dd62ed3e1161006f578063dd62ed3e14610698578063e2f45605146106de578063e7ad9fcd146106f4578063f023f57314610714578063f8b45b051461073457600080fd5b8063bbc0c7421461060d578063c02466681461062c578063c8c8ebe41461064c578063d257b34f14610662578063d85ba0631461068257600080fd5b80639a7a23d6116100f25780639a7a23d61461055d578063a457c2d71461057d578063a9059cbb1461059d578063aacebbe3146105bd578063b62496f5146105dd57600080fd5b80638da5cb5b146104db578063924de9b7146104f957806395d89b411461051957806396880b171461052e57600080fd5b806349bd5a5e116101a65780636ddd1713116101755780636ddd17131461043b57806370a082311461045b578063715018a6146104915780637571336a146104a65780638a8c523c146104c657600080fd5b806349bd5a5e1461039e5780634a62bb65146103d25780634fbee193146103ec5780636a486a8e1461042557600080fd5b806318160ddd116101ed57806318160ddd1461030157806323b872dd146103205780632e6ed7ef14610340578063313ce56714610362578063395093511461037e57600080fd5b806306fdde031461022a578063095ea7b31461025557806310d5de53146102855780631694505e146102b557600080fd5b3661022557005b600080fd5b34801561023657600080fd5b5061023f61074a565b60405161024c919061204d565b60405180910390f35b34801561026157600080fd5b506102756102703660046120ba565b6107dc565b604051901515815260200161024c565b34801561029157600080fd5b506102756102a03660046120e6565b601f6020526000908152604090205460ff1681565b3480156102c157600080fd5b506102e97f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b03909116815260200161024c565b34801561030d57600080fd5b506002545b60405190815260200161024c565b34801561032c57600080fd5b5061027561033b366004612103565b6107f3565b34801561034c57600080fd5b5061036061035b366004612144565b61085c565b005b34801561036e57600080fd5b506040516009815260200161024c565b34801561038a57600080fd5b506102756103993660046120ba565b6108db565b3480156103aa57600080fd5b506102e97f000000000000000000000000000000000000000000000000000000000000000081565b3480156103de57600080fd5b50600c546102759060ff1681565b3480156103f857600080fd5b506102756104073660046120e6565b6001600160a01b03166000908152601e602052604090205460ff1690565b34801561043157600080fd5b5061031260145481565b34801561044757600080fd5b50600c546102759062010000900460ff1681565b34801561046757600080fd5b506103126104763660046120e6565b6001600160a01b031660009081526020819052604090205490565b34801561049d57600080fd5b50610360610911565b3480156104b257600080fd5b506103606104c1366004612186565b610985565b3480156104d257600080fd5b506103606109da565b3480156104e757600080fd5b506005546001600160a01b03166102e9565b34801561050557600080fd5b506103606105143660046121bb565b610a1b565b34801561052557600080fd5b5061023f610a61565b34801561053a57600080fd5b506102756105493660046120e6565b602080526000908152604090205460ff1681565b34801561056957600080fd5b50610360610578366004612186565b610a70565b34801561058957600080fd5b506102756105983660046120ba565b610b50565b3480156105a957600080fd5b506102756105b83660046120ba565b610b9f565b3480156105c957600080fd5b506103606105d83660046120e6565b610bac565b3480156105e957600080fd5b506102756105f83660046120e6565b60216020526000908152604090205460ff1681565b34801561061957600080fd5b50600c5461027590610100900460ff1681565b34801561063857600080fd5b50610360610647366004612186565b610c33565b34801561065857600080fd5b5061031260095481565b34801561066e57600080fd5b5061027561067d3660046121d6565b610cbc565b34801561068e57600080fd5b50610312600f5481565b3480156106a457600080fd5b506103126106b33660046121ef565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b3480156106ea57600080fd5b50610312600a5481565b34801561070057600080fd5b5061036061070f366004612144565b610e0e565b34801561072057600080fd5b5061036061072f3660046120e6565b610e7e565b34801561074057600080fd5b50610312600b5481565b60606003805461075990612228565b80601f016020809104026020016040519081016040528092919081815260200182805461078590612228565b80156107d25780601f106107a7576101008083540402835291602001916107d2565b820191906000526020600020905b8154815290600101906020018083116107b557829003601f168201915b5050505050905090565b60006107e9338484610f6b565b5060015b92915050565b6000610800848484611090565b610852843361084d8560405180606001604052806028815260200161249f602891396001600160a01b038a16600090815260016020908152604080832033845290915290205491906117fd565b610f6b565b5060019392505050565b6005546001600160a01b0316331461088f5760405162461bcd60e51b815260040161088690612263565b60405180910390fd5b601284905560138390556011829055601081905580826108af85876122ae565b6108b991906122ae565b6108c391906122ae565b600f819055606410156108d557600080fd5b50505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916107e991859061084d9086610f05565b6005546001600160a01b0316331461093b5760405162461bcd60e51b815260040161088690612263565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b031633146109af5760405162461bcd60e51b815260040161088690612263565b6001600160a01b03919091166000908152601f60205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610a045760405162461bcd60e51b815260040161088690612263565b600c805462ffff0019166201010017905543601d55565b6005546001600160a01b03163314610a455760405162461bcd60e51b815260040161088690612263565b600c8054911515620100000262ff000019909216919091179055565b60606004805461075990612228565b6005546001600160a01b03163314610a9a5760405162461bcd60e51b815260040161088690612263565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b03161415610b425760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610886565b610b4c8282611837565b5050565b60006107e9338461084d856040518060600160405280602581526020016124c7602591393360009081526001602090815260408083206001600160a01b038d16845290915290205491906117fd565b60006107e9338484611090565b6005546001600160a01b03163314610bd65760405162461bcd60e51b815260040161088690612263565b6006546040516001600160a01b03918216918316907fa751787977eeb3902e30e1d19ca00c6ad274a1f622c31a206e32366700b0567490600090a3600680546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610c5d5760405162461bcd60e51b815260040161088690612263565b6001600160a01b0382166000818152601e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546000906001600160a01b03163314610ce95760405162461bcd60e51b815260040161088690612263565b6103e8610cf560025490565b610d009060016122c6565b610d0a91906122e5565b821015610d755760405162461bcd60e51b815260206004820152603360248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e6044820152721018171892903a37ba30b61039bab838363c9760691b6064820152608401610886565b6103e8610d8160025490565b610d8c90600a6122c6565b610d9691906122e5565b821115610e005760405162461bcd60e51b815260206004820152603260248201527f5377617020616d6f756e742063616e6e6f74206265206869676865722074686160448201527137101892903a37ba30b61039bab838363c9760711b6064820152608401610886565b50600a81905560015b919050565b6005546001600160a01b03163314610e385760405162461bcd60e51b815260040161088690612263565b60178490556018839055601682905560158190558082610e5885876122ae565b610e6291906122ae565b610e6c91906122ae565b6014819055606410156108d557600080fd5b6005546001600160a01b03163314610ea85760405162461bcd60e51b815260040161088690612263565b6007546040516001600160a01b03918216918316907ffaf1b77ed79f6e898c44dd8ab36b330c7b2fd39bcaab05ed6362480df870396590600090a3600780546001600160a01b0319166001600160a01b0392909216919091179055565b600080610f1283856122ae565b905083811015610f645760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610886565b9392505050565b6001600160a01b038316610fcd5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610886565b6001600160a01b03821661102e5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610886565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b0383166110b65760405162461bcd60e51b815260040161088690612307565b6001600160a01b0382166110dc5760405162461bcd60e51b81526004016108869061234c565b806110f2576110ed8383600061188b565b505050565b600c5460ff1615611468576005546001600160a01b0384811691161480159061112957506005546001600160a01b03838116911614155b801561113d57506001600160a01b03821615155b801561115457506001600160a01b03821661dead14155b801561116a5750600554600160a01b900460ff16155b1561146857600c54610100900460ff16611202576001600160a01b0383166000908152601e602052604090205460ff16806111bd57506001600160a01b0382166000908152601e602052604090205460ff165b6112025760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610886565b6001600160a01b03831660009081526021602052604090205460ff16801561124357506001600160a01b0382166000908152601f602052604090205460ff16155b15611327576009548111156112b85760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610886565b600b546001600160a01b0383166000908152602081905260409020546112de90836122ae565b11156113225760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610886565b611468565b6001600160a01b03821660009081526021602052604090205460ff16801561136857506001600160a01b0383166000908152601f602052604090205460ff16155b156113de576009548111156113225760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610886565b6001600160a01b0382166000908152601f602052604090205460ff1661146857600b546001600160a01b03831660009081526020819052604090205461142490836122ae565b11156114685760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610886565b30600090815260208190526040902054600a54811080159081906114945750600c5462010000900460ff165b80156114aa5750600554600160a01b900460ff16155b80156114cf57506001600160a01b03851660009081526021602052604090205460ff16155b80156114f457506001600160a01b0385166000908152601e602052604090205460ff16155b801561151957506001600160a01b0384166000908152601e602052604090205460ff16155b15611547576005805460ff60a01b1916600160a01b179055611539611994565b6005805460ff60a01b191690555b6005546001600160a01b0386166000908152601e602052604090205460ff600160a01b90920482161591168061159557506001600160a01b0385166000908152601e602052604090205460ff165b1561159e575060005b600081156117e9576001600160a01b03861660009081526021602052604090205460ff1680156115d057506000601454115b156116be576115f560646115ef60145488611c5e90919063ffffffff16565b90611cdd565b90506014546016548261160891906122c6565b61161291906122e5565b601a600082825461162391906122ae565b909155505060145460175461163890836122c6565b61164291906122e5565b601b600082825461165391906122ae565b909155505060145460185461166890836122c6565b61167291906122e5565b601c600082825461168391906122ae565b909155505060145460155461169890836122c6565b6116a291906122e5565b601960008282546116b391906122ae565b909155506117cb9050565b6001600160a01b03871660009081526021602052604090205460ff1680156116e857506000600f54115b156117cb5761170760646115ef600f5488611c5e90919063ffffffff16565b9050600f546011548261171a91906122c6565b61172491906122e5565b601a600082825461173591906122ae565b9091555050600f5460125461174a90836122c6565b61175491906122e5565b601b600082825461176591906122ae565b9091555050600f5460135461177a90836122c6565b61178491906122e5565b601c600082825461179591906122ae565b9091555050600f546010546117aa90836122c6565b6117b491906122e5565b601960008282546117c591906122ae565b90915550505b80156117dc576117dc87308361188b565b6117e6818661238f565b94505b6117f487878761188b565b50505050505050565b600081848411156118215760405162461bcd60e51b8152600401610886919061204d565b50600061182e848661238f565b95945050505050565b6001600160a01b038216600081815260216020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b0383166118b15760405162461bcd60e51b815260040161088690612307565b6001600160a01b0382166118d75760405162461bcd60e51b81526004016108869061234c565b61191481604051806060016040528060268152602001612479602691396001600160a01b03861660009081526020819052604090205491906117fd565b6001600160a01b0380851660009081526020819052604080822093909355908416815220546119439082610f05565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101611083565b3060009081526020819052604081205490506000601c54601b54601954601a546119be91906122ae565b6119c891906122ae565b6119d291906122ae565b905060008215806119e1575081155b156119eb57505050565b600a546119f99060146122c6565b831115611a1157600a54611a0e9060146122c6565b92505b6000600283601a5486611a2491906122c6565b611a2e91906122e5565b611a3891906122e5565b90506000611a468583611d1f565b905047611a5282611d61565b6000611a5e4783611d1f565b90506000611a7b876115ef60195485611c5e90919063ffffffff16565b90506000611a98886115ef601b5486611c5e90919063ffffffff16565b90506000611ab5896115ef601c5487611c5e90919063ffffffff16565b905060008183611ac5868861238f565b611acf919061238f565b611ad9919061238f565b6000601a8190556019819055601b819055601c8190556007546040519293506001600160a01b031691859181818185875af1925050503d8060008114611b3b576040519150601f19603f3d011682016040523d82523d6000602084013e611b40565b606091505b5050600854604051919a506001600160a01b0316908390600081818185875af1925050503d8060008114611b90576040519150601f19603f3d011682016040523d82523d6000602084013e611b95565b606091505b50909950508715801590611ba95750600081115b15611bfc57611bb88882611f30565b601a54604080518981526020810184905280820192909252517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a15b6006546040516001600160a01b03909116904790600081818185875af1925050503d8060008114611c49576040519150601f19603f3d011682016040523d82523d6000602084013e611c4e565b606091505b5050505050505050505050505050565b600082611c6d575060006107ed565b6000611c7983856122c6565b905082611c8685836122e5565b14610f645760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610886565b6000610f6483836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525061201f565b6000610f6483836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506117fd565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611d9657611d966123a6565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015611e0f57600080fd5b505afa158015611e23573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611e4791906123bc565b81600181518110611e5a57611e5a6123a6565b60200260200101906001600160a01b031690816001600160a01b031681525050611ea5307f000000000000000000000000000000000000000000000000000000000000000084610f6b565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063791ac94790611efa9085906000908690309042906004016123d9565b600060405180830381600087803b158015611f1457600080fd5b505af1158015611f28573d6000803e3d6000fd5b505050505050565b611f5b307f000000000000000000000000000000000000000000000000000000000000000084610f6b565b60405163f305d71960e01b8152306004820181905260248201849052600060448301819052606483015260848201524260a48201527f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03169063f305d71990839060c4016060604051808303818588803b158015611fdf57600080fd5b505af1158015611ff3573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190612018919061244a565b5050505050565b600081836120405760405162461bcd60e51b8152600401610886919061204d565b50600061182e84866122e5565b600060208083528351808285015260005b8181101561207a5785810183015185820160400152820161205e565b8181111561208c576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b03811681146120b757600080fd5b50565b600080604083850312156120cd57600080fd5b82356120d8816120a2565b946020939093013593505050565b6000602082840312156120f857600080fd5b8135610f64816120a2565b60008060006060848603121561211857600080fd5b8335612123816120a2565b92506020840135612133816120a2565b929592945050506040919091013590565b6000806000806080858703121561215a57600080fd5b5050823594602084013594506040840135936060013592509050565b80358015158114610e0957600080fd5b6000806040838503121561219957600080fd5b82356121a4816120a2565b91506121b260208401612176565b90509250929050565b6000602082840312156121cd57600080fd5b610f6482612176565b6000602082840312156121e857600080fd5b5035919050565b6000806040838503121561220257600080fd5b823561220d816120a2565b9150602083013561221d816120a2565b809150509250929050565b600181811c9082168061223c57607f821691505b6020821081141561225d57634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b600082198211156122c1576122c1612298565b500190565b60008160001904831182151516156122e0576122e0612298565b500290565b60008261230257634e487b7160e01b600052601260045260246000fd5b500490565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b6000828210156123a1576123a1612298565b500390565b634e487b7160e01b600052603260045260246000fd5b6000602082840312156123ce57600080fd5b8151610f64816120a2565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156124295784516001600160a01b031683529383019391830191600101612404565b50506001600160a01b03969096166060850152505050608001529392505050565b60008060006060848603121561245f57600080fd5b835192506020840151915060408401519050925092509256fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220c3d03333c7278d16581f1d37539f5e14b642c063649704a494b930e3d7e5ce0264736f6c634300080900334f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572

Deployed Bytecode

0x60806040526004361061021e5760003560e01c80638da5cb5b11610123578063bbc0c742116100ab578063dd62ed3e1161006f578063dd62ed3e14610698578063e2f45605146106de578063e7ad9fcd146106f4578063f023f57314610714578063f8b45b051461073457600080fd5b8063bbc0c7421461060d578063c02466681461062c578063c8c8ebe41461064c578063d257b34f14610662578063d85ba0631461068257600080fd5b80639a7a23d6116100f25780639a7a23d61461055d578063a457c2d71461057d578063a9059cbb1461059d578063aacebbe3146105bd578063b62496f5146105dd57600080fd5b80638da5cb5b146104db578063924de9b7146104f957806395d89b411461051957806396880b171461052e57600080fd5b806349bd5a5e116101a65780636ddd1713116101755780636ddd17131461043b57806370a082311461045b578063715018a6146104915780637571336a146104a65780638a8c523c146104c657600080fd5b806349bd5a5e1461039e5780634a62bb65146103d25780634fbee193146103ec5780636a486a8e1461042557600080fd5b806318160ddd116101ed57806318160ddd1461030157806323b872dd146103205780632e6ed7ef14610340578063313ce56714610362578063395093511461037e57600080fd5b806306fdde031461022a578063095ea7b31461025557806310d5de53146102855780631694505e146102b557600080fd5b3661022557005b600080fd5b34801561023657600080fd5b5061023f61074a565b60405161024c919061204d565b60405180910390f35b34801561026157600080fd5b506102756102703660046120ba565b6107dc565b604051901515815260200161024c565b34801561029157600080fd5b506102756102a03660046120e6565b601f6020526000908152604090205460ff1681565b3480156102c157600080fd5b506102e97f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b03909116815260200161024c565b34801561030d57600080fd5b506002545b60405190815260200161024c565b34801561032c57600080fd5b5061027561033b366004612103565b6107f3565b34801561034c57600080fd5b5061036061035b366004612144565b61085c565b005b34801561036e57600080fd5b506040516009815260200161024c565b34801561038a57600080fd5b506102756103993660046120ba565b6108db565b3480156103aa57600080fd5b506102e97f000000000000000000000000d0bfc3e69a35e22c6adc3fa9371add5e9950d6be81565b3480156103de57600080fd5b50600c546102759060ff1681565b3480156103f857600080fd5b506102756104073660046120e6565b6001600160a01b03166000908152601e602052604090205460ff1690565b34801561043157600080fd5b5061031260145481565b34801561044757600080fd5b50600c546102759062010000900460ff1681565b34801561046757600080fd5b506103126104763660046120e6565b6001600160a01b031660009081526020819052604090205490565b34801561049d57600080fd5b50610360610911565b3480156104b257600080fd5b506103606104c1366004612186565b610985565b3480156104d257600080fd5b506103606109da565b3480156104e757600080fd5b506005546001600160a01b03166102e9565b34801561050557600080fd5b506103606105143660046121bb565b610a1b565b34801561052557600080fd5b5061023f610a61565b34801561053a57600080fd5b506102756105493660046120e6565b602080526000908152604090205460ff1681565b34801561056957600080fd5b50610360610578366004612186565b610a70565b34801561058957600080fd5b506102756105983660046120ba565b610b50565b3480156105a957600080fd5b506102756105b83660046120ba565b610b9f565b3480156105c957600080fd5b506103606105d83660046120e6565b610bac565b3480156105e957600080fd5b506102756105f83660046120e6565b60216020526000908152604090205460ff1681565b34801561061957600080fd5b50600c5461027590610100900460ff1681565b34801561063857600080fd5b50610360610647366004612186565b610c33565b34801561065857600080fd5b5061031260095481565b34801561066e57600080fd5b5061027561067d3660046121d6565b610cbc565b34801561068e57600080fd5b50610312600f5481565b3480156106a457600080fd5b506103126106b33660046121ef565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b3480156106ea57600080fd5b50610312600a5481565b34801561070057600080fd5b5061036061070f366004612144565b610e0e565b34801561072057600080fd5b5061036061072f3660046120e6565b610e7e565b34801561074057600080fd5b50610312600b5481565b60606003805461075990612228565b80601f016020809104026020016040519081016040528092919081815260200182805461078590612228565b80156107d25780601f106107a7576101008083540402835291602001916107d2565b820191906000526020600020905b8154815290600101906020018083116107b557829003601f168201915b5050505050905090565b60006107e9338484610f6b565b5060015b92915050565b6000610800848484611090565b610852843361084d8560405180606001604052806028815260200161249f602891396001600160a01b038a16600090815260016020908152604080832033845290915290205491906117fd565b610f6b565b5060019392505050565b6005546001600160a01b0316331461088f5760405162461bcd60e51b815260040161088690612263565b60405180910390fd5b601284905560138390556011829055601081905580826108af85876122ae565b6108b991906122ae565b6108c391906122ae565b600f819055606410156108d557600080fd5b50505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916107e991859061084d9086610f05565b6005546001600160a01b0316331461093b5760405162461bcd60e51b815260040161088690612263565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b031633146109af5760405162461bcd60e51b815260040161088690612263565b6001600160a01b03919091166000908152601f60205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610a045760405162461bcd60e51b815260040161088690612263565b600c805462ffff0019166201010017905543601d55565b6005546001600160a01b03163314610a455760405162461bcd60e51b815260040161088690612263565b600c8054911515620100000262ff000019909216919091179055565b60606004805461075990612228565b6005546001600160a01b03163314610a9a5760405162461bcd60e51b815260040161088690612263565b7f000000000000000000000000d0bfc3e69a35e22c6adc3fa9371add5e9950d6be6001600160a01b0316826001600160a01b03161415610b425760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610886565b610b4c8282611837565b5050565b60006107e9338461084d856040518060600160405280602581526020016124c7602591393360009081526001602090815260408083206001600160a01b038d16845290915290205491906117fd565b60006107e9338484611090565b6005546001600160a01b03163314610bd65760405162461bcd60e51b815260040161088690612263565b6006546040516001600160a01b03918216918316907fa751787977eeb3902e30e1d19ca00c6ad274a1f622c31a206e32366700b0567490600090a3600680546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610c5d5760405162461bcd60e51b815260040161088690612263565b6001600160a01b0382166000818152601e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546000906001600160a01b03163314610ce95760405162461bcd60e51b815260040161088690612263565b6103e8610cf560025490565b610d009060016122c6565b610d0a91906122e5565b821015610d755760405162461bcd60e51b815260206004820152603360248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e6044820152721018171892903a37ba30b61039bab838363c9760691b6064820152608401610886565b6103e8610d8160025490565b610d8c90600a6122c6565b610d9691906122e5565b821115610e005760405162461bcd60e51b815260206004820152603260248201527f5377617020616d6f756e742063616e6e6f74206265206869676865722074686160448201527137101892903a37ba30b61039bab838363c9760711b6064820152608401610886565b50600a81905560015b919050565b6005546001600160a01b03163314610e385760405162461bcd60e51b815260040161088690612263565b60178490556018839055601682905560158190558082610e5885876122ae565b610e6291906122ae565b610e6c91906122ae565b6014819055606410156108d557600080fd5b6005546001600160a01b03163314610ea85760405162461bcd60e51b815260040161088690612263565b6007546040516001600160a01b03918216918316907ffaf1b77ed79f6e898c44dd8ab36b330c7b2fd39bcaab05ed6362480df870396590600090a3600780546001600160a01b0319166001600160a01b0392909216919091179055565b600080610f1283856122ae565b905083811015610f645760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610886565b9392505050565b6001600160a01b038316610fcd5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610886565b6001600160a01b03821661102e5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610886565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b0383166110b65760405162461bcd60e51b815260040161088690612307565b6001600160a01b0382166110dc5760405162461bcd60e51b81526004016108869061234c565b806110f2576110ed8383600061188b565b505050565b600c5460ff1615611468576005546001600160a01b0384811691161480159061112957506005546001600160a01b03838116911614155b801561113d57506001600160a01b03821615155b801561115457506001600160a01b03821661dead14155b801561116a5750600554600160a01b900460ff16155b1561146857600c54610100900460ff16611202576001600160a01b0383166000908152601e602052604090205460ff16806111bd57506001600160a01b0382166000908152601e602052604090205460ff165b6112025760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610886565b6001600160a01b03831660009081526021602052604090205460ff16801561124357506001600160a01b0382166000908152601f602052604090205460ff16155b15611327576009548111156112b85760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610886565b600b546001600160a01b0383166000908152602081905260409020546112de90836122ae565b11156113225760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610886565b611468565b6001600160a01b03821660009081526021602052604090205460ff16801561136857506001600160a01b0383166000908152601f602052604090205460ff16155b156113de576009548111156113225760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610886565b6001600160a01b0382166000908152601f602052604090205460ff1661146857600b546001600160a01b03831660009081526020819052604090205461142490836122ae565b11156114685760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610886565b30600090815260208190526040902054600a54811080159081906114945750600c5462010000900460ff165b80156114aa5750600554600160a01b900460ff16155b80156114cf57506001600160a01b03851660009081526021602052604090205460ff16155b80156114f457506001600160a01b0385166000908152601e602052604090205460ff16155b801561151957506001600160a01b0384166000908152601e602052604090205460ff16155b15611547576005805460ff60a01b1916600160a01b179055611539611994565b6005805460ff60a01b191690555b6005546001600160a01b0386166000908152601e602052604090205460ff600160a01b90920482161591168061159557506001600160a01b0385166000908152601e602052604090205460ff165b1561159e575060005b600081156117e9576001600160a01b03861660009081526021602052604090205460ff1680156115d057506000601454115b156116be576115f560646115ef60145488611c5e90919063ffffffff16565b90611cdd565b90506014546016548261160891906122c6565b61161291906122e5565b601a600082825461162391906122ae565b909155505060145460175461163890836122c6565b61164291906122e5565b601b600082825461165391906122ae565b909155505060145460185461166890836122c6565b61167291906122e5565b601c600082825461168391906122ae565b909155505060145460155461169890836122c6565b6116a291906122e5565b601960008282546116b391906122ae565b909155506117cb9050565b6001600160a01b03871660009081526021602052604090205460ff1680156116e857506000600f54115b156117cb5761170760646115ef600f5488611c5e90919063ffffffff16565b9050600f546011548261171a91906122c6565b61172491906122e5565b601a600082825461173591906122ae565b9091555050600f5460125461174a90836122c6565b61175491906122e5565b601b600082825461176591906122ae565b9091555050600f5460135461177a90836122c6565b61178491906122e5565b601c600082825461179591906122ae565b9091555050600f546010546117aa90836122c6565b6117b491906122e5565b601960008282546117c591906122ae565b90915550505b80156117dc576117dc87308361188b565b6117e6818661238f565b94505b6117f487878761188b565b50505050505050565b600081848411156118215760405162461bcd60e51b8152600401610886919061204d565b50600061182e848661238f565b95945050505050565b6001600160a01b038216600081815260216020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b0383166118b15760405162461bcd60e51b815260040161088690612307565b6001600160a01b0382166118d75760405162461bcd60e51b81526004016108869061234c565b61191481604051806060016040528060268152602001612479602691396001600160a01b03861660009081526020819052604090205491906117fd565b6001600160a01b0380851660009081526020819052604080822093909355908416815220546119439082610f05565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101611083565b3060009081526020819052604081205490506000601c54601b54601954601a546119be91906122ae565b6119c891906122ae565b6119d291906122ae565b905060008215806119e1575081155b156119eb57505050565b600a546119f99060146122c6565b831115611a1157600a54611a0e9060146122c6565b92505b6000600283601a5486611a2491906122c6565b611a2e91906122e5565b611a3891906122e5565b90506000611a468583611d1f565b905047611a5282611d61565b6000611a5e4783611d1f565b90506000611a7b876115ef60195485611c5e90919063ffffffff16565b90506000611a98886115ef601b5486611c5e90919063ffffffff16565b90506000611ab5896115ef601c5487611c5e90919063ffffffff16565b905060008183611ac5868861238f565b611acf919061238f565b611ad9919061238f565b6000601a8190556019819055601b819055601c8190556007546040519293506001600160a01b031691859181818185875af1925050503d8060008114611b3b576040519150601f19603f3d011682016040523d82523d6000602084013e611b40565b606091505b5050600854604051919a506001600160a01b0316908390600081818185875af1925050503d8060008114611b90576040519150601f19603f3d011682016040523d82523d6000602084013e611b95565b606091505b50909950508715801590611ba95750600081115b15611bfc57611bb88882611f30565b601a54604080518981526020810184905280820192909252517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a15b6006546040516001600160a01b03909116904790600081818185875af1925050503d8060008114611c49576040519150601f19603f3d011682016040523d82523d6000602084013e611c4e565b606091505b5050505050505050505050505050565b600082611c6d575060006107ed565b6000611c7983856122c6565b905082611c8685836122e5565b14610f645760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610886565b6000610f6483836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525061201f565b6000610f6483836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506117fd565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611d9657611d966123a6565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015611e0f57600080fd5b505afa158015611e23573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611e4791906123bc565b81600181518110611e5a57611e5a6123a6565b60200260200101906001600160a01b031690816001600160a01b031681525050611ea5307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84610f6b565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac94790611efa9085906000908690309042906004016123d9565b600060405180830381600087803b158015611f1457600080fd5b505af1158015611f28573d6000803e3d6000fd5b505050505050565b611f5b307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84610f6b565b60405163f305d71960e01b8152306004820181905260248201849052600060448301819052606483015260848201524260a48201527f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b03169063f305d71990839060c4016060604051808303818588803b158015611fdf57600080fd5b505af1158015611ff3573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190612018919061244a565b5050505050565b600081836120405760405162461bcd60e51b8152600401610886919061204d565b50600061182e84866122e5565b600060208083528351808285015260005b8181101561207a5785810183015185820160400152820161205e565b8181111561208c576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b03811681146120b757600080fd5b50565b600080604083850312156120cd57600080fd5b82356120d8816120a2565b946020939093013593505050565b6000602082840312156120f857600080fd5b8135610f64816120a2565b60008060006060848603121561211857600080fd5b8335612123816120a2565b92506020840135612133816120a2565b929592945050506040919091013590565b6000806000806080858703121561215a57600080fd5b5050823594602084013594506040840135936060013592509050565b80358015158114610e0957600080fd5b6000806040838503121561219957600080fd5b82356121a4816120a2565b91506121b260208401612176565b90509250929050565b6000602082840312156121cd57600080fd5b610f6482612176565b6000602082840312156121e857600080fd5b5035919050565b6000806040838503121561220257600080fd5b823561220d816120a2565b9150602083013561221d816120a2565b809150509250929050565b600181811c9082168061223c57607f821691505b6020821081141561225d57634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b600082198211156122c1576122c1612298565b500190565b60008160001904831182151516156122e0576122e0612298565b500290565b60008261230257634e487b7160e01b600052601260045260246000fd5b500490565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b6000828210156123a1576123a1612298565b500390565b634e487b7160e01b600052603260045260246000fd5b6000602082840312156123ce57600080fd5b8151610f64816120a2565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156124295784516001600160a01b031683529383019391830191600101612404565b50506001600160a01b03969096166060850152505050608001529392505050565b60008060006060848603121561245f57600080fd5b835192506020840151915060408401519050925092509256fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220c3d03333c7278d16581f1d37539f5e14b642c063649704a494b930e3d7e5ce0264736f6c63430008090033

Deployed Bytecode Sourcemap

28954:14881:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7448:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;9621:169;;;;;;;;;;-1:-1:-1;9621:169:0;;;;;:::i;:::-;;:::i;:::-;;;1237:14:1;;1230:22;1212:41;;1200:2;1185:18;9621:169:0;1072:187:1;30543:64:0;;;;;;;;;;-1:-1:-1;30543:64:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;29029:51;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;1707:32:1;;;1689:51;;1677:2;1662:18;29029:51:0;1516:230:1;8570:108:0;;;;;;;;;;-1:-1:-1;8658:12:0;;8570:108;;;1897:25:1;;;1885:2;1870:18;8570:108:0;1751:177:1;10273:355:0;;;;;;;;;;-1:-1:-1;10273:355:0;;;;;:::i;:::-;;:::i;34847:475::-;;;;;;;;;;-1:-1:-1;34847:475:0;;;;;:::i;:::-;;:::i;:::-;;8412:92;;;;;;;;;;-1:-1:-1;8412:92:0;;8495:1;2926:36:1;;2914:2;2899:18;8412:92:0;2784:184:1;11038:218:0;;;;;;;;;;-1:-1:-1;11038:218:0;;;;;:::i;:::-;;:::i;29087:38::-;;;;;;;;;;;;;;;29396:33;;;;;;;;;;-1:-1:-1;29396:33:0;;;;;;;;37085:125;;;;;;;;;;-1:-1:-1;37085:125:0;;;;;:::i;:::-;-1:-1:-1;;;;;37174:28:0;37150:4;37174:28;;;:19;:28;;;;;;;;;37085:125;29978:28;;;;;;;;;;;;;;;;29476:31;;;;;;;;;;-1:-1:-1;29476:31:0;;;;;;;;;;;8742:127;;;;;;;;;;-1:-1:-1;8742:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;8843:18:0;8816:7;8843:18;;;;;;;;;;;;8742:127;21949:148;;;;;;;;;;;;;:::i;34695:144::-;;;;;;;;;;-1:-1:-1;34695:144:0;;;;;:::i;:::-;;:::i;34080:148::-;;;;;;;;;;;;;:::i;21305:79::-;;;;;;;;;;-1:-1:-1;21370:6:0;;-1:-1:-1;;;;;21370:6:0;21305:79;;35914:101;;;;;;;;;;-1:-1:-1;35914:101:0;;;;;:::i;:::-;;:::i;7668:104::-;;;;;;;;;;;;;:::i;30614:59::-;;;;;;;;;;-1:-1:-1;30614:59:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;36215:245;;;;;;;;;;-1:-1:-1;36215:245:0;;;;;:::i;:::-;;:::i;11760:269::-;;;;;;;;;;-1:-1:-1;11760:269:0;;;;;:::i;:::-;;:::i;9083:175::-;;;;;;;;;;-1:-1:-1;9083:175:0;;;;;:::i;:::-;;:::i;36667:208::-;;;;;;;;;;-1:-1:-1;36667:208:0;;;;;:::i;:::-;;:::i;30834:58::-;;;;;;;;;;-1:-1:-1;30834:58:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;29436:33;;;;;;;;;;-1:-1:-1;29436:33:0;;;;;;;;;;;36024:182;;;;;;;;;;-1:-1:-1;36024:182:0;;;;;:::i;:::-;;:::i;29280:35::-;;;;;;;;;;;;;;;;34305:381;;;;;;;;;;-1:-1:-1;34305:381:0;;;;;:::i;:::-;;:::i;29790:27::-;;;;;;;;;;;;;;;;9322:151;;;;;;;;;;-1:-1:-1;9322:151:0;;;;;:::i;:::-;-1:-1:-1;;;;;9438:18:0;;;9411:7;9438:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;9322:151;29322:33;;;;;;;;;;;;;;;;35330:487;;;;;;;;;;-1:-1:-1;35330:487:0;;;;;:::i;:::-;;:::i;36884:189::-;;;;;;;;;;-1:-1:-1;36884:189:0;;;;;:::i;:::-;;:::i;29362:24::-;;;;;;;;;;;;;;;;7448:100;7502:13;7535:5;7528:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7448:100;:::o;9621:169::-;9704:4;9721:39;219:10;9744:7;9753:6;9721:8;:39::i;:::-;-1:-1:-1;9778:4:0;9621:169;;;;;:::o;10273:355::-;10413:4;10430:36;10440:6;10448:9;10459:6;10430:9;:36::i;:::-;10477:121;10486:6;219:10;10508:89;10546:6;10508:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;10508:19:0;;;;;;:11;:19;;;;;;;;219:10;10508:33;;;;;;;;;;:37;:89::i;:::-;10477:8;:121::i;:::-;-1:-1:-1;10616:4:0;10273:355;;;;;:::o;34847:475::-;21518:6;;-1:-1:-1;;;;;21518:6:0;219:10;21518:22;21510:67;;;;-1:-1:-1;;;21510:67:0;;;;;;;:::i;:::-;;;;;;;;;35032:17:::1;:35:::0;;;35078:10:::1;:21:::0;;;35110:15:::1;:31:::0;;;35152:15:::1;:31:::0;;;35170:13;35128;35209:30:::1;35091:8:::0;35052:15;35209:30:::1;:::i;:::-;:48;;;;:::i;:::-;:66;;;;:::i;:::-;35194:12;:81:::0;;;35310:3:::1;-1:-1:-1::0;35294:19:0::1;35286:28;;;::::0;::::1;;34847:475:::0;;;;:::o;11038:218::-;219:10;11126:4;11175:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11175:34:0;;;;;;;;;;11126:4;;11143:83;;11166:7;;11175:50;;11214:10;11175:38;:50::i;21949:148::-;21518:6;;-1:-1:-1;;;;;21518:6:0;219:10;21518:22;21510:67;;;;-1:-1:-1;;;21510:67:0;;;;;;;:::i;:::-;22040:6:::1;::::0;22019:40:::1;::::0;22056:1:::1;::::0;-1:-1:-1;;;;;22040:6:0::1;::::0;22019:40:::1;::::0;22056:1;;22019:40:::1;22070:6;:19:::0;;-1:-1:-1;;;;;;22070:19:0::1;::::0;;21949:148::o;34695:144::-;21518:6;;-1:-1:-1;;;;;21518:6:0;219:10;21518:22;21510:67;;;;-1:-1:-1;;;21510:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;34785:39:0;;;::::1;;::::0;;;:31:::1;:39;::::0;;;;:46;;-1:-1:-1;;34785:46:0::1;::::0;::::1;;::::0;;;::::1;::::0;;34695:144::o;34080:148::-;21518:6;;-1:-1:-1;;;;;21518:6:0;219:10;21518:22;21510:67;;;;-1:-1:-1;;;21510:67:0;;;;;;;:::i;:::-;34135:13:::1;:20:::0;;-1:-1:-1;;34166:18:0;;;;;34208:12:::1;34195:10;:25:::0;34080:148::o;35914:101::-;21518:6;;-1:-1:-1;;;;;21518:6:0;219:10;21518:22;21510:67;;;;-1:-1:-1;;;21510:67:0;;;;;;;:::i;:::-;35986:11:::1;:21:::0;;;::::1;;::::0;::::1;-1:-1:-1::0;;35986:21:0;;::::1;::::0;;;::::1;::::0;;35914:101::o;7668:104::-;7724:13;7757:7;7750:14;;;;;:::i;36215:245::-;21518:6;;-1:-1:-1;;;;;21518:6:0;219:10;21518:22;21510:67;;;;-1:-1:-1;;;21510:67:0;;;;;;;:::i;:::-;36322:13:::1;-1:-1:-1::0;;;;;36314:21:0::1;:4;-1:-1:-1::0;;;;;36314:21:0::1;;;36306:91;;;::::0;-1:-1:-1;;;36306:91:0;;5642:2:1;36306:91:0::1;::::0;::::1;5624:21:1::0;5681:2;5661:18;;;5654:30;5720:34;5700:18;;;5693:62;5791:27;5771:18;;;5764:55;5836:19;;36306:91:0::1;5440:421:1::0;36306:91:0::1;36411:41;36440:4;36446:5;36411:28;:41::i;:::-;36215:245:::0;;:::o;11760:269::-;11853:4;11870:129;219:10;11893:7;11902:96;11941:15;11902:96;;;;;;;;;;;;;;;;;219:10;11902:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11902:34:0;;;;;;;;;;;;:38;:96::i;9083:175::-;9169:4;9186:42;219:10;9210:9;9221:6;9186:9;:42::i;36667:208::-;21518:6;;-1:-1:-1;;;;;21518:6:0;219:10;21518:22;21510:67;;;;-1:-1:-1;;;21510:67:0;;;;;;;:::i;:::-;36804:15:::1;::::0;36761:59:::1;::::0;-1:-1:-1;;;;;36804:15:0;;::::1;::::0;36761:59;::::1;::::0;::::1;::::0;36804:15:::1;::::0;36761:59:::1;36831:15;:36:::0;;-1:-1:-1;;;;;;36831:36:0::1;-1:-1:-1::0;;;;;36831:36:0;;;::::1;::::0;;;::::1;::::0;;36667:208::o;36024:182::-;21518:6;;-1:-1:-1;;;;;21518:6:0;219:10;21518:22;21510:67;;;;-1:-1:-1;;;21510:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;36109:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;36109:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;36164:34;;1212:41:1;;;36164:34:0::1;::::0;1185:18:1;36164:34:0::1;;;;;;;36024:182:::0;;:::o;34305:381::-;21518:6;;34386:4;;-1:-1:-1;;;;;21518:6:0;219:10;21518:22;21510:67;;;;-1:-1:-1;;;21510:67:0;;;;;;;:::i;:::-;34443:4:::1;34423:13;8658:12:::0;;;8570:108;34423:13:::1;:17;::::0;34439:1:::1;34423:17;:::i;:::-;:24;;;;:::i;:::-;34410:9;:37;;34402:101;;;::::0;-1:-1:-1;;;34402:101:0;;6463:2:1;34402:101:0::1;::::0;::::1;6445:21:1::0;6502:2;6482:18;;;6475:30;6541:34;6521:18;;;6514:62;-1:-1:-1;;;6592:18:1;;;6585:49;6651:19;;34402:101:0::1;6261:415:1::0;34402:101:0::1;34556:4;34535:13;8658:12:::0;;;8570:108;34535:13:::1;:18;::::0;34551:2:::1;34535:18;:::i;:::-;:25;;;;:::i;:::-;34522:9;:38;;34514:101;;;::::0;-1:-1:-1;;;34514:101:0;;6883:2:1;34514:101:0::1;::::0;::::1;6865:21:1::0;6922:2;6902:18;;;6895:30;6961:34;6941:18;;;6934:62;-1:-1:-1;;;7012:18:1;;;7005:48;7070:19;;34514:101:0::1;6681:414:1::0;34514:101:0::1;-1:-1:-1::0;34626:18:0::1;:30:::0;;;34674:4:::1;21588:1;34305:381:::0;;;:::o;35330:487::-;21518:6;;-1:-1:-1;;;;;21518:6:0;219:10;21518:22;21510:67;;;;-1:-1:-1;;;21510:67:0;;;;;;;:::i;:::-;35516:18:::1;:36:::0;;;35563:11:::1;:22:::0;;;35596:16:::1;:32:::0;;;35639:16:::1;:32:::0;;;35658:13;35615;35698:33:::1;35577:8:::0;35537:15;35698:33:::1;:::i;:::-;:52;;;;:::i;:::-;:71;;;;:::i;:::-;35682:13;:87:::0;;;35805:3:::1;-1:-1:-1::0;35788:20:0::1;35780:29;;;::::0;::::1;36884:189:::0;21518:6;;-1:-1:-1;;;;;21518:6:0;219:10;21518:22;21510:67;;;;-1:-1:-1;;;21510:67:0;;;;;;;:::i;:::-;37007:17:::1;::::0;36971:54:::1;::::0;-1:-1:-1;;;;;37007:17:0;;::::1;::::0;36971:54;::::1;::::0;::::1;::::0;37007:17:::1;::::0;36971:54:::1;37036:17;:29:::0;;-1:-1:-1;;;;;;37036:29:0::1;-1:-1:-1::0;;;;;37036:29:0;;;::::1;::::0;;;::::1;::::0;;36884:189::o;16337:182::-;16395:7;;16427:5;16431:1;16427;:5;:::i;:::-;16415:17;;16456:1;16451;:6;;16443:46;;;;-1:-1:-1;;;16443:46:0;;7302:2:1;16443:46:0;;;7284:21:1;7341:2;7321:18;;;7314:30;7380:29;7360:18;;;7353:57;7427:18;;16443:46:0;7100:351:1;16443:46:0;16510:1;16337:182;-1:-1:-1;;;16337:182:0:o;14956:381::-;-1:-1:-1;;;;;15092:19:0;;15084:68;;;;-1:-1:-1;;;15084:68:0;;7658:2:1;15084:68:0;;;7640:21:1;7697:2;7677:18;;;7670:30;7736:34;7716:18;;;7709:62;-1:-1:-1;;;7787:18:1;;;7780:34;7831:19;;15084:68:0;7456:400:1;15084:68:0;-1:-1:-1;;;;;15171:21:0;;15163:68;;;;-1:-1:-1;;;15163:68:0;;8063:2:1;15163:68:0;;;8045:21:1;8102:2;8082:18;;;8075:30;8141:34;8121:18;;;8114:62;-1:-1:-1;;;8192:18:1;;;8185:32;8234:19;;15163:68:0;7861:398:1;15163:68:0;-1:-1:-1;;;;;15245:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;15297:32;;1897:25:1;;;15297:32:0;;1870:18:1;15297:32:0;;;;;;;;14956:381;;;:::o;37219:3631::-;-1:-1:-1;;;;;37351:18:0;;37343:68;;;;-1:-1:-1;;;37343:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;37430:16:0;;37422:64;;;;-1:-1:-1;;;37422:64:0;;;;;;;:::i;:::-;37501:11;37498:92;;37529:28;37545:4;37551:2;37555:1;37529:15;:28::i;:::-;37219:3631;;;:::o;37498:92::-;37606:14;;;;37603:1236;;;21370:6;;-1:-1:-1;;;;;37658:15:0;;;21370:6;;37658:15;;;;:49;;-1:-1:-1;21370:6:0;;-1:-1:-1;;;;;37694:13:0;;;21370:6;;37694:13;;37658:49;:86;;;;-1:-1:-1;;;;;;37728:16:0;;;;37658:86;:128;;;;-1:-1:-1;;;;;;37765:21:0;;37779:6;37765:21;;37658:128;:158;;;;-1:-1:-1;37808:8:0;;-1:-1:-1;;;37808:8:0;;;;37807:9;37658:158;37636:1192;;;37854:13;;;;;;;37850:148;;-1:-1:-1;;;;;37899:25:0;;;;;;:19;:25;;;;;;;;;:52;;-1:-1:-1;;;;;;37928:23:0;;;;;;:19;:23;;;;;;;;37899:52;37891:87;;;;-1:-1:-1;;;37891:87:0;;9276:2:1;37891:87:0;;;9258:21:1;9315:2;9295:18;;;9288:30;-1:-1:-1;;;9334:18:1;;;9327:52;9396:18;;37891:87:0;9074:346:1;37891:87:0;-1:-1:-1;;;;;38054:31:0;;;;;;:25;:31;;;;;;;;:71;;;;-1:-1:-1;;;;;;38090:35:0;;;;;;:31;:35;;;;;;;;38089:36;38054:71;38050:763;;;38172:20;;38162:6;:30;;38154:96;;;;-1:-1:-1;;;38154:96:0;;9627:2:1;38154:96:0;;;9609:21:1;9666:2;9646:18;;;9639:30;9705:34;9685:18;;;9678:62;-1:-1:-1;;;9756:18:1;;;9749:51;9817:19;;38154:96:0;9425:417:1;38154:96:0;38311:9;;-1:-1:-1;;;;;8843:18:0;;8816:7;8843:18;;;;;;;;;;;38285:22;;:6;:22;:::i;:::-;:35;;38277:67;;;;-1:-1:-1;;;38277:67:0;;10049:2:1;38277:67:0;;;10031:21:1;10088:2;10068:18;;;10061:30;-1:-1:-1;;;10107:18:1;;;10100:49;10166:18;;38277:67:0;9847:343:1;38277:67:0;38050:763;;;-1:-1:-1;;;;;38423:29:0;;;;;;:25;:29;;;;;;;;:71;;;;-1:-1:-1;;;;;;38457:37:0;;;;;;:31;:37;;;;;;;;38456:38;38423:71;38419:394;;;38541:20;;38531:6;:30;;38523:97;;;;-1:-1:-1;;;38523:97:0;;10397:2:1;38523:97:0;;;10379:21:1;10436:2;10416:18;;;10409:30;10475:34;10455:18;;;10448:62;-1:-1:-1;;;10526:18:1;;;10519:52;10588:19;;38523:97:0;10195:418:1;38419:394:0;-1:-1:-1;;;;;38667:35:0;;;;;;:31;:35;;;;;;;;38663:150;;38760:9;;-1:-1:-1;;;;;8843:18:0;;8816:7;8843:18;;;;;;;;;;;38734:22;;:6;:22;:::i;:::-;:35;;38726:67;;;;-1:-1:-1;;;38726:67:0;;10049:2:1;38726:67:0;;;10031:21:1;10088:2;10068:18;;;10061:30;-1:-1:-1;;;10107:18:1;;;10100:49;10166:18;;38726:67:0;9847:343:1;38726:67:0;38901:4;38852:28;8843:18;;;;;;;;;;;38960;;38936:42;;;;;;;39010:35;;-1:-1:-1;39034:11:0;;;;;;;39010:35;:61;;;;-1:-1:-1;39063:8:0;;-1:-1:-1;;;39063:8:0;;;;39062:9;39010:61;:110;;;;-1:-1:-1;;;;;;39089:31:0;;;;;;:25;:31;;;;;;;;39088:32;39010:110;:153;;;;-1:-1:-1;;;;;;39138:25:0;;;;;;:19;:25;;;;;;;;39137:26;39010:153;:194;;;;-1:-1:-1;;;;;;39181:23:0;;;;;;:19;:23;;;;;;;;39180:24;39010:194;38992:328;;;39231:8;:15;;-1:-1:-1;;;;39231:15:0;-1:-1:-1;;;39231:15:0;;;39264:10;:8;:10::i;:::-;39292:8;:16;;-1:-1:-1;;;;39292:16:0;;;38992:328;39349:8;;-1:-1:-1;;;;;39459:25:0;;39333:12;39459:25;;;:19;:25;;;;;;39349:8;-1:-1:-1;;;39349:8:0;;;;;39348:9;;39459:25;;:52;;-1:-1:-1;;;;;;39488:23:0;;;;;;:19;:23;;;;;;;;39459:52;39456:99;;;-1:-1:-1;39538:5:0;39456:99;39568:12;39672:7;39669:1127;;;-1:-1:-1;;;;;39723:29:0;;;;;;:25;:29;;;;;;;;:50;;;;;39772:1;39756:13;;:17;39723:50;39719:924;;;39800:34;39830:3;39800:25;39811:13;;39800:6;:10;;:25;;;;:::i;:::-;:29;;:34::i;:::-;39793:41;;39901:13;;39882:16;;39875:4;:23;;;;:::i;:::-;:39;;;;:::i;:::-;39853:18;;:61;;;;;;;:::i;:::-;;;;-1:-1:-1;;39985:13:0;;39964:18;;39957:25;;:4;:25;:::i;:::-;:41;;;;:::i;:::-;39933:20;;:65;;;;;;;:::i;:::-;;;;-1:-1:-1;;40055:13:0;;40041:11;;40034:18;;:4;:18;:::i;:::-;:34;;;;:::i;:::-;40017:13;;:51;;;;;;;:::i;:::-;;;;-1:-1:-1;;40135:13:0;;40116:16;;40109:23;;:4;:23;:::i;:::-;:39;;;;:::i;:::-;40087:18;;:61;;;;;;;:::i;:::-;;;;-1:-1:-1;39719:924:0;;-1:-1:-1;39719:924:0;;-1:-1:-1;;;;;40209:31:0;;;;;;:25;:31;;;;;;;;:51;;;;;40259:1;40244:12;;:16;40209:51;40206:437;;;40288:33;40317:3;40288:24;40299:12;;40288:6;:10;;:24;;;;:::i;:33::-;40281:40;;40387:12;;40369:15;;40362:4;:22;;;;:::i;:::-;:37;;;;:::i;:::-;40340:18;;:59;;;;;;;:::i;:::-;;;;-1:-1:-1;;40469:12:0;;40449:17;;40442:24;;:4;:24;:::i;:::-;:39;;;;:::i;:::-;40418:20;;:63;;;;;;;:::i;:::-;;;;-1:-1:-1;;40537:12:0;;40524:10;;40517:17;;:4;:17;:::i;:::-;:32;;;;:::i;:::-;40500:13;;:49;;;;;;;:::i;:::-;;;;-1:-1:-1;;40615:12:0;;40597:15;;40590:22;;:4;:22;:::i;:::-;:37;;;;:::i;:::-;40568:18;;:59;;;;;;;:::i;:::-;;;;-1:-1:-1;;40206:437:0;40663:8;;40660:93;;40695:42;40711:4;40725;40732;40695:15;:42::i;:::-;40770:14;40780:4;40770:14;;:::i;:::-;;;39669:1127;40809:33;40825:4;40831:2;40835:6;40809:15;:33::i;:::-;37332:3518;;;;37219:3631;;;:::o;17243:193::-;17329:7;17365:12;17357:6;;;;17349:29;;;;-1:-1:-1;;;17349:29:0;;;;;;;;:::i;:::-;-1:-1:-1;17389:9:0;17401:5;17405:1;17401;:5;:::i;:::-;17389:17;17243:193;-1:-1:-1;;;;;17243:193:0:o;36469:189::-;-1:-1:-1;;;;;36552:31:0;;;;;;:25;:31;;;;;;:39;;-1:-1:-1;;36552:39:0;;;;;;;;;;36610:40;;36552:39;;:31;36610:40;;;36469:189;;:::o;12520:575::-;-1:-1:-1;;;;;12660:20:0;;12652:70;;;;-1:-1:-1;;;12652:70:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;12741:23:0;;12733:71;;;;-1:-1:-1;;;12733:71:0;;;;;;;:::i;:::-;12899;12921:6;12899:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;12899:17:0;;:9;:17;;;;;;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;12879:17:0;;;:9;:17;;;;;;;;;;;:91;;;;13004:20;;;;;;;:32;;13029:6;13004:24;:32::i;:::-;-1:-1:-1;;;;;12981:20:0;;;:9;:20;;;;;;;;;;;;:55;;;;13052:35;1897:25:1;;;12981:20:0;;13052:35;;;;;;1870:18:1;13052:35:0;1751:177:1;41994:1838:0;42077:4;42033:23;8843:18;;;;;;;;;;;42033:50;;42094:25;42187:13;;42164:20;;42143:18;;42122;;:39;;;;:::i;:::-;:62;;;;:::i;:::-;:78;;;;:::i;:::-;42094:106;-1:-1:-1;42211:12:0;42240:20;;;:46;;-1:-1:-1;42264:22:0;;42240:46;42237:60;;;42289:7;;;41994:1838::o;42237:60::-;42331:18;;:23;;42352:2;42331:23;:::i;:::-;42313:15;:41;42310:111;;;42386:18;;:23;;42407:2;42386:23;:::i;:::-;42368:41;;42310:111;42483:23;42568:1;42548:17;42527:18;;42509:15;:36;;;;:::i;:::-;:56;;;;:::i;:::-;:60;;;;:::i;:::-;42483:86;-1:-1:-1;42580:26:0;42609:36;:15;42483:86;42609:19;:36::i;:::-;42580:65;-1:-1:-1;42687:21:0;42722:36;42580:65;42722:16;:36::i;:::-;42773:18;42794:44;:21;42820:17;42794:25;:44::i;:::-;42773:65;;42852:23;42878:57;42917:17;42878:34;42893:18;;42878:10;:14;;:34;;;;:::i;:57::-;42852:83;;42946:25;42974:59;43015:17;42974:36;42989:20;;42974:10;:14;;:36;;;;:::i;:59::-;42946:87;;43044:18;43065:52;43099:17;43065:29;43080:13;;43065:10;:14;;:29;;;;:::i;:52::-;43044:73;-1:-1:-1;43128:23:0;43044:73;43185:17;43154:28;43167:15;43154:10;:28;:::i;:::-;:48;;;;:::i;:::-;:61;;;;:::i;:::-;43253:1;43232:18;:22;;;43265:18;:22;;;43298:20;:24;;;43333:13;:17;;;43385;;43377:61;;43128:87;;-1:-1:-1;;;;;;43385:17:0;;43416;;43377:61;43253:1;43377:61;43416:17;43385;43377:61;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;43470:10:0;;43462:47;;43364:74;;-1:-1:-1;;;;;;43470:10:0;;43494;;43462:47;;;;43494:10;43470;43462:47;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;43449:60:0;;-1:-1:-1;;43528:19:0;;;;;:42;;;43569:1;43551:15;:19;43528:42;43525:210;;;43586:46;43599:15;43616;43586:12;:46::i;:::-;43704:18;;43652:71;;;11160:25:1;;;11216:2;11201:18;;11194:34;;;11244:18;;;11237:34;;;;43652:71:0;;;;;;11148:2:1;43652:71:0;;;43525:210;43769:15;;43761:63;;-1:-1:-1;;;;;43769:15:0;;;;43798:21;;43761:63;;;;43798:21;43769:15;43761:63;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;;;;41994:1838:0:o;17696:473::-;17754:7;17999:6;17995:47;;-1:-1:-1;18029:1:0;18022:8;;17995:47;18055:9;18067:5;18071:1;18067;:5;:::i;:::-;18055:17;-1:-1:-1;18100:1:0;18091:5;18095:1;18055:17;18091:5;:::i;:::-;:10;18083:56;;;;-1:-1:-1;;;18083:56:0;;11484:2:1;18083:56:0;;;11466:21:1;11523:2;11503:18;;;11496:30;11562:34;11542:18;;;11535:62;-1:-1:-1;;;11613:18:1;;;11606:31;11654:19;;18083:56:0;11282:397:1;18646:132:0;18704:7;18731:39;18735:1;18738;18731:39;;;;;;;;;;;;;;;;;:3;:39::i;16803:136::-;16861:7;16888:43;16892:1;16895;16888:43;;;;;;;;;;;;;;;;;:3;:43::i;40859:597::-;41012:16;;;41026:1;41012:16;;;;;;;;40988:21;;41012:16;;;;;;;;;;-1:-1:-1;41012:16:0;40988:40;;41057:4;41039;41044:1;41039:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;41039:23:0;;;-1:-1:-1;;;;;41039:23:0;;;;;41083:15;-1:-1:-1;;;;;41083:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;41073:4;41078:1;41073:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;41073:32:0;;;-1:-1:-1;;;;;41073:32:0;;;;;41119:62;41136:4;41151:15;41169:11;41119:8;:62::i;:::-;41221:224;;-1:-1:-1;;;41221:224:0;;-1:-1:-1;;;;;41221:15:0;:66;;;;:224;;41302:11;;41328:1;;41372:4;;41399;;41419:15;;41221:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;40914:542;40859:597;:::o;41465:520::-;41613:62;41630:4;41645:15;41663:11;41613:8;:62::i;:::-;41719:258;;-1:-1:-1;;;41719:258:0;;41791:4;41719:258;;;13530:34:1;;;13580:18;;;13573:34;;;41837:1:0;13623:18:1;;;13616:34;;;13666:18;;;13659:34;13709:19;;;13702:44;41951:15:0;13762:19:1;;;13755:35;41719:15:0;-1:-1:-1;;;;;41719:31:0;;;;41758:9;;13464:19:1;;41719:258:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;41465:520;;:::o;19275:279::-;19361:7;19396:12;19389:5;19381:28;;;;-1:-1:-1;;;19381:28:0;;;;;;;;:::i;:::-;-1:-1:-1;19420:9:0;19432:5;19436:1;19432;:5;:::i;14:597: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;;;452:6;449:1;446:13;443:91;;;522:1;517:2;508:6;497:9;493:22;489:31;482:42;443:91;-1:-1:-1;595:2:1;574:15;-1:-1:-1;;570:29:1;555:45;;;;602:2;551:54;;14:597;-1:-1:-1;;;14:597:1:o;616:131::-;-1:-1:-1;;;;;691:31:1;;681:42;;671:70;;737:1;734;727:12;671:70;616:131;:::o;752:315::-;820:6;828;881:2;869:9;860:7;856:23;852:32;849:52;;;897:1;894;887:12;849:52;936:9;923:23;955:31;980:5;955:31;:::i;:::-;1005:5;1057:2;1042:18;;;;1029:32;;-1:-1:-1;;;752:315:1:o;1264:247::-;1323:6;1376:2;1364:9;1355:7;1351:23;1347:32;1344:52;;;1392:1;1389;1382:12;1344:52;1431:9;1418:23;1450:31;1475:5;1450:31;:::i;1933:456::-;2010:6;2018;2026;2079:2;2067:9;2058:7;2054:23;2050:32;2047:52;;;2095:1;2092;2085:12;2047:52;2134:9;2121:23;2153:31;2178:5;2153:31;:::i;:::-;2203:5;-1:-1:-1;2260:2:1;2245:18;;2232:32;2273:33;2232:32;2273:33;:::i;:::-;1933:456;;2325:7;;-1:-1:-1;;;2379:2:1;2364:18;;;;2351:32;;1933:456::o;2394:385::-;2480:6;2488;2496;2504;2557:3;2545:9;2536:7;2532:23;2528:33;2525:53;;;2574:1;2571;2564:12;2525:53;-1:-1:-1;;2597:23:1;;;2667:2;2652:18;;2639:32;;-1:-1:-1;2718:2:1;2703:18;;2690:32;;2769:2;2754:18;2741:32;;-1:-1:-1;2394:385:1;-1:-1:-1;2394:385:1:o;3181:160::-;3246:20;;3302:13;;3295:21;3285:32;;3275:60;;3331:1;3328;3321:12;3346:315;3411:6;3419;3472:2;3460:9;3451:7;3447:23;3443:32;3440:52;;;3488:1;3485;3478:12;3440:52;3527:9;3514:23;3546:31;3571:5;3546:31;:::i;:::-;3596:5;-1:-1:-1;3620:35:1;3651:2;3636:18;;3620:35;:::i;:::-;3610:45;;3346:315;;;;;:::o;3666:180::-;3722:6;3775:2;3763:9;3754:7;3750:23;3746:32;3743:52;;;3791:1;3788;3781:12;3743:52;3814:26;3830:9;3814:26;:::i;3851:180::-;3910:6;3963:2;3951:9;3942:7;3938:23;3934:32;3931:52;;;3979:1;3976;3969:12;3931:52;-1:-1:-1;4002:23:1;;3851:180;-1:-1:-1;3851:180:1:o;4036:388::-;4104:6;4112;4165:2;4153:9;4144:7;4140:23;4136:32;4133:52;;;4181:1;4178;4171:12;4133:52;4220:9;4207:23;4239:31;4264:5;4239:31;:::i;:::-;4289:5;-1:-1:-1;4346:2:1;4331:18;;4318:32;4359:33;4318:32;4359:33;:::i;:::-;4411:7;4401:17;;;4036:388;;;;;:::o;4429:380::-;4508:1;4504:12;;;;4551;;;4572:61;;4626:4;4618:6;4614:17;4604:27;;4572:61;4679:2;4671:6;4668:14;4648:18;4645:38;4642:161;;;4725:10;4720:3;4716:20;4713:1;4706:31;4760:4;4757:1;4750:15;4788:4;4785:1;4778:15;4642:161;;4429:380;;;:::o;4814:356::-;5016:2;4998:21;;;5035:18;;;5028:30;5094:34;5089:2;5074:18;;5067:62;5161:2;5146:18;;4814:356::o;5175:127::-;5236:10;5231:3;5227:20;5224:1;5217:31;5267:4;5264:1;5257:15;5291:4;5288:1;5281:15;5307:128;5347:3;5378:1;5374:6;5371:1;5368:13;5365:39;;;5384:18;;:::i;:::-;-1:-1:-1;5420:9:1;;5307:128::o;5866:168::-;5906:7;5972:1;5968;5964:6;5960:14;5957:1;5954:21;5949:1;5942:9;5935:17;5931:45;5928:71;;;5979:18;;:::i;:::-;-1:-1:-1;6019:9:1;;5866:168::o;6039:217::-;6079:1;6105;6095:132;;6149:10;6144:3;6140:20;6137:1;6130:31;6184:4;6181:1;6174:15;6212:4;6209:1;6202:15;6095:132;-1:-1:-1;6241:9:1;;6039:217::o;8264:401::-;8466:2;8448:21;;;8505:2;8485:18;;;8478:30;8544:34;8539:2;8524:18;;8517:62;-1:-1:-1;;;8610:2:1;8595:18;;8588:35;8655:3;8640:19;;8264:401::o;8670:399::-;8872:2;8854:21;;;8911:2;8891:18;;;8884:30;8950:34;8945:2;8930:18;;8923:62;-1:-1:-1;;;9016:2:1;9001:18;;8994:33;9059:3;9044:19;;8670:399::o;10618:125::-;10658:4;10686:1;10683;10680:8;10677:34;;;10691:18;;:::i;:::-;-1:-1:-1;10728:9:1;;10618:125::o;11816:127::-;11877:10;11872:3;11868:20;11865:1;11858:31;11908:4;11905:1;11898:15;11932:4;11929:1;11922:15;11948:251;12018:6;12071:2;12059:9;12050:7;12046:23;12042:32;12039:52;;;12087:1;12084;12077:12;12039:52;12119:9;12113:16;12138:31;12163:5;12138:31;:::i;12204:980::-;12466:4;12514:3;12503:9;12499:19;12545:6;12534:9;12527:25;12571:2;12609:6;12604:2;12593:9;12589:18;12582:34;12652:3;12647:2;12636:9;12632:18;12625:31;12676:6;12711;12705:13;12742:6;12734;12727:22;12780:3;12769:9;12765:19;12758:26;;12819:2;12811:6;12807:15;12793:29;;12840:1;12850:195;12864:6;12861:1;12858:13;12850:195;;;12929:13;;-1:-1:-1;;;;;12925:39:1;12913:52;;13020:15;;;;12985:12;;;;12961:1;12879:9;12850:195;;;-1:-1:-1;;;;;;;13101:32:1;;;;13096:2;13081:18;;13074:60;-1:-1:-1;;;13165:3:1;13150:19;13143:35;13062:3;12204:980;-1:-1:-1;;;12204:980:1:o;13801:306::-;13889:6;13897;13905;13958:2;13946:9;13937:7;13933:23;13929:32;13926:52;;;13974:1;13971;13964:12;13926:52;14003:9;13997:16;13987:26;;14053:2;14042:9;14038:18;14032:25;14022:35;;14097:2;14086:9;14082:18;14076:25;14066:35;;13801:306;;;;;:::o

Swarm Source

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