Xinqi Bao's Git

fmt_human: Improve types
[slstatus.git] / components / disk.c
index bf69875..9d2284e 100644 (file)
@@ -1,7 +1,5 @@
 /* See LICENSE file for copyright and license details. */
-#include <errno.h>
 #include <stdio.h>
-#include <string.h>
 #include <sys/statvfs.h>
 
 #include "../util.h"
@@ -12,12 +10,11 @@ disk_free(const char *mnt)
        struct statvfs fs;
 
        if (statvfs(mnt, &fs) < 0) {
-               fprintf(stderr, "statvfs '%s': %s\n", mnt, strerror(errno));
+               warn("statvfs '%s':", mnt);
                return NULL;
        }
 
-       return bprintf("%f",
-                      (float)fs.f_frsize * (float)fs.f_bavail / 1024 / 1024 / 1024);
+       return fmt_human(fs.f_frsize * fs.f_bavail, 1024);
 }
 
 const char *
@@ -26,7 +23,7 @@ disk_perc(const char *mnt)
        struct statvfs fs;
 
        if (statvfs(mnt, &fs) < 0) {
-               fprintf(stderr, "statvfs '%s': %s\n", mnt, strerror(errno));
+               warn("statvfs '%s':", mnt);
                return NULL;
        }
 
@@ -40,12 +37,11 @@ disk_total(const char *mnt)
        struct statvfs fs;
 
        if (statvfs(mnt, &fs) < 0) {
-               fprintf(stderr, "statvfs '%s': %s\n", mnt, strerror(errno));
+               warn("statvfs '%s':", mnt);
                return NULL;
        }
 
-       return bprintf("%f",
-                      (float)fs.f_frsize * (float)fs.f_blocks / 1024 / 1024 / 1024);
+       return fmt_human(fs.f_frsize * fs.f_blocks, 1024);
 }
 
 const char *
@@ -54,11 +50,9 @@ disk_used(const char *mnt)
        struct statvfs fs;
 
        if (statvfs(mnt, &fs) < 0) {
-               fprintf(stderr, "statvfs '%s': %s\n", mnt, strerror(errno));
+               warn("statvfs '%s':", mnt);
                return NULL;
        }
 
-       return bprintf("%f",
-                      (float)fs.f_frsize * ((float)fs.f_blocks -
-                      (float)fs.f_bfree) / 1024 / 1024 / 1024);
+       return fmt_human(fs.f_frsize * (fs.f_blocks - fs.f_bfree), 1024);
 }