-/* $NetBSD: progress.c,v 1.2 2003/01/22 03:13:32 enami Exp $ */
+/* $NetBSD: progress.c,v 1.7 2003/02/12 00:58:34 ross Exp $ */
/*-
* Copyright (c) 2003 The NetBSD Foundation, Inc.
#include <sys/cdefs.h>
#ifndef lint
-__RCSID("$NetBSD: progress.c,v 1.2 2003/01/22 03:13:32 enami Exp $");
+__RCSID("$NetBSD: progress.c,v 1.7 2003/02/12 00:58:34 ross Exp $");
#endif /* not lint */
#include <sys/types.h>
{
static char fb_buf[BUFSIZ];
char *infile = NULL;
- pid_t pid;
+ pid_t pid = 0, gzippid = 0;
int ch, fd, outpipe[2], waitstat;
int lflag = 0, zflag = 0;
ssize_t nr, nw, off;
struct stat statb;
+ struct ttysize ts;
setprogname(argv[0]);
}
/* Pipe input through gzip -dc if -z is given */
if (zflag) {
- pid_t gzippid;
int gzippipe[2];
if (pipe(gzippipe) < 0)
bytes = 0;
progress = 1;
ttyout = stdout;
- ttywidth = 80;
+
+ if (ioctl(fileno(ttyout), TIOCGSIZE, &ts) == -1) {
+ ttywidth = 80;
+ } else
+ ttywidth = ts.ts_cols;
if (pipe(outpipe) < 0)
err(1, "output pipe");
for (off = 0; nr; nr -= nw, off += nw, bytes += nw)
if ((nw = write(outpipe[1], fb_buf + off,
(size_t) nr)) < 0)
- err(1, "writing %d bytes to output pipe", nr);
+ err(1, "writing %u bytes to output pipe",
+ (unsigned) nr);
close(outpipe[1]);
- wait(&waitstat);
+ while (pid || gzippid) {
+ int deadpid;
+
+ deadpid = wait(&waitstat);
+
+ if (deadpid == pid)
+ pid = 0;
+ else if (deadpid == gzippid)
+ gzippid = 0;
+ else if (deadpid != -1)
+ continue;
+ else if (errno == EINTR)
+ continue;
+ else break;
+ }
progressmeter(1);
return 0;