Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/netbsd-9]: src/usr.bin/w Pull up following revision(s) (requested by kim...
details: https://anonhg.NetBSD.org/src/rev/0cf537d595ac
branches: netbsd-9
changeset: 963975:0cf537d595ac
user: martin <martin%NetBSD.org@localhost>
date: Tue Jul 07 10:43:00 2020 +0000
description:
Pull up following revision(s) (requested by kim in ticket #982):
usr.bin/w/w.c: revision 1.87
Don't overwrite host_buf as x might be pointing to wanted data in it
diffstat:
usr.bin/w/w.c | 22 ++++++++++++----------
1 files changed, 12 insertions(+), 10 deletions(-)
diffs (63 lines):
diff -r e5ecd28d2347 -r 0cf537d595ac usr.bin/w/w.c
--- a/usr.bin/w/w.c Tue Jul 07 10:40:46 2020 +0000
+++ b/usr.bin/w/w.c Tue Jul 07 10:43:00 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: w.c,v 1.84.2.1 2020/06/30 18:48:00 martin Exp $ */
+/* $NetBSD: w.c,v 1.84.2.2 2020/07/07 10:43:00 martin Exp $ */
/*-
* Copyright (c) 1980, 1991, 1993, 1994
@@ -39,7 +39,7 @@
#if 0
static char sccsid[] = "@(#)w.c 8.6 (Berkeley) 6/30/94";
#else
-__RCSID("$NetBSD: w.c,v 1.84.2.1 2020/06/30 18:48:00 martin Exp $");
+__RCSID("$NetBSD: w.c,v 1.84.2.2 2020/07/07 10:43:00 martin Exp $");
#endif
#endif /* not lint */
@@ -621,7 +621,7 @@
fixhost(struct entry *ep)
{
char host_buf[sizeof(ep->host)];
- char *p, *x, *m;
+ char *p, *r, *x, *m;
struct hostent *hp;
union {
struct in_addr l4;
@@ -649,26 +649,28 @@
} else
x = NULL;
}
+
int af = m ? AF_INET6 : AF_INET;
size_t alen = m ? sizeof(l.l6) : sizeof(l.l4);
if (!nflag && inet_pton(af, p, &l) &&
(hp = gethostbyaddr((char *)&l, alen, af)))
- strlcpy(host_buf, hp->h_name, sizeof(host_buf));
+ r = hp->h_name;
+ else
+ r = host_buf;
if (domain[0] != '\0') {
- p = host_buf;
- p += strlen(host_buf);
+ p = r;
+ p += strlen(r);
p -= strlen(domain);
- if (p > host_buf &&
+ if (p > r &&
strcasecmp(p, domain) == 0)
*p = '\0';
}
if (x)
- (void)snprintf(ep->host, sizeof(ep->host), "%s:%s", host_buf,
- x);
+ (void)snprintf(ep->host, sizeof(ep->host), "%s:%s", r, x);
else
- strlcpy(ep->host, host_buf, sizeof(ep->host));
+ strlcpy(ep->host, r, sizeof(ep->host));
}
static void
Home |
Main Index |
Thread Index |
Old Index