2023-01-10 14:16:32 +01:00
|
|
|
// SPDX-License-Identifier: MIT
|
2024-01-23 10:24:02 +01:00
|
|
|
pragma solidity 0.8.23;
|
2023-01-10 14:16:32 +01:00
|
|
|
|
|
|
|
contract Periods {
|
|
|
|
type Period is uint256;
|
|
|
|
|
2023-01-23 11:57:10 +01:00
|
|
|
uint256 internal immutable _secondsPerPeriod;
|
2023-01-10 14:16:32 +01:00
|
|
|
|
2023-01-23 11:57:10 +01:00
|
|
|
constructor(uint256 secondsPerPeriod) {
|
|
|
|
_secondsPerPeriod = secondsPerPeriod;
|
2023-01-10 14:16:32 +01:00
|
|
|
}
|
|
|
|
|
2023-01-19 16:47:29 +01:00
|
|
|
function _periodOf(uint256 timestamp) internal view returns (Period) {
|
2023-01-23 11:57:10 +01:00
|
|
|
return Period.wrap(timestamp / _secondsPerPeriod);
|
2023-01-10 14:16:32 +01:00
|
|
|
}
|
|
|
|
|
2023-01-19 16:47:29 +01:00
|
|
|
function _blockPeriod() internal view returns (Period) {
|
|
|
|
return _periodOf(block.timestamp);
|
2023-01-10 14:16:32 +01:00
|
|
|
}
|
|
|
|
|
2023-01-19 16:47:29 +01:00
|
|
|
function _nextPeriod(Period period) internal pure returns (Period) {
|
2023-01-10 14:16:32 +01:00
|
|
|
return Period.wrap(Period.unwrap(period) + 1);
|
|
|
|
}
|
|
|
|
|
2023-01-19 16:47:29 +01:00
|
|
|
function _periodStart(Period period) internal view returns (uint256) {
|
2023-01-23 11:57:10 +01:00
|
|
|
return Period.unwrap(period) * _secondsPerPeriod;
|
2023-01-10 14:16:32 +01:00
|
|
|
}
|
|
|
|
|
2023-01-19 16:47:29 +01:00
|
|
|
function _periodEnd(Period period) internal view returns (uint256) {
|
|
|
|
return _periodStart(_nextPeriod(period));
|
2023-01-10 14:16:32 +01:00
|
|
|
}
|
|
|
|
|
2023-01-19 16:47:29 +01:00
|
|
|
function _isBefore(Period a, Period b) internal pure returns (bool) {
|
2023-01-10 14:16:32 +01:00
|
|
|
return Period.unwrap(a) < Period.unwrap(b);
|
|
|
|
}
|
|
|
|
|
2023-01-19 16:47:29 +01:00
|
|
|
function _isAfter(Period a, Period b) internal pure returns (bool) {
|
|
|
|
return _isBefore(b, a);
|
2023-01-10 14:16:32 +01:00
|
|
|
}
|
|
|
|
}
|