diff options
| author | pml68 <tutorialmester@gmail.com> | 2023-12-27 00:46:22 +0100 |
|---|---|---|
| committer | pml68 <tutorialmester@gmail.com> | 2023-12-27 00:46:22 +0100 |
| commit | f9a968b6818c858d15f459ab9e8315b6df56952a (patch) | |
| tree | 97f19f54e5fbc2be7c987edadd1a681cb52de015 /slstatus/components/uptime.c | |
| download | suckless-setup-f9a968b6818c858d15f459ab9e8315b6df56952a.tar.gz | |
Initial commit
Diffstat (limited to '')
| -rw-r--r-- | slstatus/components/uptime.c | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/slstatus/components/uptime.c b/slstatus/components/uptime.c new file mode 100644 index 0000000..6227f73 --- /dev/null +++ b/slstatus/components/uptime.c @@ -0,0 +1,34 @@ +/* See LICENSE file for copyright and license details. */ +#include <stdint.h> +#include <stdio.h> +#include <time.h> + +#include "../slstatus.h" +#include "../util.h" + +#if defined(CLOCK_BOOTTIME) + #define UPTIME_FLAG CLOCK_BOOTTIME +#elif defined(CLOCK_UPTIME) + #define UPTIME_FLAG CLOCK_UPTIME +#else + #define UPTIME_FLAG CLOCK_MONOTONIC +#endif + +const char * +uptime(const char *unused) +{ + char warn_buf[256]; + uintmax_t h, m; + struct timespec uptime; + + if (clock_gettime(UPTIME_FLAG, &uptime) < 0) { + snprintf(warn_buf, sizeof(warn_buf), "clock_gettime %d", UPTIME_FLAG); + warn(warn_buf); + return NULL; + } + + h = uptime.tv_sec / 3600; + m = uptime.tv_sec % 3600 / 60; + + return bprintf("%juh %jum", h, m); +} |
