* Initial migration to Solidity 0.6.x - v3.0 first steps (#2063) * Initial migration, missing GSN, 721, 777 and Crowdsales. * Add _beforeTokenOperation and _afterTokenOperation. * Add documentation for hooks. * Add hooks doc * Add missing drafts * Add back ERC721 with hooks * Bring back ERC777 * Notes on hooks * Bring back GSN * Make functions virtual * Make GSN overrides explicit * Fix ERC20Pausable tests * Remove virtual from some view functions * Update linter * Delete examples * Remove unnecessary virtual * Remove roles from Pausable * Remove roles * Remove users of roles * Adapt ERC20 tests * Fix ERC721 tests * Add all ERC721 hooks * Add ERC777 hooks * Fix remaining tests * Bump compiler version * Move 721BurnableMock into mocks directory * Remove _before hooks * Fix tests * Upgrade linter * Put modifiers last * Remove _beforeTokenApproval and _beforeOperatorApproval hooks
39 lines
1.4 KiB
Solidity
39 lines
1.4 KiB
Solidity
pragma solidity ^0.6.0;
|
|
|
|
import "../math/SafeMath.sol";
|
|
|
|
/**
|
|
* @title Counters
|
|
* @author Matt Condon (@shrugs)
|
|
* @dev Provides counters that can only be incremented or decremented by one. This can be used e.g. to track the number
|
|
* of elements in a mapping, issuing ERC721 ids, or counting request ids.
|
|
*
|
|
* Include with `using Counters for Counters.Counter;`
|
|
* Since it is not possible to overflow a 256 bit integer with increments of one, `increment` can skip the {SafeMath}
|
|
* overflow check, thereby saving gas. This does assume however correct usage, in that the underlying `_value` is never
|
|
* directly accessed.
|
|
*/
|
|
library Counters {
|
|
using SafeMath for uint256;
|
|
|
|
struct Counter {
|
|
// This variable should never be directly accessed by users of the library: interactions must be restricted to
|
|
// the library's function. As of Solidity v0.5.2, this cannot be enforced, though there is a proposal to add
|
|
// this feature: see https://github.com/ethereum/solidity/issues/4637
|
|
uint256 _value; // default: 0
|
|
}
|
|
|
|
function current(Counter storage counter) internal view returns (uint256) {
|
|
return counter._value;
|
|
}
|
|
|
|
function increment(Counter storage counter) internal {
|
|
// The {SafeMath} overflow check can be skipped here, see the comment at the top
|
|
counter._value += 1;
|
|
}
|
|
|
|
function decrement(Counter storage counter) internal {
|
|
counter._value = counter._value.sub(1);
|
|
}
|
|
}
|