MyTokenTimestampBased.sol 1.2 KB

1234567891011121314151617181920212223242526272829303132
  1. // SPDX-License-Identifier: MIT
  2. pragma solidity ^0.8.24;
  3. import {ERC20} from "../../../token/ERC20/ERC20.sol";
  4. import {ERC20Permit} from "../../../token/ERC20/extensions/ERC20Permit.sol";
  5. import {ERC20Votes} from "../../../token/ERC20/extensions/ERC20Votes.sol";
  6. import {Nonces} from "../../../utils/Nonces.sol";
  7. contract MyTokenTimestampBased is ERC20, ERC20Permit, ERC20Votes {
  8. constructor() ERC20("MyTokenTimestampBased", "MTK") ERC20Permit("MyTokenTimestampBased") {}
  9. // Overrides IERC6372 functions to make the token & governor timestamp-based
  10. function clock() public view override returns (uint48) {
  11. return uint48(block.timestamp);
  12. }
  13. // solhint-disable-next-line func-name-mixedcase
  14. function CLOCK_MODE() public pure override returns (string memory) {
  15. return "mode=timestamp";
  16. }
  17. // The functions below are overrides required by Solidity.
  18. function _update(address from, address to, uint256 amount) internal override(ERC20, ERC20Votes) {
  19. super._update(from, to, amount);
  20. }
  21. function nonces(address owner) public view virtual override(ERC20Permit, Nonces) returns (uint256) {
  22. return super.nonces(owner);
  23. }
  24. }