diff options
author | andersen <andersen@69ca8d6d-28ef-0310-b511-8ec308f3f277> | 2001-02-21 00:24:51 +0000 |
---|---|---|
committer | andersen <andersen@69ca8d6d-28ef-0310-b511-8ec308f3f277> | 2001-02-21 00:24:51 +0000 |
commit | 917a1f2a1d907b13e47b44f5d5400bb358dd6b37 (patch) | |
tree | f927deb113d565038886aa13cecb5ae372465993 /df.c | |
parent | f0572f2297244af48caada7483d07a0ee7e80a63 (diff) | |
download | busybox-w32-917a1f2a1d907b13e47b44f5d5400bb358dd6b37.tar.gz busybox-w32-917a1f2a1d907b13e47b44f5d5400bb358dd6b37.tar.bz2 busybox-w32-917a1f2a1d907b13e47b44f5d5400bb358dd6b37.zip |
df was totally broken. So I fixed it.
-Erik
git-svn-id: svn://busybox.net/trunk/busybox@1873 69ca8d6d-28ef-0310-b511-8ec308f3f277
Diffstat (limited to 'df.c')
-rw-r--r-- | df.c | 43 |
1 files changed, 32 insertions, 11 deletions
@@ -39,6 +39,9 @@ static int df(char *device, const char *mountPoint) | |||
39 | struct statfs s; | 39 | struct statfs s; |
40 | long blocks_used; | 40 | long blocks_used; |
41 | long blocks_percent_used; | 41 | long blocks_percent_used; |
42 | #ifdef BB_FEATURE_HUMAN_READABLE | ||
43 | long divisor, base; | ||
44 | #endif | ||
42 | 45 | ||
43 | if (statfs(mountPoint, &s) != 0) { | 46 | if (statfs(mountPoint, &s) != 0) { |
44 | perror_msg("%s", mountPoint); | 47 | perror_msg("%s", mountPoint); |
@@ -59,20 +62,38 @@ static int df(char *device, const char *mountPoint) | |||
59 | find_real_root_device_name( device); | 62 | find_real_root_device_name( device); |
60 | } | 63 | } |
61 | #ifdef BB_FEATURE_HUMAN_READABLE | 64 | #ifdef BB_FEATURE_HUMAN_READABLE |
62 | printf("%-20s %9s %9s %9s %3ld%% %s\n", | 65 | switch (disp_hr) { |
63 | device, | 66 | case MEGABYTE: |
64 | format((s.f_blocks * s.f_bsize), disp_hr), | 67 | fprintf(stderr, "got MEGABYTE\n"); |
65 | format((s.f_blocks - s.f_bfree) * s.f_bsize, disp_hr), | 68 | divisor = KILOBYTE; |
66 | format(s.f_bavail * s.f_bsize, disp_hr), | 69 | base = KILOBYTE; |
70 | break; | ||
71 | case KILOBYTE: | ||
72 | fprintf(stderr, "got KILOBYTE\n"); | ||
73 | divisor = KILOBYTE; | ||
74 | base = 1; | ||
75 | break; | ||
76 | default: | ||
77 | fprintf(stderr, "got something else\n"); | ||
78 | divisor = KILOBYTE; | ||
79 | base = 0; | ||
80 | } | ||
81 | |||
82 | printf("%-20s %9s ", device, | ||
83 | format((s.f_blocks * (s.f_bsize / divisor)), base)); | ||
84 | printf("%9s ", | ||
85 | format(((s.f_blocks - s.f_bfree) * | ||
86 | (s.f_bsize / divisor)), base)); | ||
87 | printf("%9s %3ld%% %s\n", | ||
88 | format((s.f_bavail * (s.f_bsize / divisor)), base), | ||
67 | blocks_percent_used, mountPoint); | 89 | blocks_percent_used, mountPoint); |
68 | #else | 90 | #else |
69 | printf("%-20s %9ld %9ld %9ld %3ld%% %s\n", | 91 | printf("%-20s %9ld %9ld %9ld %3ld%% %s\n", |
70 | device, | 92 | device, |
71 | (long) (s.f_blocks * s.f_bsize) / KILOBYTE, | 93 | (long) (s.f_blocks * (s.f_bsize / KILOBYTE)), |
72 | (long) ((s.f_blocks - s.f_bfree) * s.f_bsize) / KILOBYTE, | 94 | (long) ((s.f_blocks - s.f_bfree) * (s.f_bsize / KILOBYTE)), |
73 | (long) (s.f_bavail * s.f_bsize) / KILOBYTE, | 95 | (long) (s.f_bavail * (s.f_bsize / KILOBYTE)), |
74 | blocks_percent_used, mountPoint); | 96 | blocks_percent_used, mountPoint); |
75 | |||
76 | #endif | 97 | #endif |
77 | } | 98 | } |
78 | 99 | ||