summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--bin/df/df.c154
1 files changed, 117 insertions, 37 deletions
diff --git a/bin/df/df.c b/bin/df/df.c
index de2e283dc91..c77f89763bd 100644
--- a/bin/df/df.c
+++ b/bin/df/df.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: df.c,v 1.17 1997/07/23 14:41:03 kstailey Exp $ */
+/* $OpenBSD: df.c,v 1.18 1997/08/19 06:44:54 denny Exp $ */
/* $NetBSD: df.c,v 1.21.2.1 1995/11/01 00:06:11 jtc Exp $ */
/*
@@ -49,7 +49,7 @@ static char copyright[] =
#if 0
static char sccsid[] = "@(#)df.c 8.7 (Berkeley) 4/2/94";
#else
-static char rcsid[] = "$OpenBSD: df.c,v 1.17 1997/07/23 14:41:03 kstailey Exp $";
+static char rcsid[] = "$OpenBSD: df.c,v 1.18 1997/08/19 06:44:54 denny Exp $";
#endif
#endif /* not lint */
@@ -67,7 +67,8 @@ static char rcsid[] = "$OpenBSD: df.c,v 1.17 1997/07/23 14:41:03 kstailey Exp $"
int bread __P((int, off_t, void *, int));
char *getmntpt __P((char *));
-void prtstat __P((struct statfs *, int));
+void bsdprint __P((struct statfs *, long, int));
+void posixprint __P((struct statfs *, long, int));
int selected __P((const char *));
void maketypelist __P((char *));
long regetmntinfo __P((struct statfs **, long));
@@ -78,9 +79,8 @@ extern int ffs_df __P((int, char *, struct statfs *));
extern int lfs_df __P((int, char *, struct statfs *));
extern int e2fs_df __P((int, char *, struct statfs *));
-int hflag, iflag, kflag, lflag, nflag;
+int hflag, iflag, kflag, lflag, nflag, Pflag;
char **typelist = NULL;
-struct ufs_args mdev;
int
main(argc, argv)
@@ -90,10 +90,11 @@ main(argc, argv)
struct stat stbuf;
struct statfs *mntbuf;
long mntsize;
- int ch, i, maxwidth, width;
+ int ch, i;
+ int width, maxwidth;
char *mntpt;
- while ((ch = getopt(argc, argv, "hiklnt:")) != -1)
+ while ((ch = getopt(argc, argv, "hiklnPt:")) != -1)
switch (ch) {
case 'h':
hflag = 1;
@@ -112,6 +113,9 @@ main(argc, argv)
case 'n':
nflag = 1;
break;
+ case 'P':
+ Pflag = 1;
+ break;
case 't':
if (typelist != NULL)
errx(1, "only one -t option may be specified.");
@@ -123,6 +127,11 @@ main(argc, argv)
argc -= optind;
argv += optind;
+ if (iflag && Pflag) {
+ warnx("-i is incompatible with -P");
+ usage();
+ }
+
mntsize = getmntinfo(&mntbuf, MNT_NOWAIT);
if (mntsize == 0)
err(1, "retrieving information on mounted file systems");
@@ -168,8 +177,15 @@ main(argc, argv)
if (width > maxwidth)
maxwidth = width;
}
- for (i = 0; i < mntsize; i++)
- prtstat(&mntbuf[i], maxwidth);
+
+ if (maxwidth < 11)
+ maxwidth = 11;
+
+ if (Pflag)
+ posixprint(mntbuf, mntsize, maxwidth);
+ else
+ bsdprint(mntbuf, mntsize, maxwidth);
+
exit(0);
}
@@ -346,37 +362,13 @@ prthuman(sfsp, used)
* Print out status about a filesystem.
*/
void
-prtstat(sfsp, maxwidth)
+prtstat(sfsp, maxwidth, headerlen, blocksize)
struct statfs *sfsp;
- int maxwidth;
+ int maxwidth, headerlen;
+ long blocksize;
{
- static long blocksize;
- static int headerlen, timesthrough;
- static char *header;
long used, availblks, inodes;
- if (maxwidth < 11)
- maxwidth = 11;
- if (++timesthrough == 1) {
- if (hflag) {
- header = " Size";
- headerlen = strlen(header);
- (void)printf("%-*.*s %s Used Avail Capacity",
- maxwidth, maxwidth, "Filesystem", header);
- } else {
- if (kflag) {
- blocksize = 1024;
- header = "1K-blocks";
- headerlen = strlen(header);
- } else
- header = getbsize(&headerlen, &blocksize);
- (void)printf("%-*.*s %s Used Avail Capacity",
- maxwidth, maxwidth, "Filesystem", header);
- }
- if (iflag)
- (void)printf(" iused ifree %%iused");
- (void)printf(" Mounted on\n");
- }
(void)printf("%-*.*s", maxwidth, maxwidth, sfsp->f_mntfromname);
used = sfsp->f_blocks - sfsp->f_bfree;
availblks = sfsp->f_bavail + used;
@@ -399,6 +391,94 @@ prtstat(sfsp, maxwidth)
(void)printf(" %s\n", sfsp->f_mntonname);
}
+/*
+ * Print in traditional BSD format.
+ */
+void
+bsdprint(mntbuf, mntsize, maxwidth)
+ struct statfs *mntbuf;
+ long mntsize;
+ int maxwidth;
+{
+ int i;
+ char *header;
+ int headerlen;
+ long blocksize;
+
+ /* Print the header line */
+ if (hflag) {
+ header = " Size";
+ headerlen = strlen(header);
+ (void)printf("%-*.*s %s Used Avail Capacity",
+ maxwidth, maxwidth, "Filesystem", header);
+ } else {
+ if (kflag) {
+ blocksize = 1024;
+ header = "1K-blocks";
+ headerlen = strlen(header);
+ } else
+ header = getbsize(&headerlen, &blocksize);
+ (void)printf("%-*.*s %s Used Avail Capacity",
+ maxwidth, maxwidth, "Filesystem", header);
+ }
+ if (iflag)
+ (void)printf(" iused ifree %%iused");
+ (void)printf(" Mounted on\n");
+
+
+ for (i = 0; i < mntsize; i++)
+ prtstat(&mntbuf[i], maxwidth, headerlen, blocksize);
+ return;
+}
+
+/*
+ * Print in format defined by POSIX 1002.2, invoke with -P option.
+ */
+void
+posixprint(mntbuf, mntsize, maxwidth)
+ struct statfs *mntbuf;
+ long mntsize;
+ int maxwidth;
+{
+ int i;
+ int blocklen;
+ long blocksize;
+ char *blockstr;
+ struct statfs *sfsp;
+ long used, avail;
+ int percentused;
+
+ if (kflag) {
+ blocksize = 1024;
+ blockstr = "1024-blocks";
+ } else {
+ blocksize = 512;
+ blockstr = " 512-blocks";
+ }
+ blocklen = strlen(blockstr);
+
+ (void)printf(
+ "%-*.*s %s Used Available Capacity Mounted on\n",
+ maxwidth, maxwidth, "Filesystem", blockstr);
+
+ for (i = 0; i < mntsize; i++) {
+ sfsp = &mntbuf[i];
+ used = sfsp->f_blocks - sfsp->f_bfree;
+ avail = sfsp->f_bavail + used;
+ percentused = (used * 100 / avail)
+ + ((used % avail) ? 1 : 0);
+
+ (void) printf ("%-*.*s %*ld %10ld %11ld %5d%% %s\n",
+ maxwidth, maxwidth, sfsp->f_mntfromname,
+ strlen(blockstr),
+ fsbtoblk(sfsp->f_blocks, sfsp->f_bsize, blocksize),
+ fsbtoblk(used, sfsp->f_bsize, blocksize),
+ fsbtoblk(sfsp->f_bavail, sfsp->f_bsize, blocksize),
+ percentused, sfsp->f_mntonname);
+ }
+}
+
+
int
raw_df(file, sfsp)
char *file;
@@ -448,6 +528,6 @@ bread(rfd, off, buf, cnt)
void
usage()
{
- (void)fprintf(stderr, "usage: df [-ikln] [-t type] [file | file_system ...]\n");
+ (void)fprintf(stderr, "usage: df [-iklnP] [-t type] [file | file_system ...]\n");
exit(1);
}