Description:
ERC20 token contract with Factory capabilities. Standard implementation for fungible tokens on Ethereum.
Blockchain: Ethereum
Source Code: View Code On The Blockchain
Solidity Source Code:
{{
"language": "Solidity",
"sources": {
"contracts/Context.sol": {
"content": "// SPDX-License-Identifier: MIT\r
\r
pragma solidity ^0.8.19;\r
\r
/**\r
* @dev Provides information about the current execution context.\r
*/\r
abstract contract Context {\r
function _msgSender() internal view virtual returns (address) {\r
return msg.sender;\r
}\r
\r
function _msgData() internal view virtual returns (bytes calldata) {\r
return msg.data;\r
}\r
}"
},
"contracts/ERC20.sol": {
"content": "// SPDX-License-Identifier: MIT\r
\r
pragma solidity ^0.8.19;\r
\r
import "./Context.sol";\r
import "./IERC20Metadata.sol";\r
\r
/**\r
* @dev Implementation of the ERC20 interface.\r
*/\r
contract ERC20 is Context, IERC20Metadata {\r
mapping(address => uint256) private _balances;\r
mapping(address => mapping(address => uint256)) private _allowances;\r
\r
uint256 private _totalSupply;\r
string private _name;\r
string private _symbol;\r
\r
constructor(string memory name_, string memory symbol_) {\r
_name = name_;\r
_symbol = symbol_;\r
}\r
\r
function name() public view virtual override returns (string memory) {\r
return _name;\r
}\r
\r
function symbol() public view virtual override returns (string memory) {\r
return _symbol;\r
}\r
\r
function decimals() public view virtual override returns (uint8) {\r
return 18;\r
}\r
\r
function totalSupply() public view virtual override returns (uint256) {\r
return _totalSupply;\r
}\r
\r
function balanceOf(address account) public view virtual override returns (uint256) {\r
return _balances[account];\r
}\r
\r
function transfer(address recipient, uint256 amount) public virtual override returns (bool) {\r
address sender = _msgSender();\r
_transfer(sender, recipient, amount);\r
return true;\r
}\r
\r
function allowance(address owner, address spender) public view virtual override returns (uint256) {\r
return _allowances[owner][spender];\r
}\r
\r
function approve(address spender, uint256 amount) public virtual override returns (bool) {\r
address sender = _msgSender();\r
_approve(sender, spender, amount);\r
return true;\r
}\r
\r
function transferFrom(address sender, address recipient, uint256 amount) public virtual override returns (bool) {\r
address caller = _msgSender();\r
_spendAllowance(sender, caller, amount);\r
_transfer(sender, recipient, amount);\r
return true;\r
}\r
\r
function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {\r
address sender = _msgSender();\r
_approve(sender, spender, _allowances[sender][spender] + addedValue);\r
return true;\r
}\r
\r
function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {\r
address sender = _msgSender();\r
uint256 currentAllowance = _allowances[sender][spender];\r
require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");\r
_approve(sender, spender, currentAllowance - subtractedValue);\r
return true;\r
}\r
\r
function _transfer(address sender, address recipient, uint256 amount) internal virtual {\r
require(sender != address(0), "ERC20: transfer from zero address");\r
require(recipient != address(0), "ERC20: transfer to zero address");\r
\r
uint256 senderBalance = _balances[sender];\r
require(senderBalance >= amount, "ERC20: transfer amount exceeds balance");\r
\r
unchecked {\r
_balances[sender] = senderBalance - amount;\r
}\r
\r
_balances[recipient] += amount;\r
emit Transfer(sender, recipient, amount);\r
}\r
\r
function _mint(address account, uint256 amount) internal virtual {\r
require(account != address(0), "ERC20: mint to zero address");\r
\r
_totalSupply += amount;\r
_balances[account] += amount;\r
emit Transfer(address(0), account, amount);\r
}\r
\r
function _approve(address owner, address spender, uint256 amount) internal virtual {\r
require(owner != address(0), "ERC20: approve from zero address");\r
require(spender != address(0), "ERC20: approve to zero address");\r
\r
_allowances[owner][spender] = amount;\r
emit Approval(owner, spender, amount);\r
}\r
\r
function _spendAllowance(address owner, address spender, uint256 amount) internal virtual {\r
uint256 currentAllowance = allowance(owner, spender);\r
if (currentAllowance != type(uint256).max) {\r
require(currentAllowance >= amount, "ERC20: insufficient allowance");\r
unchecked {\r
_approve(owner, spender, currentAllowance - amount);\r
}\r
}\r
}\r
}"
},
"contracts/IERC20.sol": {
"content": "// SPDX-License-Identifier: MIT\r
\r
pragma solidity ^0.8.19;\r
\r
/**\r
* @dev Interface of the ERC20 standard as defined in the EIP.\r
*/\r
interface IERC20 {\r
function totalSupply() external view returns (uint256);\r
function balanceOf(address account) external view returns (uint256);\r
function transfer(address recipient, uint256 amount) external returns (bool);\r
function allowance(address owner, address spender) external view returns (uint256);\r
function approve(address spender, uint256 amount) external returns (bool);\r
function transferFrom(address sender, address recipient, uint256 amount) external returns (bool);\r
\r
event Transfer(address indexed from, address indexed to, uint256 value);\r
event Approval(address indexed owner, address indexed spender, uint256 value);\r
}"
},
"contracts/IERC20Metadata.sol": {
"content": "// SPDX-License-Identifier: MIT\r
\r
pragma solidity ^0.8.19;\r
\r
import "./IERC20.sol";\r
\r
/**\r
* @dev Interface for the optional metadata functions from the ERC20 standard.\r
*/\r
interface IERC20Metadata is IERC20 {\r
function name() external view returns (string memory);\r
function symbol() external view returns (string memory);\r
function decimals() external view returns (uint8);\r
}"
},
"contracts/UbuntuToken.sol": {
"content": "// SPDX-License-Identifier: MIT
pragma solidity ^0.8.19;
import "./ERC20.sol";
/**
* @dev Ubuntu Token Contract
*/
contract UbuntuToken is ERC20 {
constructor() ERC20("Ubuntu", "Ubuntu") {
_mint(msg.sender, 10_000_000_000 * 10 ** decimals());
}
function decimals() public view virtual override returns (uint8) {
return 6;
}
}"
}
},
"settings": {
"optimizer": {
"enabled": true,
"runs": 200
},
"outputSelection": {
"*": {
"*": [
"evm.bytecode",
"evm.deployedBytecode",
"devdoc",
"userdoc",
"metadata",
"abi"
]
}
}
}
}}
Submitted on: 2025-10-27 19:24:21
Comments
Log in to comment.
No comments yet.