2020-03-22 01:45:04 +02:00
|
|
|
#pragma once
|
2016-03-25 14:28:07 +02:00
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
2021-01-30 08:51:39 +02:00
|
|
|
#include "Core/Common.hpp"
|
2016-03-25 14:28:07 +02:00
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
namespace SqMod {
|
|
|
|
|
2016-06-04 19:17:42 +03:00
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
class Date;
|
|
|
|
class Time;
|
|
|
|
class Datetime;
|
|
|
|
class Timer;
|
|
|
|
class Timestamp;
|
2016-03-25 14:28:07 +02:00
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
2016-06-04 19:17:42 +03:00
|
|
|
* Class that offers helpers to work with time related information.
|
2016-03-25 14:28:07 +02:00
|
|
|
*/
|
2016-06-04 19:17:42 +03:00
|
|
|
class Chrono
|
|
|
|
{
|
|
|
|
public:
|
2016-03-25 14:28:07 +02:00
|
|
|
|
2016-06-04 19:17:42 +03:00
|
|
|
// ------------------------------------------------------------------------------------------------
|
2021-01-30 08:51:39 +02:00
|
|
|
static const uint8_t MonthLengths[12];
|
2016-06-04 19:17:42 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Default constructor. (disabled)
|
|
|
|
*/
|
|
|
|
Chrono() = delete;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Copy constructor. (disabled)
|
|
|
|
*/
|
|
|
|
Chrono(const Chrono & o) = delete;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Move constructor. (disabled)
|
|
|
|
*/
|
|
|
|
Chrono(Chrono && o) = delete;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Destructor. (disabled)
|
|
|
|
*/
|
|
|
|
~Chrono() = delete;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Copy assignment operator. (disabled)
|
|
|
|
*/
|
|
|
|
Chrono & operator = (const Chrono & o) = delete;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Move assignment operator. (disabled)
|
|
|
|
*/
|
|
|
|
Chrono & operator = (Chrono && o) = delete;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the current time as microseconds.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
static int64_t GetCurrentSysTime();
|
2016-06-04 19:17:42 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the epoch time as microseconds.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
static int64_t GetEpochTimeMicro();
|
2016-06-04 19:17:42 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the epoch time as milliseconds.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
static int64_t GetEpochTimeMilli();
|
2016-06-04 19:17:42 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* See whether the specified date is valid.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
static bool ValidDate(uint16_t year, uint8_t month, uint8_t day);
|
2016-06-04 19:17:42 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* See whether the specified year is a leap year.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
static bool IsLeapYear(uint16_t year)
|
2016-06-04 19:17:42 +03:00
|
|
|
{
|
|
|
|
return !(year % 400) || (!(year % 4) && (year % 100));
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* retrieve the number of days in the specified year.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
static uint16_t DaysInYear(uint16_t year)
|
2016-06-04 19:17:42 +03:00
|
|
|
{
|
|
|
|
return IsLeapYear(year) ? 366 : 365;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the number of days in the specified month.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
static uint8_t DaysInMonth(uint16_t year, uint8_t month);
|
2016-06-04 19:17:42 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the number/position of the specified day in the specified year and month.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
static uint16_t DayOfYear(uint16_t year, uint8_t month, uint8_t day);
|
2016-06-04 19:17:42 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Convert just the year and day of year to full date.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
static Date ReverseDayOfYear(uint16_t year, uint16_t doy);
|
2016-07-04 16:23:35 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Calculate the number of days in the specified date range.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
static int64_t DateRangeToSeconds(uint16_t _year, uint8_t _month, uint8_t _day, uint16_t year_, uint8_t month_, uint8_t day_);
|
2016-06-04 19:17:42 +03:00
|
|
|
};
|
2016-03-25 14:28:07 +02:00
|
|
|
|
|
|
|
} // Namespace:: SqMod
|