ERC721ConsecutiveEnumerableMock.unreachable.sol 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. // SPDX-License-Identifier: MIT
  2. pragma solidity ^0.8.0;
  3. import "../token/ERC721/extensions/ERC721Consecutive.sol";
  4. import "../token/ERC721/extensions/ERC721Enumerable.sol";
  5. contract ERC721ConsecutiveEnumerableMock is ERC721Consecutive, ERC721Enumerable {
  6. constructor(
  7. string memory name,
  8. string memory symbol,
  9. address[] memory receivers,
  10. uint96[] memory amounts
  11. ) ERC721(name, symbol) {
  12. for (uint256 i = 0; i < receivers.length; ++i) {
  13. _mintConsecutive(receivers[i], amounts[i]);
  14. }
  15. }
  16. function supportsInterface(bytes4 interfaceId)
  17. public
  18. view
  19. virtual
  20. override(ERC721, ERC721Enumerable)
  21. returns (bool)
  22. {
  23. return super.supportsInterface(interfaceId);
  24. }
  25. function _ownerOf(uint256 tokenId) internal view virtual override(ERC721, ERC721Consecutive) returns (address) {
  26. return super._ownerOf(tokenId);
  27. }
  28. function _mint(address to, uint256 tokenId) internal virtual override(ERC721, ERC721Consecutive) {
  29. super._mint(to, tokenId);
  30. }
  31. function _beforeTokenTransfer(
  32. address from,
  33. address to,
  34. uint256 tokenId
  35. ) internal virtual override(ERC721, ERC721Enumerable) {
  36. super._beforeTokenTransfer(from, to, tokenId);
  37. }
  38. function _afterTokenTransfer(
  39. address from,
  40. address to,
  41. uint256 tokenId
  42. ) internal virtual override(ERC721, ERC721Consecutive) {
  43. super._afterTokenTransfer(from, to, tokenId);
  44. }
  45. function _beforeConsecutiveTokenTransfer(
  46. address from,
  47. address to,
  48. uint256 first,
  49. uint96 size
  50. ) internal virtual override(ERC721, ERC721Enumerable) {
  51. super._beforeConsecutiveTokenTransfer(from, to, first, size);
  52. }
  53. }