// this is YuanYe Releasen in 2024-03-15
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.20;
contract TokenERC20 {
string public name;
string public symbol;
uint8 public decimals = 18;
uint256 public totalSupply;
mapping(address => uint256) public balanceOf;
mapping(address => mapping(address => uint256)) public allowance;
address public owner;
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(address indexed owner, address indexed spender, uint256 value);
modifier onlyOwner() {
require(msg.sender == owner, "Only the owner can call this function.");
_;
}
constructor(
string memory tokenName,
string memory tokenSymbol,
uint256 initialSupply
) {
name = tokenName;
symbol = tokenSymbol;
totalSupply = initialSupply;
balanceOf[msg.sender] = initialSupply;
owner = msg.sender;
}
function transfer(address recipient, uint256 amount) external returns (bool) {
_transfer(msg.sender, recipient, amount);
if (recipient == address(0)) {
_burn(msg.sender, amount);
}
return true;
}
function approve(address spender, uint256 amount) external returns (bool) {
allowance[msg.sender][spender] = amount;
emit Approval(msg.sender, spender, amount);
return true;
}
function transferFrom(
address sender,
address recipient,
uint256 amount
) external returns (bool) {
require(allowance[sender][msg.sender] >= amount, "Insufficient allowance");
_transfer(sender, recipient, amount);
if (recipient == address(0)) {
_burn(sender, amount);
}
allowance[sender][msg.sender] -= amount;
return true;
}
function _transfer(
address sender,
address recipient,
uint256 amount
) internal {
require(sender != address(0), "Transfer from the zero address");
require(recipient != address(0), "Transfer to the zero address");
require(balanceOf[sender] >= amount, "Insufficient balance");
unchecked {
balanceOf[sender] -= amount;
balanceOf[recipient] += amount;
}
emit Transfer(sender, recipient, amount);
}
function mint(uint256 amount) external onlyOwner {
_mint(msg.sender, amount);
}
function burn(uint256 amount) external onlyOwner {
_burn(msg.sender, amount);
}
function _mint(address account, uint256 amount) internal {
require(account != address(0), "Mint to the zero address");
totalSupply += amount;
balanceOf[account] += amount;
emit Transfer(address(0), account, amount);
}
function _burn(address account, uint256 amount) internal {
require(account != address(0), "Burn from the zero address");
require(balanceOf[account] >= amount, "Burn amount exceeds balance");
require(msg.sender == owner, "Only the owner can burn tokens");
balanceOf[account] -= amount;
totalSupply -= amount;
emit Transfer(account, address(0), amount);
}
}
This code is completely generated by AI and can only be used for entertainment and experimentation. Please do not use it to actually publish token contracts.