From 31d961e34ab55b9ca117095da2a3d29e239b488c Mon Sep 17 00:00:00 2001 From: ume Date: Fri, 27 Jan 2006 08:52:14 +0000 Subject: make wall(1) work with pts. --- usr.bin/wall/ttymsg.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'usr.bin') diff --git a/usr.bin/wall/ttymsg.c b/usr.bin/wall/ttymsg.c index 131cf2c..a977875 100644 --- a/usr.bin/wall/ttymsg.c +++ b/usr.bin/wall/ttymsg.c @@ -68,14 +68,18 @@ ttymsg(struct iovec *iov, int iovcnt, const char *line, int tmout) int cnt, fd; static char device[MAXNAMLEN] = _PATH_DEV; static char errbuf[1024]; + char *p; int forked; forked = 0; if (iovcnt > (int)(sizeof(localiov) / sizeof(localiov[0]))) return ("too many iov's (change code in wall/ttymsg.c)"); - strlcpy(device + sizeof(_PATH_DEV) - 1, line, sizeof(device)); - if (strchr(device + sizeof(_PATH_DEV) - 1, '/')) { + p = device + sizeof(_PATH_DEV) - 1; + strlcpy(p, line, sizeof(device)); + if (strncmp(p, "pts/", 4) == 0) + p += 4; + if (strchr(p, '/') != NULL) { /* A slash is an attempt to break security... */ (void) snprintf(errbuf, sizeof(errbuf), "Too many '/' in \"%s\"", device); -- cgit v1.1