fixed df
This commit is contained in:
parent
5a29ac490e
commit
87abbeffa3
@ -83,7 +83,7 @@ int main(int argc, char **argv) {
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
puts("date [rsdu] [+\"fmt\"]\n\t-s TIME Set new date\n\t-d TIME Print new date\n\t-u Work in UTC\n\nRecognized TIME formats:");
|
puts("date [sdu] [+\"fmt\"]\n\t-s TIME Set new date\n\t-d TIME Print new date\n\t-u Work in UTC\n\nRecognized TIME formats:");
|
||||||
for (size_t i = 0; i < sizeof(fmts) / sizeof(char *); i++)
|
for (size_t i = 0; i < sizeof(fmts) / sizeof(char *); i++)
|
||||||
puts(fmts[i]);
|
puts(fmts[i]);
|
||||||
|
|
||||||
|
@ -11,12 +11,53 @@
|
|||||||
|
|
||||||
char a_flag;
|
char a_flag;
|
||||||
char h_flag;
|
char h_flag;
|
||||||
|
char *t_flag;
|
||||||
off_t block = 1024;
|
off_t block = 1024;
|
||||||
|
|
||||||
|
int print(const struct mntent *me) {
|
||||||
|
|
||||||
|
struct statvfs disk;
|
||||||
|
if (!strcmp(me->mnt_fsname, "none"))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if (statvfs(me->mnt_dir, &disk) < 0)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
if (!a_flag)
|
||||||
|
if (!strcmp(me->mnt_fsname, "/dev/root") || disk.f_blocks == 0)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if (t_flag && strcmp(t_flag, me->mnt_type))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
off_t bs = disk.f_frsize / block;
|
||||||
|
off_t total = disk.f_blocks * bs;
|
||||||
|
off_t avail = disk.f_bfree * bs;
|
||||||
|
off_t used = total - avail;
|
||||||
|
off_t capacity = (used * 100 + 1) / (avail + used + 1);
|
||||||
|
|
||||||
|
if (h_flag) {
|
||||||
|
char total_s[MU_HUMAN_BUF_SIZE + 1];
|
||||||
|
char used_s[MU_HUMAN_BUF_SIZE + 1];
|
||||||
|
char avail_s[MU_HUMAN_BUF_SIZE + 1];
|
||||||
|
|
||||||
|
snprintf(total_s, sizeof(total_s), "%s", mu_humansize(total * block, block));
|
||||||
|
snprintf(used_s, sizeof(used_s), "%s", mu_humansize(used * block, block));
|
||||||
|
snprintf(avail_s, sizeof(avail_s), "%s", mu_humansize(avail * block, block));
|
||||||
|
|
||||||
|
printf("%-20s %12s %10s %9s %9s %3jd%% %s\n", me->mnt_fsname, me->mnt_type, total_s, used_s, avail_s, capacity, me->mnt_dir);
|
||||||
|
}
|
||||||
|
|
||||||
|
else
|
||||||
|
printf("%-20s %12s %12jd %12jd %12jd %12jd%% %s\n", me->mnt_fsname, me->mnt_type, total, used, avail, capacity, me->mnt_dir);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char **argv) {
|
int main(int argc, char **argv) {
|
||||||
|
|
||||||
int opt;
|
int opt;
|
||||||
while ((opt = getopt(argc, argv, "hHka")) != -1) {
|
while ((opt = getopt(argc, argv, "hHat:")) != -1) {
|
||||||
switch (opt) {
|
switch (opt) {
|
||||||
case 'h':
|
case 'h':
|
||||||
h_flag = 1;
|
h_flag = 1;
|
||||||
@ -31,12 +72,19 @@ int main(int argc, char **argv) {
|
|||||||
a_flag = 1;
|
a_flag = 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 't':
|
||||||
|
t_flag = optarg;
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
printf("df [rHa]\n\t-h Human readable (1024)\n\t-a Show all\n\t-H Human readable (1000)\n");
|
puts("df [hHat]\n\t-h Human readable (1024)\n\t-a Show all\n\t-H Human readable (1000)\n\t-t TYPE Print only mounts of this type");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
argv += optind;
|
||||||
|
argc -= optind;
|
||||||
|
|
||||||
FILE *fp = setmntent("/proc/mounts", "r");
|
FILE *fp = setmntent("/proc/mounts", "r");
|
||||||
if (fp == NULL) {
|
if (fp == NULL) {
|
||||||
fprintf(stderr, "df: %s\n", strerror(errno));
|
fprintf(stderr, "df: %s\n", strerror(errno));
|
||||||
@ -44,52 +92,28 @@ int main(int argc, char **argv) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (h_flag)
|
if (h_flag)
|
||||||
puts("Filesystem Size Used Available Use% Mounted on");
|
puts("Filesystem Type Size Used Available Use% Mounted on");
|
||||||
|
|
||||||
else
|
else
|
||||||
puts("Filesystem Size Used Available Use% Mounted on");
|
puts("Filesystem Type Size Used Available Use% Mounted on");
|
||||||
|
|
||||||
|
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
struct mntent *me;
|
struct mntent *me;
|
||||||
struct statvfs disk;
|
|
||||||
|
|
||||||
while ((me = getmntent(fp)) != NULL) {
|
while ((me = getmntent(fp)) != NULL) {
|
||||||
if (!strcmp(me->mnt_fsname, "none"))
|
if (argc) {
|
||||||
continue;
|
for (int i = 0; i < argc; i++) {
|
||||||
|
if (!strcmp(argv[i], me->mnt_fsname) || !strcmp(argv[i], me->mnt_dir))
|
||||||
if (statvfs(me->mnt_dir, &disk) < 0) {
|
if (print(me))
|
||||||
ret = 1;
|
ret = 1;
|
||||||
continue;
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!a_flag)
|
else
|
||||||
if (!strcmp(me->mnt_fsname, "/dev/root") || disk.f_blocks == 0)
|
print(me);
|
||||||
continue;
|
|
||||||
|
|
||||||
off_t bs = disk.f_frsize / block;
|
|
||||||
off_t total = disk.f_blocks * bs;
|
|
||||||
off_t avail = disk.f_bfree * bs;
|
|
||||||
off_t used = total - avail;
|
|
||||||
off_t capacity = (used * 100 + 1) / (avail + used + 1);
|
|
||||||
|
|
||||||
if (!h_flag)
|
|
||||||
printf("%-20s %12jd %12jd %12jd %12jd%% %s\n", me->mnt_fsname, total, used, avail, capacity, me->mnt_dir);
|
|
||||||
|
|
||||||
else {
|
|
||||||
char total_s[MU_HUMAN_BUF_SIZE + 1];
|
|
||||||
char used_s[MU_HUMAN_BUF_SIZE + 1];
|
|
||||||
char avail_s[MU_HUMAN_BUF_SIZE + 1];
|
|
||||||
|
|
||||||
snprintf(total_s, sizeof(total_s), "%s", mu_humansize(total * block, block));
|
|
||||||
snprintf(used_s, sizeof(used_s), "%s", mu_humansize(used * block, block));
|
|
||||||
snprintf(avail_s, sizeof(avail_s), "%s", mu_humansize(avail * block, block));
|
|
||||||
|
|
||||||
printf("%-20s %10s %9s %9s %3jd%% %s\n", me->mnt_fsname, total_s, used_s, avail_s, capacity, me->mnt_dir);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
endmntent(fp);
|
endmntent(fp);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user