ERC20SnapshotMockUpgradeable.sol 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. // SPDX-License-Identifier: MIT
  2. pragma solidity ^0.8.0;
  3. import "../token/ERC20/extensions/ERC20SnapshotUpgradeable.sol";
  4. import "../proxy/utils/Initializable.sol";
  5. contract ERC20SnapshotMockUpgradeable is Initializable, ERC20SnapshotUpgradeable {
  6. function __ERC20SnapshotMock_init(
  7. string memory name,
  8. string memory symbol,
  9. address initialAccount,
  10. uint256 initialBalance
  11. ) internal onlyInitializing {
  12. __ERC20_init_unchained(name, symbol);
  13. __ERC20SnapshotMock_init_unchained(name, symbol, initialAccount, initialBalance);
  14. }
  15. function __ERC20SnapshotMock_init_unchained(
  16. string memory,
  17. string memory,
  18. address initialAccount,
  19. uint256 initialBalance
  20. ) internal onlyInitializing {
  21. _mint(initialAccount, initialBalance);
  22. }
  23. function snapshot() public {
  24. _snapshot();
  25. }
  26. function mint(address account, uint256 amount) public {
  27. _mint(account, amount);
  28. }
  29. function burn(address account, uint256 amount) public {
  30. _burn(account, amount);
  31. }
  32. /**
  33. * @dev This empty reserved space is put in place to allow future versions to add new
  34. * variables without shifting down storage in the inheritance chain.
  35. * See https://docs.openzeppelin.com/contracts/4.x/upgradeable#storage_gaps
  36. */
  37. uint256[50] private __gap;
  38. }