Revert -n flag for w
This commit is contained in:
parent
a26c3bfa39
commit
3f59ff5a16
69
w.c
69
w.c
@ -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();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user