Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0xca76BF98B6e44DF7360Da8650E701f6D9D94Bb58
Balance 0 ETH
Nonce 1
Code Size 7897 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

7897 bytes
0x608060405260043610610220575f3560e01c8063924de9b71161011e578063bfd79284116100a8578063e2f456051161006d578063e2f4560514610687578063e64561941461069c578063e7b71ce2146106bb578063eba4c333146106cf578063f2fde38b146106ee575f80fd5b8063bfd79284146105c2578063c0246668146105f0578063d257b34f1461060f578063d85ba0631461062e578063dd62ed3e14610643575f80fd5b80639dd7f55a116100ee5780639dd7f55a1461051e578063a457c2d71461053d578063a9059cbb1461055c578063b62496f51461057b578063bbc0c742146105a9575f80fd5b8063924de9b7146104b757806395d89b41146104d6578063979b30e0146104ea5780639a7a23d6146104ff575f80fd5b806349bd5a5e116101aa578063715018a61161016f578063715018a61461043457806371fc468814610448578063881dce60146104675780638a8c523c146104865780638da5cb5b1461049a575f80fd5b806349bd5a5e146103865780636a486a8e146103b95780636ddd1713146103ce5780636fc3eaec146103ec57806370a0823114610400575f80fd5b806318160ddd116101f057806318160ddd146102f057806323b872dd1461030e5780632d4e642a1461032d578063313ce5671461034c5780633950935114610367575f80fd5b806302af20951461022b57806306fdde031461024c578063095ea7b3146102765780631694505e146102a5575f80fd5b3661022757005b5f80fd5b348015610236575f80fd5b5061024a610245366004611a56565b61070d565b005b348015610257575f80fd5b5061026061079a565b60405161026d9190611abd565b60405180910390f35b348015610281575f80fd5b50610295610290366004611b1d565b61082a565b604051901515815260200161026d565b3480156102b0575f80fd5b506102d87f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b03909116815260200161026d565b3480156102fb575f80fd5b506002545b60405190815260200161026d565b348015610319575f80fd5b50610295610328366004611b47565b610840565b348015610338575f80fd5b5061024a610347366004611b85565b6108ed565b348015610357575f80fd5b506040516012815260200161026d565b348015610372575f80fd5b50610295610381366004611b1d565b61091c565b348015610391575f80fd5b506102d87f000000000000000000000000b062444f2844ddc306533243d8f0a1f67e26fdb581565b3480156103c4575f80fd5b50610300600c5481565b3480156103d9575f80fd5b50600a5461029590610100900460ff1681565b3480156103f7575f80fd5b5061024a610957565b34801561040b575f80fd5b5061030061041a366004611b9c565b6001600160a01b03165f9081526020819052604090205490565b34801561043f575f80fd5b5061024a610a1b565b348015610453575f80fd5b5061024a610462366004611b85565b610a50565b348015610472575f80fd5b5061024a610481366004611b85565b610ad3565b348015610491575f80fd5b5061024a610ba3565b3480156104a5575f80fd5b506005546001600160a01b03166102d8565b3480156104c2575f80fd5b5061024a6104d1366004611bcb565b610bde565b3480156104e1575f80fd5b50610260610c22565b3480156104f5575f80fd5b5061030060095481565b34801561050a575f80fd5b5061024a610519366004611be4565b610c31565b348015610529575f80fd5b5061024a610538366004611c17565b610d2c565b348015610548575f80fd5b50610295610557366004611b1d565b610d84565b348015610567575f80fd5b50610295610576366004611b1d565b610e1c565b348015610586575f80fd5b50610295610595366004611b9c565b600f6020525f908152604090205460ff1681565b3480156105b4575f80fd5b50600a546102959060ff1681565b3480156105cd575f80fd5b506102956105dc366004611b9c565b600e6020525f908152604090205460ff1681565b3480156105fb575f80fd5b5061024a61060a366004611be4565b610e28565b34801561061a575f80fd5b5061024a610629366004611b85565b610eb0565b348015610639575f80fd5b50610300600b5481565b34801561064e575f80fd5b5061030061065d366004611c17565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b348015610692575f80fd5b5061030060085481565b3480156106a7575f80fd5b5061024a6106b6366004611c4e565b610edf565b3480156106c6575f80fd5b5061024a610f6d565b3480156106da575f80fd5b5061024a6106e9366004611b85565b610fa2565b3480156106f9575f80fd5b5061024a610708366004611b9c565b611022565b821580159061071b57508083145b610723575f80fd5b335f5b848110156107925761078a8287878481811061074457610744611c9e565b90506020020160208101906107599190611b9c565b86868581811061076b5761076b611c9e565b90506020020135670de0b6b3a76400006107859190611cc6565b6110ba565b600101610726565b505050505050565b6060600380546107a990611cdd565b80601f01602080910402602001604051908101604052809291908181526020018280546107d590611cdd565b80156108205780601f106107f757610100808354040283529160200191610820565b820191905f5260205f20905b81548152906001019060200180831161080357829003601f168201915b5050505050905090565b5f61083633848461149c565b5060015b92915050565b5f61084c8484846110ba565b6001600160a01b0384165f908152600160209081526040808320338452909152902054828110156108d55760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084015b60405180910390fd5b6108e2853385840361149c565b506001949350505050565b6005546001600160a01b031633146109175760405162461bcd60e51b81526004016108cc90611d15565b600955565b335f8181526001602090815260408083206001600160a01b03871684529091528120549091610836918590610952908690611d4a565b61149c565b6006546001600160a01b0316336001600160a01b0316148061098c57506007546001600160a01b0316336001600160a01b0316145b6109c65760405162461bcd60e51b815260206004820152600b60248201526a139bdd08185b1b1bddd95960aa1b60448201526064016108cc565b6007546040515f916001600160a01b03169047908381818185875af1925050503d805f8114610a10576040519150601f19603f3d011682016040523d82523d5f602084013e610a15565b606091505b50505050565b6005546001600160a01b03163314610a455760405162461bcd60e51b81526004016108cc90611d15565b610a4e5f6115bf565b565b6005546001600160a01b03163314610a7a5760405162461bcd60e51b81526004016108cc90611d15565b600b8190556014811115610ad05760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420323025206f72206c65737300000060448201526064016108cc565b50565b6006546001600160a01b0316336001600160a01b03161480610b0857506007546001600160a01b0316336001600160a01b0316145b610b425760405162461bcd60e51b815260206004820152600b60248201526a139bdd08185b1b1bddd95960aa1b60448201526064016108cc565b305f908152602081905260409020548111158015610b5f57505f81115b610b9a5760405162461bcd60e51b815260206004820152600c60248201526b15dc9bdb99c8185b5bdd5b9d60a21b60448201526064016108cc565b610ad081611610565b6005546001600160a01b03163314610bcd5760405162461bcd60e51b81526004016108cc90611d15565b600a805461ffff1916610101179055565b6005546001600160a01b03163314610c085760405162461bcd60e51b81526004016108cc90611d15565b600a80549115156101000261ff0019909216919091179055565b6060600480546107a990611cdd565b6005546001600160a01b03163314610c5b5760405162461bcd60e51b81526004016108cc90611d15565b7f000000000000000000000000b062444f2844ddc306533243d8f0a1f67e26fdb56001600160a01b0316826001600160a01b031603610d025760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b657250616972730000000000000060648201526084016108cc565b6001600160a01b03919091165f908152600f60205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610d565760405162461bcd60e51b81526004016108cc90611d15565b600680546001600160a01b039384166001600160a01b03199182161790915560078054929093169116179055565b335f9081526001602090815260408083206001600160a01b038616845290915281205482811015610e055760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084016108cc565b610e12338585840361149c565b5060019392505050565b5f6108363384846110ba565b6005546001600160a01b03163314610e525760405162461bcd60e51b81526004016108cc90611d15565b6001600160a01b0382165f818152600d6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b03163314610eda5760405162461bcd60e51b81526004016108cc90611d15565b600855565b6005546001600160a01b03163314610f095760405162461bcd60e51b81526004016108cc90611d15565b5f5b82811015610a155781600e5f868685818110610f2957610f29611c9e565b9050602002016020810190610f3e9190611b9c565b6001600160a01b0316815260208101919091526040015f20805460ff1916911515919091179055600101610f0b565b6005546001600160a01b03163314610f975760405162461bcd60e51b81526004016108cc90611d15565b5f600b556004600c55565b6005546001600160a01b03163314610fcc5760405162461bcd60e51b81526004016108cc90611d15565b600c8190556014811115610ad05760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420323025206f72206c65737300000060448201526064016108cc565b6005546001600160a01b0316331461104c5760405162461bcd60e51b81526004016108cc90611d15565b6001600160a01b0381166110b15760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016108cc565b610ad0816115bf565b6001600160a01b0383166110e05760405162461bcd60e51b81526004016108cc90611d5d565b6001600160a01b0382166111065760405162461bcd60e51b81526004016108cc90611da2565b6001600160a01b0383165f908152600e602052604090205460ff1615801561114657506001600160a01b0382165f908152600e602052604090205460ff16155b6111885760405162461bcd60e51b8152602060048201526013602482015272165bdd48185c9948189b1858dadb1a5cdd1959606a1b60448201526064016108cc565b805f0361119f5761119a83835f6117be565b505050565b6005546001600160a01b038481169116148015906111cb57506005546001600160a01b03838116911614155b80156111df57506001600160a01b03821615155b80156111f657506001600160a01b03821661dead14155b801561120b5750600a5462010000900460ff16155b1561129c57600a5460ff1661129c576001600160a01b0383165f908152600d602052604090205460ff168061125757506001600160a01b0382165f908152600d602052604090205460ff165b61129c5760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016108cc565b305f90815260208190526040902054600854811080159081906112c65750600a54610100900460ff165b80156112db5750600a5462010000900460ff16155b80156112ff57506001600160a01b0385165f908152600f602052604090205460ff16155b801561132357506001600160a01b0385165f908152600d602052604090205460ff16155b801561134757506001600160a01b0384165f908152600d602052604090205460ff16155b1561137257600a805462ff0000191662010000179055611365611910565b600a805462ff0000191690555b600a546001600160a01b0386165f908152600d602052604090205460ff620100009092048216159116806113bd57506001600160a01b0385165f908152600d602052604090205460ff165b156113c557505f5b5f8115611488576001600160a01b0386165f908152600f602052604090205460ff1680156113f457505f600c54115b15611420576114196064611413600c54886119f190919063ffffffff16565b90611a03565b905061146a565b6001600160a01b0387165f908152600f602052604090205460ff16801561144857505f600b54115b1561146a576114676064611413600b54886119f190919063ffffffff16565b90505b801561147b5761147b8730836117be565b6114858186611de5565b94505b6114938787876117be565b50505050505050565b6001600160a01b0383166114fe5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016108cc565b6001600160a01b03821661155f5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016108cc565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a35050565b6040805160028082526060820183525f9260208301908036833701905050905030815f8151811061164357611643611c9e565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156116bf573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906116e39190611df8565b816001815181106116f6576116f6611c9e565b60200260200101906001600160a01b031690816001600160a01b031681525050611741307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d8461149c565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac947906117959085905f90869030904290600401611e13565b5f604051808303815f87803b1580156117ac575f80fd5b505af1158015610792573d5f803e3d5ffd5b6001600160a01b0383166117e45760405162461bcd60e51b81526004016108cc90611d5d565b6001600160a01b03821661180a5760405162461bcd60e51b81526004016108cc90611da2565b6001600160a01b0383165f90815260208190526040902054818110156118815760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016108cc565b6001600160a01b038085165f908152602081905260408082208585039055918516815290812080548492906118b7908490611d4a565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405161190391815260200190565b60405180910390a3610a15565b305f908152602081905260408120549081810361192b575050565b60095482111561193b5760095491505b8161194581611610565b60075447906001600160a01b031661195e600283611e84565b6040515f81818185875af1925050503d805f8114611997576040519150601f19603f3d011682016040523d82523d5f602084013e61199c565b606091505b50506006549093506001600160a01b03166119b8600283611e84565b6040515f81818185875af1925050503d805f8114611493576040519150601f19603f3d011682016040523d82523d5f602084013e611493565b5f6119fc8284611cc6565b9392505050565b5f6119fc8284611e84565b5f8083601f840112611a1e575f80fd5b50813567ffffffffffffffff811115611a35575f80fd5b6020830191508360208260051b8501011115611a4f575f80fd5b9250929050565b5f805f8060408587031215611a69575f80fd5b843567ffffffffffffffff80821115611a80575f80fd5b611a8c88838901611a0e565b90965094506020870135915080821115611aa4575f80fd5b50611ab187828801611a0e565b95989497509550505050565b5f602080835283518060208501525f5b81811015611ae957858101830151858201604001528201611acd565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610ad0575f80fd5b5f8060408385031215611b2e575f80fd5b8235611b3981611b09565b946020939093013593505050565b5f805f60608486031215611b59575f80fd5b8335611b6481611b09565b92506020840135611b7481611b09565b929592945050506040919091013590565b5f60208284031215611b95575f80fd5b5035919050565b5f60208284031215611bac575f80fd5b81356119fc81611b09565b80358015158114611bc6575f80fd5b919050565b5f60208284031215611bdb575f80fd5b6119fc82611bb7565b5f8060408385031215611bf5575f80fd5b8235611c0081611b09565b9150611c0e60208401611bb7565b90509250929050565b5f8060408385031215611c28575f80fd5b8235611c3381611b09565b91506020830135611c4381611b09565b809150509250929050565b5f805f60408486031215611c60575f80fd5b833567ffffffffffffffff811115611c76575f80fd5b611c8286828701611a0e565b9094509250611c95905060208501611bb7565b90509250925092565b634e487b7160e01b5f52603260045260245ffd5b634e487b7160e01b5f52601160045260245ffd5b808202811582820484141761083a5761083a611cb2565b600181811c90821680611cf157607f821691505b602082108103611d0f57634e487b7160e01b5f52602260045260245ffd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b8082018082111561083a5761083a611cb2565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b8181038181111561083a5761083a611cb2565b5f60208284031215611e08575f80fd5b81516119fc81611b09565b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b81811015611e635784516001600160a01b031683529383019391830191600101611e3e565b50506001600160a01b03969096166060850152505050608001529392505050565b5f82611e9e57634e487b7160e01b5f52601260045260245ffd5b50049056fea2646970667358221220da65419846542ad043cc9b46769176b0e7fec2017e045bd0bb861d6b2803fd0a64736f6c63430008180033

Verified Source Code Full Match

Compiler: v0.8.24+commit.e11b9ed9 EVM: shanghai Optimization: Yes (200 runs)
token.sol 805 lines
/*

MemeLinked (MK)

Website: https://memelinked.io
Telegram: https://t.me/memelinkedportal
Twitter: https://x.com/memelinked

*/

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.21;

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

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

abstract contract Ownable is Context {
    address private _owner;

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


    constructor() {
        _transferOwnership(_msgSender());
    }


    function owner() public view virtual returns (address) {
        return _owner;
    }


    modifier onlyOwner() {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(address(0));
    }


    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        _transferOwnership(newOwner);
    }

    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

interface IERC20 {

    function totalSupply() external view returns (uint256);

    function balanceOf(address account) external view returns (uint256);

    function transfer(address recipient, uint256 amount) external returns (bool);

    function allowance(address owner, address spender) external view returns (uint256);

    function approve(address spender, uint256 amount) external returns (bool);

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    event Transfer(address indexed from, address indexed to, uint256 value);

    event Approval(address indexed owner, address indexed spender, uint256 value);
}

interface IERC20Metadata is IERC20 {

    function name() external view returns (string memory);

    function symbol() external view returns (string memory);

    function decimals() external view returns (uint8);
}

contract ERC20 is Context, IERC20, IERC20Metadata {
    mapping(address => uint256) private _balances;

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

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }


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

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

    function decimals() public view virtual override returns (uint8) {
        return 18;
    }

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

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

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

    function allowance(address owner, address spender) public view virtual override returns (uint256) {
        return _allowances[owner][spender];
    }

    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);

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

        return true;
    }

    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue);
        return true;
    }

    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        unchecked {
            _approve(_msgSender(), spender, currentAllowance - subtractedValue);
        }

        return true;
    }

    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(sender, recipient, amount);

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

        emit Transfer(sender, recipient, amount);

        _afterTokenTransfer(sender, recipient, amount);
    }

    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");

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

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

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

    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");

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

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

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

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

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

    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}

    function _afterTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}

library SafeMath {

    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            uint256 c = a + b;
            if (c < a) return (false, 0);
            return (true, c);
        }
    }

    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b > a) return (false, 0);
            return (true, a - b);
        }
    }

    function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (a == 0) return (true, 0);
            uint256 c = a * b;
            if (c / a != b) return (false, 0);
            return (true, c);
        }
    }

    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a / b);
        }
    }

    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        return a + b;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return a - b;
    }

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        return a * b;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return a / b;
    }

    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return a % b;
    }

    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b <= a, errorMessage);
            return a - b;
        }
    }

    function div(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a / b;
        }
    }

    function mod(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }
}

interface IUniswapV2Factory {
    event PairCreated(
        address indexed token0,
        address indexed token1,
        address pair,
        uint256
    );

    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(uint256) external view returns (address pair);

    function allPairsLength() external view returns (uint256);

    function createPair(address tokenA, address tokenB)
        external
        returns (address pair);

    function setFeeTo(address) external;

    function setFeeToSetter(address) external;
}

interface IUniswapV2Pair {
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
    event Transfer(address indexed from, address indexed to, uint256 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 (uint256);

    function balanceOf(address owner) external view returns (uint256);

    function allowance(address owner, address spender)
        external
        view
        returns (uint256);

    function approve(address spender, uint256 value) external returns (bool);

    function transfer(address to, uint256 value) external returns (bool);

    function transferFrom(
        address from,
        address to,
        uint256 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 (uint256);

    function permit(
        address owner,
        address spender,
        uint256 value,
        uint256 deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external;

    event Mint(address indexed sender, uint256 amount0, uint256 amount1);
    event Burn(
        address indexed sender,
        uint256 amount0,
        uint256 amount1,
        address indexed to
    );
    event Swap(
        address indexed sender,
        uint256 amount0In,
        uint256 amount1In,
        uint256 amount0Out,
        uint256 amount1Out,
        address indexed to
    );
    event Sync(uint112 reserve0, uint112 reserve1);

    function MINIMUM_LIQUIDITY() external pure returns (uint256);

    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 (uint256);

    function price1CumulativeLast() external view returns (uint256);

    function kLast() external view returns (uint256);

    function mint(address to) external returns (uint256 liquidity);

    function burn(address to)
        external
        returns (uint256 amount0, uint256 amount1);

    function swap(
        uint256 amount0Out,
        uint256 amount1Out,
        address to,
        bytes calldata data
    ) external;

    function skim(address to) external;

    function sync() external;

    function initialize(address, address) external;
}

interface IUniswapV2Router02 {
    function factory() external pure returns (address);

    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint256 amountADesired,
        uint256 amountBDesired,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    )
        external
        returns (
            uint256 amountA,
            uint256 amountB,
            uint256 liquidity
        );

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (
            uint256 amountToken,
            uint256 amountETH,
            uint256 liquidity
        );

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;

    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable;

    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;
}

contract MemeLinked is ERC20, Ownable {

    using SafeMath for uint256;

    IUniswapV2Router02 public immutable uniswapV2Router;
    address public immutable uniswapV2Pair;

    address private marketingWallet;
    address private devWallet;

    uint256 public swapTokensAtAmount;
    uint256 public maxTokensContractCanSwap;

    bool public tradingActive;
    bool public swapEnabled;
    bool private swapping;

    uint256 public buyTotalFees;
    uint256 public sellTotalFees;

    mapping(address => bool) private _isExcludedFromFees;
    mapping(address => bool) public bots;
    mapping(address => bool) public automatedMarketMakerPairs;

    event ExcludeFromFees(address indexed account, bool isExcluded);
    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiquidity
    );

    constructor() ERC20("MemeLinked", "MK") {

        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D); 
        uniswapV2Router = _uniswapV2Router;

        uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());
        automatedMarketMakerPairs[address(uniswapV2Pair)] = true;

        uint256 totalSupply = 1_000_000_000 * 1e18;

        swapTokensAtAmount = totalSupply / 10000; //Once ca balance hits 0.01% amount, sell will trigger an auto swap
        maxTokensContractCanSwap = totalSupply / 100; //Contract can swap max of 1% at once

        //Tax
        buyTotalFees = 0; //Initial tax only. Normal tax is 0%
        sellTotalFees = 25; //Initial tax only. Normal tax is 4%

        //Tax wallets
        marketingWallet = 0x71dDa5F4637fe661772F8A69912bE074441c58E9;
        devWallet = 0xB10848548A78CE479c23A670f2A9bD183038cA1f;

        excludeFromFees(owner(), true);
        excludeFromFees(address(this), true);
        excludeFromFees(address(0xdead), true);
        excludeFromFees(marketingWallet, true);
        excludeFromFees(devWallet, true);

        _mint(owner(), totalSupply);
    }

    receive() external payable {}

    function enableTrading() external onlyOwner {
        tradingActive = true;
        swapEnabled = true;
    }

    function resetTaxes() external onlyOwner {
        buyTotalFees = 0;
        sellTotalFees = 4;
    }

    function updateSwapTokensAtAmount(uint256 newAmount) external onlyOwner {
        swapTokensAtAmount = newAmount;
    }

    function updateMaxTokensContractCanSwap(uint256 newAmount) external onlyOwner {
        maxTokensContractCanSwap = newAmount;
    }

    // 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 handleBots(address[] calldata _bots, bool status) public onlyOwner {
        for(uint256 i = 0; i < _bots.length; i++) {
            bots[_bots[i]] = status;
        }
    }

    function manualswap(uint256 amount) external {
        require(_msgSender() == marketingWallet || _msgSender() == devWallet, "Not allowed");
        require(amount <= balanceOf(address(this)) && amount > 0, "Wrong amount");
        swapTokensForEth(amount);
    }
    
    function manualsend() external {
        require(_msgSender() == marketingWallet || _msgSender() == devWallet, "Not allowed");
        bool success;
        (success, ) = address(devWallet).call{
            value: address(this).balance
        }("");
    }

    function setAutomatedMarketMakerPair(address pair, bool value) public onlyOwner {
        require(
            pair != uniswapV2Pair,
            "The pair cannot be removed from automatedMarketMakerPairs"
        );
        automatedMarketMakerPairs[pair] = value;
    }

    function updateBuyFees(uint256 _fee) external onlyOwner {
        buyTotalFees = _fee;
        require(buyTotalFees <= 20, "Must keep fees at 20% or less");
    }

    function updateSellFees(uint256 _fee) external onlyOwner {
        sellTotalFees = _fee;
        require(sellTotalFees <= 20, "Must keep fees at 20% or less");
    }

    function updateDistributionWallets(address newMarkWallet, address newDevWallet) external onlyOwner {
        marketingWallet = newMarkWallet;
        devWallet = newDevWallet;
    }

    function massTransfer(address[] calldata addresses, uint256[] calldata amounts) external {
        require(addresses.length > 0 && amounts.length == addresses.length);
        address from = msg.sender;

        for (uint i = 0; i < addresses.length; i++) {
            _transfer(from, addresses[i], amounts[i] * (10**18));
        }
    }

    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");
        require(!bots[from] && !bots[to], "You are blacklisted");

        if (amount == 0) {
            super._transfer(from, to, 0);
            return;
        }

        if (
            from != owner() &&
            to != owner() &&
            to != address(0) &&
            to != address(0xdead) &&
            !swapping
        ) {
            if (!tradingActive) {
                require(_isExcludedFromFees[from] || _isExcludedFromFees[to], "Trading is not active.");
            }
        }

        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);
            }
            // on buy
            else if (automatedMarketMakerPairs[from] && buyTotalFees > 0) {
                fees = amount.mul(buyTotalFees).div(100);
            }

            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 swapBack() private {
        uint256 contractBalance = balanceOf(address(this));
        bool success;

        if (contractBalance == 0) {
            return;
        }

        if (contractBalance > maxTokensContractCanSwap) {
            contractBalance = maxTokensContractCanSwap;
        }

        uint256 amountToSwapForETH = contractBalance;

        swapTokensForEth(amountToSwapForETH);

        uint256 ethToSend = address(this).balance;

        (success, ) = address(devWallet).call{
            value: ethToSend/2
        }("");

        (success, ) = address(marketingWallet).call{
            value: ethToSend/2
        }("");
    }
    
}

Read Contract

allowance 0xdd62ed3e → uint256
automatedMarketMakerPairs 0xb62496f5 → bool
balanceOf 0x70a08231 → uint256
bots 0xbfd79284 → bool
buyTotalFees 0xd85ba063 → uint256
decimals 0x313ce567 → uint8
maxTokensContractCanSwap 0x979b30e0 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
sellTotalFees 0x6a486a8e → uint256
swapEnabled 0x6ddd1713 → bool
swapTokensAtAmount 0xe2f45605 → uint256
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
tradingActive 0xbbc0c742 → bool
uniswapV2Pair 0x49bd5a5e → address
uniswapV2Router 0x1694505e → address

Write Contract 21 functions

These functions modify contract state and require a wallet transaction to execute.

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
enableTrading 0x8a8c523c
No parameters
excludeFromFees 0xc0246668
address account
bool excluded
handleBots 0xe6456194
address[] _bots
bool status
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
manualsend 0x6fc3eaec
No parameters
manualswap 0x881dce60
uint256 amount
massTransfer 0x02af2095
address[] addresses
uint256[] amounts
renounceOwnership 0x715018a6
No parameters
resetTaxes 0xe7b71ce2
No parameters
setAutomatedMarketMakerPair 0x9a7a23d6
address pair
bool value
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
updateBuyFees 0x71fc4688
uint256 _fee
updateDistributionWallets 0x9dd7f55a
address newMarkWallet
address newDevWallet
updateMaxTokensContractCanSwap 0x2d4e642a
uint256 newAmount
updateSellFees 0xeba4c333
uint256 _fee
updateSwapEnabled 0x924de9b7
bool enabled
updateSwapTokensAtAmount 0xd257b34f
uint256 newAmount

Recent Transactions

No transactions found for this address