From bd8bd7340f108a4e88ac07ba892160ffe92748f1 Mon Sep 17 00:00:00 2001 From: ghudson Date: Tue, 13 Feb 1996 16:49:10 +0000 Subject: [PATCH] Don't rely on select() not to modify the timeval argument. Also, simplify the code by passing in NULL rather than an empty fd_set to indicate no file descriptors. --- usr.bin/tail/forward.c | 25 ++++++++++--------------- 1 file changed, 10 insertions(+), 15 deletions(-) diff --git a/usr.bin/tail/forward.c b/usr.bin/tail/forward.c index 543dab173430..c5eb266a45b6 100644 --- a/usr.bin/tail/forward.c +++ b/usr.bin/tail/forward.c @@ -1,4 +1,4 @@ -/* $NetBSD: forward.c,v 1.6 1994/11/23 07:42:02 jtc Exp $ */ +/* $NetBSD: forward.c,v 1.7 1996/02/13 16:49:10 ghudson Exp $ */ /*- * Copyright (c) 1991, 1993 @@ -40,7 +40,7 @@ #if 0 static char sccsid[] = "@(#)forward.c 8.1 (Berkeley) 6/6/93"; #endif -static char rcsid[] = "$NetBSD: forward.c,v 1.6 1994/11/23 07:42:02 jtc Exp $"; +static char rcsid[] = "$NetBSD: forward.c,v 1.7 1996/02/13 16:49:10 ghudson Exp $"; #endif /* not lint */ #include @@ -90,7 +90,6 @@ forward(fp, style, off, sbp) { register int ch; struct timeval second; - fd_set zero; switch(style) { case FBYTES: @@ -163,16 +162,6 @@ forward(fp, style, off, sbp) break; } - /* - * We pause for one second after displaying any data that has - * accumulated since we read the file. - */ - if (fflag) { - FD_ZERO(&zero); - second.tv_sec = 1; - second.tv_usec = 0; - } - for (;;) { while ((ch = getc(fp)) != EOF) if (putchar(ch) == EOF) @@ -184,8 +173,14 @@ forward(fp, style, off, sbp) (void)fflush(stdout); if (!fflag) break; - /* Sleep(3) is eight system calls. Do it fast. */ - if (select(0, &zero, &zero, &zero, &second) == -1) + /* + * We pause for one second after displaying any data that has + * accumulated since we read the file. Since sleep(3) takes + * eight system calls, use select() instead. + */ + second.tv_sec = 1; + second.tv_usec = 0; + if (select(0, NULL, NULL, NULL, &second) == -1) err(1, "select: %s", strerror(errno)); clearerr(fp); }