2022-10-15 11:21:22 +00:00
|
|
|
#ifndef _TIME_H
|
|
|
|
#define _TIME_H
|
|
|
|
|
2022-10-23 08:01:03 +00:00
|
|
|
#include <stddef.h>
|
2022-10-25 17:27:24 +00:00
|
|
|
#include <sys/types.h>
|
2022-10-23 08:01:03 +00:00
|
|
|
|
2022-10-25 17:27:24 +00:00
|
|
|
// Structure representing broken-down time.
|
2022-10-22 10:17:48 +00:00
|
|
|
struct tm
|
|
|
|
{
|
|
|
|
int tm_sec;
|
|
|
|
int tm_min;
|
|
|
|
int tm_hour;
|
|
|
|
int tm_mday;
|
|
|
|
int tm_mon;
|
|
|
|
int tm_year;
|
|
|
|
int tm_wday;
|
|
|
|
int tm_yday;
|
|
|
|
int tm_isdst;
|
|
|
|
};
|
|
|
|
|
2022-10-30 08:08:29 +00:00
|
|
|
// Captures elapsed time with microsecond precision.
|
2022-10-27 05:55:02 +00:00
|
|
|
struct timeval
|
|
|
|
{
|
|
|
|
time_t tv_sec;
|
2022-10-27 15:20:46 +00:00
|
|
|
suseconds_t tv_usec;
|
2022-10-27 05:55:02 +00:00
|
|
|
};
|
|
|
|
|
2022-10-30 08:08:29 +00:00
|
|
|
// Captures elapsed time with nanosecond precision.
|
|
|
|
struct timespec
|
|
|
|
{
|
|
|
|
time_t tv_sec;
|
|
|
|
long tv_nsec;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define CLOCKS_PER_SEC 10000000 // Number of clock_t per second.
|
|
|
|
|
|
|
|
#define CLOCK_REALTIME 0
|
|
|
|
#define CLOCK_MONOTONIC 1
|
|
|
|
#define CLOCK_PROCTIME 2
|
2022-10-15 11:21:22 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Returns a number representing how much CPU time has been used by this process. Divide this by CLOCKS_PER_SEC to
|
|
|
|
* get the value in seconds. */
|
|
|
|
clock_t clock(void);
|
|
|
|
|
2022-10-30 08:08:29 +00:00
|
|
|
/* Returns the current UNIX time in seconds, which is also stored in tloc if it is nonnull. */
|
2022-10-21 16:32:01 +00:00
|
|
|
time_t time(time_t* tloc);
|
|
|
|
|
2022-10-30 08:08:29 +00:00
|
|
|
/* Retrieves precise time from a specific system clock. */
|
|
|
|
int clock_gettime(clockid_t clock_id, struct timespec* tp);
|
|
|
|
|
|
|
|
/* Converts the UNIX timestamp time to broken-down time in UTC. */
|
|
|
|
struct tm* gmtime(const time_t* time);
|
|
|
|
|
|
|
|
/* Converts the UNIX timestamp time to broken-down time in UTC. Thread-safe. */
|
|
|
|
struct tm* gmtime_r(const time_t* time, struct tm* result);
|
|
|
|
|
|
|
|
/* Converts the UNIX timestamp time to broken-down time in local time. */
|
|
|
|
struct tm* localtime(const time_t* time);
|
|
|
|
|
|
|
|
/* Converts the UNIX timestamp time to broken-down time in local time. Thread-safe. */
|
|
|
|
struct tm* localtime_r(const time_t* time, struct tm* result);
|
|
|
|
|
|
|
|
/* Returns a string representation of the broken-down time in the time structure. */
|
|
|
|
char* asctime(const struct tm* time);
|
|
|
|
|
|
|
|
/* Fills buf with the string representation of the broken-down time in the time structure. Thread-safe. */
|
|
|
|
char* asctime_r(const struct tm* time, char buf[26]);
|
|
|
|
|
|
|
|
/* Returns a string representation of time. */
|
|
|
|
char* ctime(const time_t* time);
|
|
|
|
|
|
|
|
/* Fills buf with a string representation of time. Thread-safe. */
|
|
|
|
char* ctime_r(const time_t* time, char buf[26]);
|
|
|
|
|
2022-10-30 16:48:54 +00:00
|
|
|
/* Fills str with a formatted string representation of time according to the format string. */
|
|
|
|
size_t strftime(char* str, size_t max, const char* format, const struct tm* time);
|
2022-10-22 10:17:48 +00:00
|
|
|
|
2022-10-15 11:21:22 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|