fixed e and x options in watch

The -e option would print a confusing error message. This is because
most error messages in watch are one word.  This fix makes a more
sensible message about what went wrong.

The -x option exited before the endwin() function was called, so if the
child process died the terminal was left in a funky state. endwin is now
called just before the exit(8) for the -x option.
This commit is contained in:
Craig Small 2012-01-04 09:18:16 +11:00
parent 3388f65c03
commit f776e59123

16
watch.c
View File

@ -519,7 +519,7 @@ int main(int argc, char *argv[])
/* allocate pipes */ /* allocate pipes */
if (pipe(pipefd) < 0) if (pipe(pipefd) < 0)
err(7, _("pipe")); xerr(7, _("Unable to create IPC pipes"));
/* flush stdout and stderr, since we're about to do fd stuff */ /* flush stdout and stderr, since we're about to do fd stuff */
fflush(stdout); fflush(stdout);
@ -529,18 +529,18 @@ int main(int argc, char *argv[])
child = fork(); child = fork();
if (child < 0) { /* fork error */ if (child < 0) { /* fork error */
err(2, _("fork")); xerr(2, _("Unable to fork process"));
} else if (child == 0) { /* in child */ } else if (child == 0) { /* in child */
close(pipefd[0]); /* child doesn't need read side of pipe */ close(pipefd[0]); /* child doesn't need read side of pipe */
close(1); /* prepare to replace stdout with pipe */ close(1); /* prepare to replace stdout with pipe */
if (dup2(pipefd[1], 1) < 0) { /* replace stdout with write side of pipe */ if (dup2(pipefd[1], 1) < 0) { /* replace stdout with write side of pipe */
err(3, _("dup2")); xerr(3, _("dup2 failed"));
} }
dup2(1, 2); /* stderr should default to stdout */ dup2(1, 2); /* stderr should default to stdout */
if (option_exec) { /* pass command to exec instead of system */ if (option_exec) { /* pass command to exec instead of system */
if (execvp(command_argv[0], command_argv) == -1) { if (execvp(command_argv[0], command_argv) == -1) {
err(4, _("exec")); xerr(4, _("Unable to execute '%s'"), command_argv[0]);
} }
} else { } else {
status = system(command); /* watch manpage promises sh quoting */ status = system(command); /* watch manpage promises sh quoting */
@ -558,7 +558,7 @@ int main(int argc, char *argv[])
/* otherwise, we're in parent */ /* otherwise, we're in parent */
close(pipefd[1]); /* close write side of pipe */ close(pipefd[1]); /* close write side of pipe */
if ((p = fdopen(pipefd[0], "r")) == NULL) if ((p = fdopen(pipefd[0], "r")) == NULL)
err(5, _("fdopen")); xerr(5, _("fdopen"));
for (y = show_title; y < height; y++) { for (y = show_title; y < height; y++) {
int eolseen = 0, tabpending = 0; int eolseen = 0, tabpending = 0;
@ -681,15 +681,17 @@ int main(int argc, char *argv[])
/* harvest child process and get status, propagated from command */ /* harvest child process and get status, propagated from command */
if (waitpid(child, &status, 0) < 0) if (waitpid(child, &status, 0) < 0)
err(8, _("waitpid")); xerr(8, _("waitpid"));
/* if child process exited in error, beep if option_beep is set */ /* if child process exited in error, beep if option_beep is set */
if ((!WIFEXITED(status) || WEXITSTATUS(status))) { if ((!WIFEXITED(status) || WEXITSTATUS(status))) {
if (option_beep) if (option_beep)
beep(); beep();
if (option_errexit) if (option_errexit) {
endwin();
exit(8); exit(8);
} }
}
first_screen = 0; first_screen = 0;
refresh(); refresh();