/*** Copyright (C) 2021 J Reece Wilson (a/k/a "Reece"). All rights reserved. File: Time.hpp Date: 2021-6-10 Author: Reece ***/ #pragma once #include "_Time.hpp" namespace Aurora::Time { /** Converts milliseconds from the Aurora epoch to a civil timestamp structure similar to or of std::tm */ AUKN_SYM tm ToCivilTime(AuInt64 time, bool bIsUTC = true); /** Converts civil time to milliseconds from the Aurora epoch */ AUKN_SYM AuInt64 FromCivilTime(const tm &time, bool bIsUTC = true); /** Normalizes a civil data structure with respect to UTC, given the two input parameters 'in' civil and 'shiftFrom' timezone hint */ AUKN_SYM tm NormalizeCivilTimezone(const tm &in, ETimezoneShift shiftFrom = ETimezoneShift::eUTC); /** Translates the Aurora epoch to the standard unix epoch */ AUKN_SYM AuInt64 ConvertAuroraToUnixMS(AuInt64 in); /** Translates the Aurora epoch to the standard unix epoch */ AUKN_SYM AuInt64 ConvertAuroraToUnixNS(AuInt64 in); /** Translates a standard unix epoch to the Aurora epoch */ AUKN_SYM AuInt64 ConvertUnixToAuroraMS(AuInt64 in); /** Translates a standard unix epoch to the Aurora epoch */ AUKN_SYM AuInt64 ConvertUnixToAuroraNS(AuInt64 in); /** Retrieves wall clock in milliseconds from the Aurora epoch */ AUKN_SYM AuInt64 CurrentClockMS(); /** Retrieves wall clock in nanoseconds from the Aurora epoch */ AUKN_SYM AuInt64 CurrentClockNS(); /** * @brief Steady clock in jiffies * @return */ AUKN_SYM AuUInt64 SteadyClock(); /** Returns a steady system clock of SteadyClockJiffies() with an undefined epoch. These values should be used to drive thread primitives, IO time, and tick delta. On a modern plaform, these should be affected by the users' calendar or NTP. On stinkier platforms, who cares if we can run mostly bug free with an assumed-sane wall-clock, right? */ AUKN_SYM AuUInt64 SteadyClockMS(); /** * @brief * @return */ AUKN_SYM AuUInt64 SteadyClockNS(); /** Retrieves the freqency of jiffies per second */ AUKN_SYM AuUInt64 SteadyClockJiffies(); /** * @brief frequency in jiffies per second * @return */ AUKN_SYM AuUInt64 ThreadClockJiffies(); /** * @brief time spent in userspace under this context [in jiffies] * @return */ AUKN_SYM AuUInt64 ThreadClock(); /** * @brief time spent in userspace under this context [in nanoseconds] * @return */ AUKN_SYM AuUInt64 ThreadClockNS(); /** * @brief time spent in userspace under this context [in milliseconds] * @return */ AUKN_SYM AuUInt64 ThreadClockMS(); /** * @brief frequency in jiffies per second * @return */ AUKN_SYM AuUInt64 ProcessClockJiffies(); /** * @brief time spent in userspace and in the kernel under this process [in jiffies] * @return */ AUKN_SYM AuUInt64 ProcessClock(); /** * @brief time spent in userspace and in the kernel under this process [in nanoseconds] * @return */ AUKN_SYM AuUInt64 ProcessClockNS(); /** * @brief time spent in userspace and in the kernel under this process [in milliseconds] * @return */ AUKN_SYM AuUInt64 ProcessClockMS(); /** Converts seconds from the Aurora epoch to time_t */ AUKN_SYM time_t SToCTime(AuInt64 time); /** Converts nanoseconds from the Aurora epoch to time_t */ AUKN_SYM time_t NSToCTime(AuInt64 time); /** Converts milliseconds from the Aurora epoch to time_t */ AUKN_SYM time_t MSToCTime(AuInt64 time); AUKN_SYM AuInt64 CTimeToMS(time_t time); /** * @brief * @return */ AUKN_SYM AuSPtr GetWallClock(); /** * @brief * @return */ AUKN_SYM AuSPtr GetSteadyClock(); /** * @brief * @return */ AUKN_SYM AuSPtr GetProcessClock(); /** * @brief * @return */ AUKN_SYM AuSPtr GetThreadClock(); /** * @brief * @param clock * @return */ AUKN_SYM AuSPtr GetClockFromEnum(EClock clock); }