From: Quentin Rameau Date: Mon, 30 Apr 2018 13:14:38 +0000 (+0200) Subject: uptime: OS split X-Git-Url: https://git.atheridis.org/?a=commitdiff_plain;h=19f3c8f545237f9db5e994220f3529b192b4bf39;p=suckless%2Fslstatus.git uptime: OS split --- diff --git a/Makefile b/Makefile index c06e81d..067ef57 100644 --- a/Makefile +++ b/Makefile @@ -22,7 +22,7 @@ COM =\ components/run_command\ components/$(OS)/swap \ components/$(OS)/temperature \ - components/uptime\ + components/$(OS)/uptime \ components/user\ components/volume\ components/wifi diff --git a/components/Linux/uptime.c b/components/Linux/uptime.c new file mode 100644 index 0000000..e7afc8e --- /dev/null +++ b/components/Linux/uptime.c @@ -0,0 +1,24 @@ +/* See LICENSE file for copyright and license details. */ +#include +#include +#include +#include + +#include "../../util.h" + +const char * +uptime(void) +{ + int h; + int m; + int uptime = 0; + struct sysinfo info; + + sysinfo(&info); + uptime = info.uptime; + + h = uptime / 3600; + m = (uptime - h * 3600) / 60; + + return bprintf("%dh %dm", h, m); +} diff --git a/components/OpenBSD/uptime.c b/components/OpenBSD/uptime.c new file mode 100644 index 0000000..637e2e0 --- /dev/null +++ b/components/OpenBSD/uptime.c @@ -0,0 +1,40 @@ +/* See LICENSE file for copyright and license details. */ +#include +#include +#include +#include +#include + +#include "../../util.h" + +const char * +uptime(void) +{ + int h; + int m; + int uptime = 0; + + int mib[2]; + size_t size; + time_t now; + struct timeval boottime; + + time(&now); + + mib[0] = CTL_KERN; + mib[1] = KERN_BOOTTIME; + + size = sizeof(boottime); + + if (sysctl(mib, 2, &boottime, &size, NULL, 0) != -1) + uptime = now - boottime.tv_sec; + else { + fprintf(stderr, "sysctl 'KERN_BOOTTIME': %s\n", strerror(errno)); + return NULL; + } + + h = uptime / 3600; + m = (uptime - h * 3600) / 60; + + return bprintf("%dh %dm", h, m); +} diff --git a/components/uptime.c b/components/uptime.c deleted file mode 100644 index debe4cb..0000000 --- a/components/uptime.c +++ /dev/null @@ -1,63 +0,0 @@ -/* See LICENSE file for copyright and license details. */ -#include -#include -#include -#if defined(__linux__) -#include -#elif defined(__OpenBSD__) -#include -#include -#endif - -#include "../util.h" - -#if defined(__linux__) -const char * -uptime(void) -{ - int h; - int m; - int uptime = 0; - struct sysinfo info; - - sysinfo(&info); - uptime = info.uptime; - - h = uptime / 3600; - m = (uptime - h * 3600) / 60; - - return bprintf("%dh %dm", h, m); -} -#elif defined(__OpenBSD__) -const char * -uptime(void) -{ - int h; - int m; - int uptime = 0; - - int mib[2]; - size_t size; - time_t now; - struct timeval boottime; - - time(&now); - - mib[0] = CTL_KERN; - mib[1] = KERN_BOOTTIME; - - size = sizeof(boottime); - - if (sysctl(mib, 2, &boottime, &size, NULL, 0) != -1) - uptime = now - boottime.tv_sec; - else { - fprintf(stderr, "sysctl 'KERN_BOOTTIME': %s\n", strerror(errno)); - return NULL; - } - - h = uptime / 3600; - m = (uptime - h * 3600) / 60; - - return bprintf("%dh %dm", h, m); -} -#endif