uptime: Simplifiy and clean up
authorAaron Marcher <me@drkhsh.at>
Wed, 2 May 2018 06:41:06 +0000 (08:41 +0200)
committerAaron Marcher <me@drkhsh.at>
Wed, 2 May 2018 06:41:06 +0000 (08:41 +0200)
components/uptime.c

index 25f904c2fca59da2d11309c36a2a3ecc2f85f757..19908b97755b031c4438363d6eeb6344179bfbdc 100644 (file)
@@ -1,41 +1,43 @@
 /* See LICENSE file for copyright and license details. */
-#include <errno.h>
 #include <stdio.h>
-#include <string.h>
 
 #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 <sys/sysinfo.h>
 
        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 <errno.h>
+       #include <string.h>
        #include <sys/sysctl.h>
        #include <sys/time.h>
 
        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;
 
                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