From: Craig Small Date: Sat, 17 Mar 2012 21:22:07 +0000 (+1100) Subject: watch -g exits early X-Git-Tag: v3.3.3~30 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=ce82c3ea37164d089f9cb697be577ea62407b8cd;p=procps-ng watch -g exits early Patch supplied by Kent R. Spillner . Previous watch -g would do the following: unchanged screen (wait) changed screen (wait) (exit) Now it exits right after the screen changes. --- diff --git a/watch.c b/watch.c index 6ce174ba..2afde1dc 100644 --- a/watch.c +++ b/watch.c @@ -308,7 +308,6 @@ int main(int argc, char *argv[]) int pipefd[2]; int status; - int exit_early = 0; pid_t child; static struct option longopts[] = { @@ -446,7 +445,7 @@ int main(int argc, char *argv[]) if (precise_timekeeping) next_loop = get_time_usec(); - do { + while (1) { time_t t = time(NULL); char *ts = ctime(&t); int tsl = strlen(ts); @@ -581,6 +580,7 @@ int main(int argc, char *argv[]) if ((p = fdopen(pipefd[0], "r")) == NULL) xerr(5, _("fdopen")); + int exit_early = 0; for (y = show_title; y < height; y++) { int eolseen = 0, tabpending = 0; #ifdef WITH_WATCH8BIT @@ -730,6 +730,10 @@ int main(int argc, char *argv[]) } first_screen = 0; refresh(); + + if (exit_early) + break; + if (precise_timekeeping) { watch_usec_t cur_time = get_time_usec(); next_loop += USECS_PER_SEC * interval; @@ -737,7 +741,7 @@ int main(int argc, char *argv[]) usleep(next_loop - cur_time); } else usleep(interval * 1000000); - } while (!exit_early); + } endwin();