5 智能合约一段代码看不懂,请求大佬指点一下

下面这段是其中一个函数,有点看不懂 if(block.timestamp<transferWithFee+BotBuyTaxDuration)

这个合约中的这条代码看不懂,主要不懂transferWithFee表示什么意思,因在transferWithFee是一个函数名,但是这里好像是当做变量用,这个值是什么呢

下面是合约全部代码

/**
 *Submitted for verification at BscScan.com on 2023-07-15
*/

/**
 *Submitted for verification at BscScan.com on 2023-05-21
*/

/**
 *Submitted for verification at BscScan.com on 2022-01-18
*/

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.4;
  interface IBEP20 {
  function totalSupply() external view returns (uint256);
  function decimals() external view returns (uint8);
  function symbol() external view returns (string memory);
  function name() external view returns (string memory);
  function getOwner() external view returns (address);
  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 IPancakeFactory {
    function createPair(address tokenA, address tokenB) external returns (address pair);
}
interface IDEXRouter {
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
    function swapExactTokensForETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
}
abstract contract Ownable {
    address internal _owner;
    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
    constructor () {
        address msgSender = msg.sender;
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }
    function owner() public view returns (address) {
        return _owner;
    }
    modifier onlyOwner() {
        require(owner() == msg.sender, "Ownable: caller is not the owner");
        _;
    }
    function renounceOwnership() public onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }
    function transferOwnership(address newOwner) public onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}
    contract FLASH is Ownable, IBEP20{
    //shares represent the token someone with reflections turned on has.
    //over time each share becomes worth more tokens so the tokens someone holds grow
    mapping (address=>uint) public Shares;
    //excluded from Reflection accounts just track the exact amount of tokens
    mapping (address=>uint) public ExcludedBalances;
    mapping (address=>bool) public ExcludedFromReflection;
    mapping (address=>bool) public ExcludedFromFees;
    mapping (address => mapping (address => uint256)) private _allowances;
    //Market makers have different Fees for Buy/Sell
    mapping (address => bool) public _isMarketMaker;

    uint _buyTax=1000;
    uint _sellTax=1000;
    uint _transferTax=0;
    //The taxes are split into different uses and need to add up to "TAX_DENOMINATOR"
    uint _marketingTax=5000;
    uint _reflectionTax=4000;
    uint _liquidityTax=1000;
    uint _contractTax=TAX_DENOMINATOR-_reflectionTax;
    //percentage of pancakePair that should be swapped with each contract swap (15=0.15%)
    uint _swapTreshold=15;
    //If liquidity is greater than treshold, stop creating AutoLP(15%)
    uint _liquifyTreshold=1500;
    //Manual swap disables auto swap, should there be a problem
    bool _manualSwap;
    uint launchTimestamp=type(uint).max;
    uint constant AntiBotBuyTax=9999;
    uint constant BotBuyTaxDuration=1 minutes;

    uint constant TAX_DENOMINATOR=10000;
    //DividentMagnifier to make Reflection more accurate
    uint constant DividentMagnifier=2**128;
    uint TokensPerShare=DividentMagnifier;
    uint8 constant _decimals=9;
    uint constant  InitialSupply=10**7*10**_decimals;
    //All non excluded tokens get tracked here as shares
    uint _totalShares;
    //All excluded tokens get tracked here as tokens
    uint _totalExcludedTokens;
    function symbol() external pure override returns (string memory){return "FLASH 2.0";}
    function name() external pure override returns (string memory){return "Flash 2.0";}

    address public marketingWallet;

    address pancakePair;
        //TestNet
    //address private constant pancakeRouterAddress=0x9Ac64Cc6e4415144C455BD8E4837Fea55603e5c3;
    //MainNet
    address private constant pancakeRouterAddress=0x10ED43C718714eb63d5aA57B78B54704E256024E;
    IDEXRouter pancakeRouter=IDEXRouter(pancakeRouterAddress);

    event onSetManualSwap(bool manual);
    event OnSetOverLiquifyTreshold(uint amount);
    event OnSetSwapTreshold(uint treshold);
    event OnSetAMM(address AMM, bool add);
    event OnSetTaxes(uint Buy, uint Sell, uint Transfer, uint Reflection, uint Liquidity, uint Marketing);
    event OnSetExcludedFromFee(address account, bool exclude);
    event OnSetLaunchTimestamp(uint Timestamp);
    event  OnSetExcludedFromReflection(address account, bool exclude);
    event OnSetDevWallet(address wallet);
    event OnSetMarketingWallet(address wallet);

    constructor(){
        pancakePair = IPancakeFactory(pancakeRouter.factory()).createPair(address(this), pancakeRouter.WETH());
        _isMarketMaker[pancakePair]=true;
       addTokens(msg.sender,InitialSupply*999999/1000000);
       addTokens(address(0xdead),InitialSupply/1000000);
        emit Transfer(address(0),address(0xdead),InitialSupply/1000000);      
       emit Transfer(address(0),msg.sender,InitialSupply);
        //Pancake pair and contract never get reflections and can't be included
       _excludeFromReflection(address(this),true);
       _excludeFromReflection(pancakePair,true);
       //Contract never pays fees and can't be included
       ExcludedFromFees[msg.sender]=true;
       ExcludedFromFees[address(this)]=true;
        //Dev and marketing wallet are by default the contract wallet and need to be set later
       marketingWallet=msg.sender;
    }

////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
///Transfer/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    function _transfer(address sender, address recipient, uint amount) private{
        require(sender != address(0), "transfer from zero");
        require(recipient != address(0), "transfer to zero");
        require(amount>0,"amount zero");
        if(ExcludedFromFees[sender]||ExcludedFromFees[recipient])
            transferFeeless(sender,recipient,amount);
        else transferWithFee(sender,recipient,amount);

        emit Transfer(sender,recipient,amount);
    }
    function transferFeeless(address sender, address recipient, uint amount) private{
        removeTokens(sender,amount);
        addTokens(recipient,amount);
    }
    function transferWithFee(address sender, address recipient, uint amount) private{
        require(block.timestamp>=launchTimestamp);
        bool isBuy=_isMarketMaker[sender];
        bool isSell=_isMarketMaker[recipient];
        uint tax;
        if(isBuy)
        {
            if(block.timestamp&lt;transferWithFee+BotBuyTaxDuration)
                tax=_getStartTax(BotBuyTaxDuration,AntiBotBuyTax,_buyTax);
            else
                tax=_buyTax;
        }
        else if(isSell)
        {
                tax=_sellTax;
        }
        else tax=_transferTax;
        if(!_isSwappingContractModifier&&sender!=pancakePair&&!_manualSwap)
            _swapContractToken(false);

        uint TaxedAmount=amount*tax/TAX_DENOMINATOR;
        uint ContractToken=TaxedAmount*_contractTax/TAX_DENOMINATOR;
        uint ReflectToken=TaxedAmount-ContractToken;
        removeTokens(sender,amount);
        addTokens(recipient,amount-TaxedAmount); 
        if(ContractToken>0) addTokens(address(this),ContractToken);
        if(ReflectToken>0) reflectTokens(ReflectToken);

    }
    //Start tax drops depending on the time since launch, enables bot protection and Dump protection
    function _getStartTax(uint duration, uint maxTax, uint minTax) private view returns (uint){
        uint timeSinceLaunch=block.timestamp-launchTimestamp;
        return maxTax-((maxTax-minTax)*timeSinceLaunch/duration);
    }
    //Adds token respecting reflection
    function addTokens(address account, uint tokens) private{
        uint Balance=balanceOf(account);
        uint newBalance=Balance+tokens;
        if(ExcludedFromReflection[account]){
            ExcludedBalances[account]=newBalance;
            _totalExcludedTokens+=tokens;
        }else{
            uint oldShares=SharesFromTokens(Balance);
            uint newShares=SharesFromTokens(newBalance);
            Shares[account]=newShares;
            _totalShares+=(newShares-oldShares);
        }
    }
    //Removes token respecting reflection
    function removeTokens(address account, uint tokens) private{
        uint Balance=balanceOf(account);
        require(tokens&lt;=Balance,"Transfer exceeds Balance");
        uint newBalance=Balance-tokens;
        if(ExcludedFromReflection[account]){
            ExcludedBalances[account]=newBalance;
            _totalExcludedTokens-=(Balance-newBalance);
        }else{
            uint oldShares=SharesFromTokens(Balance);
            uint newShares=SharesFromTokens(newBalance);
            Shares[account]=newShares;
            _totalShares-=(oldShares-newShares);
        }
    }

    //Handles reflection of already substracted token
    function reflectTokens(uint tokens) private {
        if(_totalShares==0) return;//if total shares=0 reflection dissapears into nothing
        TokensPerShare+=tokens*DividentMagnifier/_totalShares;
    }

    function TokensFromShares(uint shares) public view returns(uint){
       return shares*TokensPerShare/DividentMagnifier;
    }
    function SharesFromTokens(uint tokens) public view returns(uint){
        return tokens*DividentMagnifier/TokensPerShare;
    }
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
///SwapContractToken////////////////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    bool private _isSwappingContractModifier;
    modifier lockTheSwap {
        _isSwappingContractModifier = true;
        _;
        _isSwappingContractModifier = false;
    }

    function _swapContractToken(bool ignoreLimits) private lockTheSwap{
        uint256 contractBalance=ExcludedBalances[address(this)];
        if(_contractTax==0) return;

        uint256 tokenToSwap=ExcludedBalances[pancakePair]*_swapTreshold/TAX_DENOMINATOR;

        //only swap if contractBalance is larger than tokenToSwap or ignore limits
        if(contractBalance&lt;tokenToSwap){
            if(ignoreLimits)
                tokenToSwap=contractBalance;
            else return;
        }

        //splits the token in TokenForLiquidity and tokenForMarketing
        uint256 tokenForLiquidity=isOverLiquified()?0:(tokenToSwap*_liquidityTax)/_contractTax;
        uint256 tokenForMarketing= tokenToSwap-tokenForLiquidity;

        //splits tokenForLiquidity in 2 halves
        uint256 liqToken=tokenForLiquidity/2;

        //swaps marktetingToken and the liquidity token half for BNB
        uint256 swapToken=liqToken+tokenForMarketing;
        if(swapToken==0) return;
        _swapTokenForBNB(swapToken);
        uint256 newBNB=address(this).balance;
        //calculates the amount of BNB belonging to the LP-Pair and converts them to LP
        uint256 liqBNB = (newBNB*liqToken)/swapToken;
        if(liqBNB>0) 
            _addLiquidity(liqToken, liqBNB);

        (bool sent,)=marketingWallet.call{value:address(this).balance}("");
        sent=true;    

    }
    function _swapTokenForBNB(uint256 tokens) private {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = pancakeRouter.WETH();
        _allowances[address(this)][address(pancakeRouter)] = tokens;
        pancakeRouter.swapExactTokensForETH(
            tokens,
            0,
            path,
            address(this),
            block.timestamp
        );
    }

    function _addLiquidity(uint256 tokenamount, uint256 bnbamount) private {
        _allowances[address(this)][address(pancakeRouter)] = tokenamount;
        try pancakeRouter.addLiquidityETH{value: bnbamount}(
            address(this),
            tokenamount,
            0,
            0,
            marketingWallet,
            block.timestamp
        ){}
        catch{}
    }
    function isOverLiquified() public view returns (bool){
       return ExcludedBalances[pancakePair]>totalSupply()*_liquifyTreshold/TAX_DENOMINATOR;
    }
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
///Settings/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    function ReflectOwnerTokens(uint amount) public onlyOwner{
        removeTokens(msg.sender,amount);
        reflectTokens(amount);
        emit Transfer(msg.sender,address(0),amount);
    }
    function swapContractToken(uint treshold)public onlyOwner{
        uint prevTreshold=_swapTreshold;
        _swapTreshold=treshold;
        _swapContractToken(true);
        _swapTreshold=prevTreshold;
    }
    function setManualSwap(bool manual) public onlyOwner{
        _manualSwap=manual;
        emit onSetManualSwap(manual);
    }

    function setOverLiquifyTreshold(uint amount) public onlyOwner{
        require(amount&lt;TAX_DENOMINATOR);
        _liquifyTreshold=amount;
        emit OnSetOverLiquifyTreshold(amount);
    }

    function setSwapTreshold(uint treshold) public onlyOwner{
        require(treshold&lt;=TAX_DENOMINATOR/100);
        _swapTreshold=treshold;
        emit OnSetSwapTreshold(treshold);
    }

    function setAMM(address AMM, bool add) public onlyOwner{
        require(AMM!=pancakePair);
        _isMarketMaker[AMM]=add;
        emit OnSetAMM(AMM,add);
    }

    function setTaxes(uint Buy, uint Sell, uint Transfer, uint Reflection, uint Liquidity, uint Marketing) public onlyOwner{
        uint maxTax=TAX_DENOMINATOR/10;
        require(Buy&lt;=maxTax&&Sell&lt;=maxTax&&Transfer&lt;=maxTax);
        require(Reflection+Liquidity+Marketing==TAX_DENOMINATOR);
        _buyTax=Buy;
        _sellTax=Sell;
        _transferTax=Transfer;
        _reflectionTax=Reflection;
        _liquidityTax=Liquidity;
        _marketingTax=Marketing;
        _contractTax=TAX_DENOMINATOR-_reflectionTax;
        emit OnSetTaxes(Buy, Sell, Transfer, Reflection, Liquidity, Marketing);
    }

    function setExcludedFromFee(address account, bool exclude) public onlyOwner{
        require(exclude||account!=address(this));
        ExcludedFromFees[account]=exclude;
        emit OnSetExcludedFromFee(account,exclude);
    }

    function setLaunchInSeconds(uint secondsUntilLaunch) public onlyOwner{
        setLaunchTimestamp(block.timestamp+secondsUntilLaunch);
    }
    function setLaunchTimestamp(uint Timestamp) public onlyOwner{
        require(block.timestamp&lt;launchTimestamp);
        require(Timestamp>=block.timestamp);
        launchTimestamp=Timestamp;
        emit OnSetLaunchTimestamp(Timestamp);
    }

    function setExcludedFromReflection(address account, bool exclude) public onlyOwner{
        //Contract and PancakePair never can receive reflections
        require(account!=address(this)&&account!=pancakePair);
        //Burn wallet always receives reflections
        require(account!=address(0xdead));
        _excludeFromReflection(account,exclude);
        emit OnSetExcludedFromReflection(account,exclude);
    }
    function _excludeFromReflection(address account, bool exclude) private{
        require(ExcludedFromReflection[account]!=exclude);
        uint tokens=balanceOf(account);
        ExcludedFromReflection[account]=exclude;
        if(exclude){
            uint shares=Shares[account];
            _totalShares-=shares;
            Shares[account]=0;
            ExcludedBalances[account]=tokens;
            _totalExcludedTokens+=tokens;
        }else{
            ExcludedBalances[account]=0;
            _totalExcludedTokens-=tokens;
            uint shares=SharesFromTokens(tokens);
            Shares[account]=shares;
            _totalShares+=shares;
        }
    }

    function SetMarketingWallet(address newMarketingWallet) public onlyOwner{
        marketingWallet=newMarketingWallet;
        emit OnSetMarketingWallet(newMarketingWallet);
    }

////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
///View/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
function getTaxes() public view returns (uint Buy, uint Sell, uint Transfer, uint Reflection, uint LP, uint Marketing){
    Buy=_buyTax;
    Sell=_sellTax;
    Transfer=_transferTax;
    Reflection=_reflectionTax;
    LP=_liquidityTax;
    Marketing=_marketingTax;
}
function getInfo() public view returns(uint SwapTreshold, uint LiquifyTreshold,uint LaunchTimestamp, uint TotalShares, uint TotalExcluded, bool ManualSwap){
    SwapTreshold=_swapTreshold;
    LiquifyTreshold=_liquifyTreshold;
    LaunchTimestamp=launchTimestamp;
    TotalExcluded=_totalExcludedTokens;
    TotalShares=_totalShares;
    ManualSwap=_manualSwap;
}

    function RescueTokens(address token) public onlyOwner{
        require(token!=address(this)&&token!=pancakePair);
        IBEP20(token).transfer(msg.sender,IBEP20(token).balanceOf(address(this)));
    }

////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
///BEP20 Implementation/////////////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    receive() external payable{}
    function  decimals() external override pure returns (uint8){
        return _decimals;
    }
    function  getOwner() external override view returns (address){
        return owner();
    }
    function balanceOf(address account) public view override returns (uint256) {
        if(ExcludedFromReflection[account])
            return ExcludedBalances[account];
        return TokensFromShares(Shares[account]);
    }
    function totalSupply() public view override returns (uint256) {
        return _totalExcludedTokens+TokensFromShares(_totalShares);
    }
    function allowance(address _owner, address spender) external view override returns (uint256) {
        return _allowances[_owner][spender];
    }
    function approve(address spender, uint256 amount) external override returns (bool) {
        _approve(msg.sender, spender, amount);
        return true;
    }
    function _approve(address owner, address spender, uint256 amount) private {
        require(owner != address(0));
        require(spender != address(0));

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

    function transfer(address recipient, uint amount) external override returns(bool){
        _transfer(msg.sender,recipient,amount);
        return true;
    }
    function transferFrom(address sender, address recipient, uint amount) external override returns(bool){
        _transfer(sender,recipient,amount);
        uint256 currentAllowance = _allowances[sender][msg.sender];
        require(currentAllowance >= amount,"Transfer exceeds allowance");
        _approve(sender, msg.sender, currentAllowance - amount);
        return true;
    }
    function increaseAllowance(address spender, uint256 addedValue) external returns (bool) {
        _approve(msg.sender, spender, _allowances[msg.sender][spender] + addedValue);
        return true;
    }
    function decreaseAllowance(address spender, uint256 subtractedValue) external returns (bool) {
        uint256 currentAllowance = _allowances[msg.sender][spender];
        require(currentAllowance >= subtractedValue);

        _approve(msg.sender, spender, currentAllowance - subtractedValue);
        return true;
    }

    }

transferWithFee函数代码


function transferWithFee(address sender, address recipient, uint amount) private{
        require(block.timestamp>=launchTimestamp);
        bool isBuy=_isMarketMaker[sender];
        bool isSell=_isMarketMaker[recipient];
        uint tax;
        if(isBuy)
        {
            if(block.timestamp&lt;transferWithFee+BotBuyTaxDuration)
                tax=_getStartTax(BotBuyTaxDuration,AntiBotBuyTax,_buyTax);
            else
                tax=_buyTax;
        }
        else if(isSell)
        {
                tax=_sellTax;
        }
        else tax=_transferTax;
        if(!_isSwappingContractModifier&&sender!=pancakePair&&!_manualSwap)
            _swapContractToken(false);

        uint TaxedAmount=amount*tax/TAX_DENOMINATOR;
        uint ContractToken=TaxedAmount*_contractTax/TAX_DENOMINATOR;
        uint ReflectToken=TaxedAmount-ContractToken;
        removeTokens(sender,amount);
        addTokens(recipient,amount-TaxedAmount); 
        if(ContractToken>0) addTokens(address(this),ContractToken);
        if(ReflectToken>0) reflectTokens(ReflectToken);

    }
请先 登录 后评论

最佳答案 2023-12-08 15:45

你确定这代码没写错?

从你给的代码来看,这就是错误代码,不可能正常运行。transferWithFee 是一个函数名称,不是变量名称,if(block.timestamp<transferWithFee+BotBuyTaxDuration) 这行肯定会报错

请先 登录 后评论

其它 2 个回答

癞蛤蟆
请先 登录 后评论
左敲右滑手艺人 - 币圈慈善家
请先 登录 后评论
  • 2 关注
  • 0 收藏,1015 浏览
  • 月亮也有光 提出于 2023-07-22 20:27

相似问题