From e43c3a16f06ccd0c35814e8b47a6f30e81f9c981 Mon Sep 17 00:00:00 2001 From: Aaron Marcher Date: Wed, 2 May 2018 08:41:06 +0200 Subject: uptime: Simplifiy and clean up --- components/uptime.c | 39 +++++++++++++++++++-------------------- 1 file changed, 19 insertions(+), 20 deletions(-) (limited to 'components/uptime.c') diff --git a/components/uptime.c b/components/uptime.c index 25f904c..19908b9 100644 --- a/components/uptime.c +++ b/components/uptime.c @@ -1,41 +1,43 @@ /* See LICENSE file for copyright and license details. */ -#include #include -#include #include "../util.h" +const char * +format(int uptime) +{ + int h, m; + + h = uptime / 3600; + m = (uptime - h * 3600) / 60; + + return bprintf("%dh %dm", h, m); +} + #if defined(__linux__) #include const char * uptime(void) { - int h; - int m; - int uptime = 0; + int uptime; struct sysinfo info; sysinfo(&info); uptime = info.uptime; - h = uptime / 3600; - m = (uptime - h * 3600) / 60; - - return bprintf("%dh %dm", h, m); + return format(uptime); } #elif defined(__OpenBSD__) + #include + #include #include #include const char * uptime(void) { - int h; - int m; - int uptime = 0; - - int mib[2]; + int mib[2], uptime; size_t size; time_t now; struct timeval boottime; @@ -47,16 +49,13 @@ size = sizeof(boottime); - if (sysctl(mib, 2, &boottime, &size, NULL, 0) != -1) - uptime = now - boottime.tv_sec; - else { + if (sysctl(mib, 2, &boottime, &size, NULL, 0) == -1) fprintf(stderr, "sysctl 'KERN_BOOTTIME': %s\n", strerror(errno)); return NULL; } - h = uptime / 3600; - m = (uptime - h * 3600) / 60; + uptime = now - boottime.tv_sec; - return bprintf("%dh %dm", h, m); + return format(uptime); } #endif -- cgit v1.2.3