From 679aa902928d20d002ff66fbba075b6fcae551c4 Mon Sep 17 00:00:00 2001 From: dg Date: Fri, 12 Aug 1994 07:26:52 +0000 Subject: Implemented the -k flag more properly...don't destroy the user's setting of the BLOCKSIZE environment variable. --- bin/df/df.c | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) (limited to 'bin/df/df.c') diff --git a/bin/df/df.c b/bin/df/df.c index 02e6ca9..24a5d26 100644 --- a/bin/df/df.c +++ b/bin/df/df.c @@ -107,7 +107,7 @@ void prtstat __P((struct statfs *, int)); void ufs_df __P((char *, int)); void usage __P((void)); -int iflag, nflag, tflag; +int iflag, nflag, tflag, kflag; struct ufs_args mdev; int @@ -121,13 +121,15 @@ main(argc, argv) int ch, err, i, maxwidth, width; char *mntpt; + iflag = nflag = tflag = kflag = 0; + while ((ch = getopt(argc, argv, "iknt:")) != EOF) switch (ch) { case 'i': iflag = 1; break; case 'k': - putenv("BLOCKSIZE=1024"); + kflag = 1; break; case 'n': nflag = 1; @@ -305,11 +307,18 @@ prtstat(sfsp, maxwidth) static int headerlen, timesthrough; static char *header; long used, availblks, inodes; + char *oldbsize = NULL; if (maxwidth < 11) maxwidth = 11; if (++timesthrough == 1) { + if (kflag) { + oldbsize = getenv("BLOCKSIZE"); + putenv("BLOCKSIZE=1k"); + } header = getbsize(&headerlen, &blocksize); + if (oldbsize) + putenv(oldbsize); (void)printf("%-*.*s %s Used Avail Capacity", maxwidth, maxwidth, "Filesystem", header); if (iflag) -- cgit v1.1