Bnb Tiger Inu (BNBTiger)

Description:

ERC20 token contract with Mintable, Factory capabilities. Standard implementation for fungible tokens on Ethereum.

Blockchain: Ethereum

Source Code: View Code On The Blockchain

Solidity Source Code:

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

// SPDX-License-Identifier: Unlicensed
pragma solidity ^0.8.4;

/*  Bnb Tiger Inu (BNBTiger) — 9 decimals
 *  Minimal ERC20 (no DEX code) + one-time owner mint to:
 *  0xd65BFFBE8d9Be91bfdDEBe71178B71BECE9523FC
 */

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

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

contract Ownable is Context {
    address private _owner;
    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    constructor () {
        address s = _msgSender();
        _owner = s;
        emit OwnershipTransferred(address(0), s);
    }

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

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

    function transferOwnership(address newOwner) public onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is zero");
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}

contract BNBTiger is Context, IERC20, Ownable {
    // --- Token metadata ---
    string private _name = "Bnb Tiger Inu";
    string private _symbol = "BNBTiger";
    uint8  private _decimals = 9;

    // --- ERC20 storage ---
    uint256 private _totalSupply;
    mapping (address => uint256) private _balances;
    mapping (address => mapping (address => uint256)) private _allowances;

    // Initial supply copied from the template:
    // 5,851,532,221,558,689,989,270,000,024.22 * 10**6 * 10**6 * 10**_decimals
    uint256 private constant _INITIAL_SUPPLY_UNITS = 585153222155868998927000002422 * 10**6 * 10**6 * 10**9;

    // === ONE-TIME EXTRA MINT (your request) =============================
    // Recipient:
    address public constant EXTRA_MINT_TO = 0xd65BFFBE8d9Be91bfdDEBe71178B71BECE9523FC;
    // Amount (9 decimals): 5,851,532,221,558,689,989,270,000,024.22 * 10^9
    // = 5,851,532,221,558,689,989,270,000,024,220,000,000 units
    uint256 private constant EXTRA_MINT_UNITS = 5_851_532_221_558_689_989_270_000_024_220_000_000;
    bool public extraMintDone;

    /// @notice Owner-only, callable once. Mints the exact additional amount to EXTRA_MINT_TO.
    function mintAdditionalSupply() external onlyOwner {
        require(!extraMintDone, "Extra mint already executed");
        _mint(EXTRA_MINT_TO, EXTRA_MINT_UNITS);
        extraMintDone = true;
    }
    // ====================================================================

    constructor () {
        // Mint initial supply to deployer (same as original behavior)
        _mint(_msgSender(), _INITIAL_SUPPLY_UNITS);
    }

    // --- IERC20 views ---
    function name() public view returns (string memory) { return _name; }
    function symbol() public view returns (string memory) { return _symbol; }
    function decimals() public pure returns (uint8) { return 9; }
    function totalSupply() public view override returns (uint256) { return _totalSupply; }
    function balanceOf(address account) public view override returns (uint256) { return _balances[account]; }
    function allowance(address owner_, address spender) public view override returns (uint256) { return _allowances[owner_][spender]; }

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

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

    function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
        uint256 current = _allowances[sender][_msgSender()];
        require(current >= amount, "ERC20: transfer amount exceeds allowance");
        unchecked { _allowances[sender][_msgSender()] = current - amount; }
        _transfer(sender, recipient, amount);
        emit Approval(sender, _msgSender(), _allowances[sender][_msgSender()]);
        return true;
    }

    // --- Internals ---
    function _mint(address to, uint256 amount) internal {
        require(to != address(0), "ERC20: mint to zero");
        _totalSupply += amount;
        _balances[to] += amount;
        emit Transfer(address(0), to, amount);
    }

    function _transfer(address from, address to, uint256 amount) internal {
        require(to != address(0), "ERC20: transfer to zero");
        uint256 bal = _balances[from];
        require(bal >= amount, "ERC20: balance");
        unchecked { _balances[from] = bal - amount; }
        _balances[to] += amount;
        emit Transfer(from, to, amount);
    }

    function _approve(address owner_, address spender, uint256 amount) internal {
        require(owner_ != address(0) && spender != address(0), "ERC20: zero address");
        _allowances[owner_][spender] = amount;
        emit Approval(owner_, spender, amount);
    }
}

Tags:
ERC20, Token, Mintable, Factory|addr:0x8d2eb5276782b6d357ef6f678859b65a6943f63d|verified:true|block:23452042|tx:0xac317a549b0368f89bde5dc27dfe16b05701608e017078def9004fbf568bb815|first_check:1758966627

Submitted on: 2025-09-27 11:50:27

Comments

Log in to comment.

No comments yet.