Fix func prototype
[oweals/busybox.git] / df.c
diff --git a/df.c b/df.c
index 8f6ef984bda0c26b6ed5b3b2b5563fb2b4e6e5dd..0d1e17608108a0f3065281544a25921a3dc73bcb 100644 (file)
--- a/df.c
+++ b/df.c
@@ -39,6 +39,9 @@ static int df(char *device, const char *mountPoint)
        struct statfs s;
        long blocks_used;
        long blocks_percent_used;
+#ifdef BB_FEATURE_HUMAN_READABLE
+       long divisor, base;
+#endif 
 
        if (statfs(mountPoint, &s) != 0) {
                perror_msg("%s", mountPoint);
@@ -59,20 +62,35 @@ static int df(char *device, const char *mountPoint)
                        find_real_root_device_name( device);
                }
 #ifdef BB_FEATURE_HUMAN_READABLE
-               printf("%-20s %9s %9s %9s %3ld%% %s\n",
-                          device,
-                          format((s.f_blocks * s.f_bsize), disp_hr),
-                          format((s.f_blocks - s.f_bfree) * s.f_bsize, disp_hr),
-                          format(s.f_bavail * s.f_bsize, disp_hr),
+               switch (disp_hr) {
+                       case MEGABYTE:
+                               divisor = KILOBYTE;
+                               base = KILOBYTE;
+                               break;
+                       case KILOBYTE:
+                               divisor = KILOBYTE;
+                               base = 1;
+                               break;
+                       default:
+                               divisor = KILOBYTE;
+                               base = 0;
+               }
+
+               printf("%-20s %9s ", device,
+                          format((s.f_blocks * (s.f_bsize / divisor)), base));
+               printf("%9s ",
+                          format(((s.f_blocks - s.f_bfree) * 
+                                          (s.f_bsize / divisor)), base));
+               printf("%9s %3ld%% %s\n",
+                          format((s.f_bavail * (s.f_bsize / divisor)), base),
                           blocks_percent_used, mountPoint);
 #else
                printf("%-20s %9ld %9ld %9ld %3ld%% %s\n",
-                          device,
-                          (long) (s.f_blocks * s.f_bsize) / KILOBYTE,
-                          (long) ((s.f_blocks - s.f_bfree) * s.f_bsize) / KILOBYTE,
-                          (long) (s.f_bavail * s.f_bsize) / KILOBYTE,
-                          blocks_percent_used, mountPoint);
-
+                               device,
+                               (long) (s.f_blocks * (s.f_bsize / KILOBYTE)),
+                               (long) ((s.f_blocks - s.f_bfree) * (s.f_bsize / KILOBYTE)),
+                               (long) (s.f_bavail * (s.f_bsize / KILOBYTE)),
+                               blocks_percent_used, mountPoint);
 #endif
        }