progress: treat "no terminal" as being in the foreground
authorJeff King <peff@peff.net>
Tue, 19 May 2015 05:24:57 +0000 (01:24 -0400)
committerJunio C Hamano <gitster@pobox.com>
Tue, 19 May 2015 16:35:14 +0000 (09:35 -0700)
progress: treat "no terminal" as being in the foreground

Commit 85cb890 (progress: no progress in background,
2015-04-13) avoids sending progress from background
processes by checking that the process group id of the
current process is the same as that of the controlling
terminal.

If we don't have a terminal, however, this check never
succeeds, and we print no progress at all (until the final
"done" message). This can be seen when cloning a large
repository; instead of getting progress updates for
"counting objects", it will appear to hang then print the
final count.

We can fix this by treating an error return from tcgetpgrp()
as a signal to show the progress.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
progress.c
index 43d9228378858d91f759acd7dbdbcade4de7b46b..2e31bec60f5c98dc7dac69227759cbf2ba5f9974 100644 (file)
@@ -74,7 +74,8 @@ static void clear_progress_signal(void)
 
 static int is_foreground_fd(int fd)
 {
-       return getpgid(0) == tcgetpgrp(fd);
+       int tpgrp = tcgetpgrp(fd);
+       return tpgrp < 0 || tpgrp == getpgid(0);
 }
 
 static int display(struct progress *progress, unsigned n, const char *done)