Module Name: src Committed By: dennis Date: Mon Dec 22 15:24:14 UTC 2014
Modified Files: src/usr.bin/w: w.c Log Message: Move enough additional 'w' code into 'uptime' to keep the latter from double-counting utmp users. To generate a diff of this commit: cvs rdiff -u -r1.81 -r1.82 src/usr.bin/w/w.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/usr.bin/w/w.c diff -u src/usr.bin/w/w.c:1.81 src/usr.bin/w/w.c:1.82 --- src/usr.bin/w/w.c:1.81 Wed Dec 3 06:12:19 2014 +++ src/usr.bin/w/w.c Mon Dec 22 15:24:14 2014 @@ -1,4 +1,4 @@ -/* $NetBSD: w.c,v 1.81 2014/12/03 06:12:19 mrg Exp $ */ +/* $NetBSD: w.c,v 1.82 2014/12/22 15:24:14 dennis Exp $ */ /*- * Copyright (c) 1980, 1991, 1993, 1994 @@ -39,7 +39,7 @@ __COPYRIGHT("@(#) Copyright (c) 1980, 19 #if 0 static char sccsid[] = "@(#)w.c 8.6 (Berkeley) 6/30/94"; #else -__RCSID("$NetBSD: w.c,v 1.81 2014/12/03 06:12:19 mrg Exp $"); +__RCSID("$NetBSD: w.c,v 1.82 2014/12/22 15:24:14 dennis Exp $"); #endif #endif /* not lint */ @@ -222,18 +222,26 @@ main(int argc, char **argv) continue; ++nusers; +#ifndef SUPPORT_UTMP if (wcmd == 0) continue; +#endif /* !SUPPORT_UTMP */ if (sel_user && strncmp(utx->ut_name, sel_user, sizeof(utx->ut_name)) != 0) continue; if ((ep = calloc(1, sizeof(struct entry))) == NULL) err(1, NULL); - (void)memcpy(ep->name, utx->ut_name, sizeof(utx->ut_name)); (void)memcpy(ep->line, utx->ut_line, sizeof(utx->ut_line)); - ep->name[sizeof(utx->ut_name)] = '\0'; ep->line[sizeof(utx->ut_line)] = '\0'; + *nextp = ep; + nextp = &(ep->next); + + if (wcmd == 0) + continue; + + (void)memcpy(ep->name, utx->ut_name, sizeof(utx->ut_name)); + ep->name[sizeof(utx->ut_name)] = '\0'; if (!nflag || getnameinfo((struct sockaddr *)&utx->ut_ss, utx->ut_ss.ss_len, ep->host, sizeof(ep->host), NULL, 0, NI_NUMERICHOST) != 0) { @@ -245,10 +253,7 @@ main(int argc, char **argv) ep->type[0] = 'x'; ep->tv = utx->ut_tv; ep->pid = utx->ut_pid; - *nextp = ep; - nextp = &(ep->next); - if (wcmd != 0) - process(ep); + process(ep); } #endif