uint256) public balanceOf; mapping(address => mapping(address => uint256)) public allowance; function transfer(address to, uint256 value) external returns (bool){ return _transfer(msg.sender, to, value); } function transferFrom(address from, address to, uint256 value) external returns (bool){ require(allowance[from][msg.sender] >= value,"ERC20: Insufficient allowance"); allowance[from][msg.sender] -= value; return _transfer(from, to, value); } function _transfer(address from, address to , uint256 value) p"> uint256) public balanceOf; mapping(address => mapping(address => uint256)) public allowance; function transfer(address to, uint256 value) external returns (bool){ return _transfer(msg.sender, to, value); } function transferFrom(address from, address to, uint256 value) external returns (bool){ require(allowance[from][msg.sender] >= value,"ERC20: Insufficient allowance"); allowance[from][msg.sender] -= value; return _transfer(from, to, value); } function _transfer(address from, address to , uint256 value) p"> uint256) public balanceOf; mapping(address => mapping(address => uint256)) public allowance; function transfer(address to, uint256 value) external returns (bool){ return _transfer(msg.sender, to, value); } function transferFrom(address from, address to, uint256 value) external returns (bool){ require(allowance[from][msg.sender] >= value,"ERC20: Insufficient allowance"); allowance[from][msg.sender] -= value; return _transfer(from, to, value); } function _transfer(address from, address to , uint256 value) p">
// SPDX-License-Identifier: MIT
pragma solidity 0.8.30;
contract ERC20{
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(address indexed owner, address indexed spender, uint256 value);
string constant public name = "MyTokenName";
string constant public symbol = "MTN";
uint8 constant public decimals = 18;
uint256 public totalSupply;
mapping( address => uint256) public balanceOf;
mapping(address => mapping(address => uint256)) public allowance;
function transfer(address to, uint256 value) external returns (bool){
return _transfer(msg.sender, to, value);
}
function transferFrom(address from, address to, uint256 value) external returns (bool){
require(allowance[from][msg.sender] >= value,"ERC20: Insufficient allowance");
allowance[from][msg.sender] -= value;
return _transfer(from, to, value);
}
function _transfer(address from, address to , uint256 value) private returns (bool){
require(balanceOf[msg.sender] >= value,"ERC20: Insufficient Token Balance");
emit Transfer(from, to, value);
balanceOf[from] -= value;
balanceOf[to] += value;
return true;
}
function approve(address spender, uint256 value) external returns (bool){
allowance[msg.sender][spender] += value;
emit Approval(msg.sender, spender, allowance[msg.sender][spender]);
return true;
}
}