123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- // SPDX-License-Identifier: MIT
- pragma solidity >=0.6.0 <0.8.0;
- import "./ERC20.sol";
- /**
- * @dev Extension of {ERC20} that adds a cap to the supply of tokens.
- */
- abstract contract ERC20Capped is ERC20 {
- using SafeMath for uint256;
- uint256 private _cap;
- /**
- * @dev Sets the value of the `cap`. This value is immutable, it can only be
- * set once during construction.
- */
- constructor (uint256 cap_) internal {
- require(cap_ > 0, "ERC20Capped: cap is 0");
- _cap = cap_;
- }
- /**
- * @dev Returns the cap on the token's total supply.
- */
- function cap() public view returns (uint256) {
- return _cap;
- }
- /**
- * @dev See {ERC20-_beforeTokenTransfer}.
- *
- * Requirements:
- *
- * - minted tokens must not cause the total supply to go over the cap.
- */
- function _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual override {
- super._beforeTokenTransfer(from, to, amount);
- if (from == address(0)) { // When minting tokens
- require(totalSupply().add(amount) <= _cap, "ERC20Capped: cap exceeded");
- }
- }
- }
|