X-Git-Url: https://git.subgeniuskitty.com/unix-history/.git/blobdiff_plain/251b09710fa057c01df8d132b6e165bd3b6c9a34..31cef89cb428866f787983e68246030321893df4:/usr/src/cmd/who.c diff --git a/usr/src/cmd/who.c b/usr/src/cmd/who.c index 27e0b1d4bb..41a0fd3e7e 100644 --- a/usr/src/cmd/who.c +++ b/usr/src/cmd/who.c @@ -1,3 +1,4 @@ +static char *sccsid = "@(#)who.c 4.2 (Berkeley) 11/1/80"; /* * who */ @@ -5,6 +6,12 @@ #include #include #include +#include +#include + +#define NMAX sizeof(utmp.ut_name) +#define LMAX sizeof(utmp.ut_line) + struct utmp utmp; struct passwd *pw; struct passwd *getpwuid(); @@ -15,7 +22,9 @@ char **argv; { register char *tp, *s; register FILE *fi; + extern char _sobuf[]; + setbuf(stdout, _sobuf); s = "/etc/utmp"; if(argc == 2) s = argv[1]; @@ -38,11 +47,12 @@ char **argv; } while (fread((char *)&utmp, sizeof(utmp), 1, fi) == 1) { if(argc==3) { + static char myname[]=sysname; if (strcmp(utmp.ut_line, tp)) continue; -#ifdef vax - printf("(Vax) "); -#endif + if (islower(*myname)) + *myname = toupper(*myname); + printf("(%s) ",myname); putline(); exit(0); } @@ -56,7 +66,7 @@ putline() { register char *cbuf; - printf("%-8.8s %-8.8s", utmp.ut_name, utmp.ut_line); + printf("%-*.*s %-*.*s", NMAX, NMAX, utmp.ut_name, LMAX, LMAX, utmp.ut_line); cbuf = ctime(&utmp.ut_time); printf("%.12s\n", cbuf+4); }