Revert -n flag for w

This commit is contained in:
Craig Small 2011-07-15 08:52:45 +10:00
parent a26c3bfa39
commit 3f59ff5a16

69
w.c
View File

@ -29,7 +29,6 @@
#include <utmp.h> #include <utmp.h>
#include <locale.h> #include <locale.h>
#include <termios.h> #include <termios.h>
#include <arpa/inet.h>
static int ignoreuser = 0; /* for '-u' */ static int ignoreuser = 0; /* for '-u' */
static proc_t **procs; /* our snapshot of the process table */ static proc_t **procs; /* our snapshot of the process table */
@ -45,7 +44,6 @@ typedef struct utmp utmp_t;
/* Uh... same thing as UT_NAMESIZE */ /* Uh... same thing as UT_NAMESIZE */
#define USERSZ (sizeof u->ut_user) #define USERSZ (sizeof u->ut_user)
#define MAX_FROM_LEN 16
/* This routine is careful since some programs leave utmp strings /* This routine is careful since some programs leave utmp strings
* unprintable. Always outputs at least 16 chars padded with spaces * unprintable. Always outputs at least 16 chars padded with spaces
@ -59,7 +57,7 @@ static void print_host(const char *restrict host, int len) {
/* for now, we'll just limit it to the 16 that the libc5 version /* for now, we'll just limit it to the 16 that the libc5 version
* of utmp uses. * of utmp uses.
*/ */
if (len > MAX_FROM_LEN) len = MAX_FROM_LEN; if (len > 16) len = 16;
last = host + len; last = host + len;
for ( ; host < last ; host++){ for ( ; host < last ; host++){
if (isprint(*host) && *host != ' ') { if (isprint(*host) && *host != ' ') {
@ -69,45 +67,8 @@ static void print_host(const char *restrict host, int len) {
break; break;
} }
} }
/* space-fill, and a '-' too if needed to ensure the column exists */ // space-fill, and a '-' too if needed to ensure the column exists
if(width < MAX_FROM_LEN) fputs("- "+width, stdout); if(width < 16) fputs("- "+width, stdout);
}
/* This routine prints either the hostname or the IP address of the remote */
static void print_from(const utmp_t *restrict const u, int ip_addresses) {
char buf[MAX_FROM_LEN + 1];
char buf_ipv6[INET6_ADDRSTRLEN];
int len;
int32_t ut_addr_v6[4]; /* IP address of remote host. */
if (ip_addresses) { /* -n switch used */
memcpy(&ut_addr_v6, &u->ut_addr_v6, sizeof(ut_addr_v6));
if (IN6_IS_ADDR_V4MAPPED(&ut_addr_v6)) {
/* map back */
ut_addr_v6[0] = ut_addr_v6[3];
ut_addr_v6[1] = 0;
ut_addr_v6[2] = 0;
ut_addr_v6[3] = 0;
}
if (ut_addr_v6[1] || ut_addr_v6[2] || ut_addr_v6[3]) {
/* IPv6 */
if (!inet_ntop(AF_INET6, &ut_addr_v6, buf_ipv6, sizeof(buf_ipv6))) {
snprintf(buf_ipv6, INET6_ADDRSTRLEN, "?");
}
strncpy(buf, buf_ipv6, MAX_FROM_LEN);
} else {
/* IPv4 */
if (!inet_ntop(AF_INET, &ut_addr_v6[0], buf, sizeof(buf))) {
snprintf(buf, MAX_FROM_LEN, "?");
}
}
buf[MAX_FROM_LEN] = 0;
for (len = strlen(buf); len < MAX_FROM_LEN; len++) buf[len]=' ';
buf[MAX_FROM_LEN] = 0;
fputs(buf, stdout);
} else {
print_host(u->ut_host, sizeof u->ut_host);
}
} }
/***** compact 7 char format for time intervals (belongs in libproc?) */ /***** compact 7 char format for time intervals (belongs in libproc?) */
@ -208,7 +169,7 @@ static const proc_t *getproc(const utmp_t *restrict const u, const char *restric
/***** showinfo */ /***** showinfo */
static void showinfo(utmp_t *u, int formtype, int maxcmd, int from, int ip_addresses) { static void showinfo(utmp_t *u, int formtype, int maxcmd, int from) {
unsigned long long jcpu; unsigned long long jcpu;
int ut_pid_found; int ut_pid_found;
unsigned i; unsigned i;
@ -235,7 +196,7 @@ static void showinfo(utmp_t *u, int formtype, int maxcmd, int from, int ip_addre
if (formtype) { if (formtype) {
printf("%-9.8s%-9.8s", uname, u->ut_line); printf("%-9.8s%-9.8s", uname, u->ut_line);
if (from) if (from)
print_from(u, ip_addresses); print_host(u->ut_host, sizeof u->ut_host);
print_logintime(u->ut_time, stdout); print_logintime(u->ut_time, stdout);
if (*u->ut_line == ':') /* idle unknown for xdm logins */ if (*u->ut_line == ':') /* idle unknown for xdm logins */
printf(" ?xdm? "); printf(" ?xdm? ");
@ -250,7 +211,7 @@ static void showinfo(utmp_t *u, int formtype, int maxcmd, int from, int ip_addre
} else { } else {
printf("%-9.8s%-9.8s", u->ut_user, u->ut_line); printf("%-9.8s%-9.8s", u->ut_user, u->ut_line);
if (from) if (from)
print_from(u, ip_addresses); print_host(u->ut_host, sizeof u->ut_host);
if (*u->ut_line == ':') /* idle unknown for xdm logins */ if (*u->ut_line == ':') /* idle unknown for xdm logins */
printf(" ?xdm? "); printf(" ?xdm? ");
else else
@ -272,22 +233,14 @@ int main(int argc, char **argv) {
char *user = NULL; char *user = NULL;
utmp_t *u; utmp_t *u;
struct winsize win; struct winsize win;
int args; int header=1, longform=1, from=1, args, maxcmd=80, ch;
int maxcmd = 80;
int ch;
/* defaults */
int header = 1;
int longform = 1;
int from = 1;
int ip_addresses = 0;
#ifndef W_SHOWFROM #ifndef W_SHOWFROM
from = 0; from = 0;
#endif #endif
setlocale(LC_ALL, ""); setlocale(LC_ALL, "");
for (args=0; (ch = getopt(argc, argv, "hlusfnV")) != EOF; args++) for (args=0; (ch = getopt(argc, argv, "hlusfV")) != EOF; args++)
switch (ch) { switch (ch) {
case 'h': header = 0; break; case 'h': header = 0; break;
case 'l': longform = 1; break; case 'l': longform = 1; break;
@ -295,7 +248,6 @@ int main(int argc, char **argv) {
case 'f': from = !from; break; case 'f': from = !from; break;
case 'V': display_version(); exit(0); case 'V': display_version(); exit(0);
case 'u': ignoreuser = 1; break; case 'u': ignoreuser = 1; break;
case 'n': ip_addresses = 1; break;
default: default:
printf("usage: w -hlsufV [user]\n" printf("usage: w -hlsufV [user]\n"
" -h skip header\n" " -h skip header\n"
@ -303,7 +255,6 @@ int main(int argc, char **argv) {
" -s short listing\n" " -s short listing\n"
" -u ignore uid of processes\n" " -u ignore uid of processes\n"
" -f toggle FROM field (default %s)\n" " -f toggle FROM field (default %s)\n"
" -n use IP addresses instead of hostname\n"
" -V display version\n", FROM_STRING); " -V display version\n", FROM_STRING);
exit(1); exit(1);
} }
@ -341,14 +292,14 @@ int main(int argc, char **argv) {
u = getutent(); u = getutent();
if (unlikely(!u)) break; if (unlikely(!u)) break;
if (u->ut_type != USER_PROCESS) continue; if (u->ut_type != USER_PROCESS) continue;
if (!strncmp(u->ut_user, user, USERSZ)) showinfo(u, longform, maxcmd, from, ip_addresses); if (!strncmp(u->ut_user, user, USERSZ)) showinfo(u, longform, maxcmd, from);
} }
} else { } else {
for (;;) { for (;;) {
u = getutent(); u = getutent();
if (unlikely(!u)) break; if (unlikely(!u)) break;
if (u->ut_type != USER_PROCESS) continue; if (u->ut_type != USER_PROCESS) continue;
if (*u->ut_user) showinfo(u, longform, maxcmd, from, ip_addresses); if (*u->ut_user) showinfo(u, longform, maxcmd, from);
} }
} }
endutent(); endutent();