From d747659ad80ac6e704ce0bc11150d13ab1622f6b Mon Sep 17 00:00:00 2001 From: Jim Warner Date: Wed, 12 Dec 2012 00:00:00 -0600 Subject: [PATCH] top: follow ps lead, allow core dumps where applicable Reference(s): Bug-Redhat: https://bugzilla.redhat.com/871825 commit c1f10d11bc7fbab3af54a2b16e6db721b7e44f5c http://www.freelists.org/post/procps/PATCH-Allow-core-file-generation-by-ps-command-rhbz871825-rhbz512857 Signed-off-by: Jim Warner --- top/top.c | 22 ++++++++++++++++------ top/top.h | 1 + top/top_nls.c | 2 +- 3 files changed, 18 insertions(+), 7 deletions(-) diff --git a/top/top.c b/top/top.c index 2d3f63cc..7df93888 100644 --- a/top/top.c +++ b/top/top.c @@ -314,9 +314,8 @@ static const char *tg2 (int x, int y) { /*###### Exit/Interrput routines #######################################*/ /* - * The real program end */ -static void bye_bye (const char *str) NORETURN; -static void bye_bye (const char *str) { + * Reset the tty, if necessary */ +static void at_eoj (void) { if (Ttychanged) { if (keypad_local) putp(keypad_local); tcsetattr(STDIN_FILENO, TCSAFLUSH, &Tty_original); @@ -325,9 +324,18 @@ static void bye_bye (const char *str) { #ifndef RMAN_IGNORED putp(Cap_smam); #endif + putp("\n"); + Ttychanged = 0; } fflush(stdout); +} // end: + + /* + * The real program end */ +static void bye_bye (const char *str) NORETURN; +static void bye_bye (const char *str) { + at_eoj(); // restore tty in preparation for exit #ifdef ATEOJ_RPTSTD { proc_t *p; if (!str && Ttychanged) { fprintf(stderr, @@ -478,7 +486,6 @@ static void bye_bye (const char *str) { fputs(str, stderr); exit(EXIT_FAILURE); } - putp("\n"); exit(EXIT_SUCCESS); } // end: bye_bye @@ -535,13 +542,16 @@ static void pause_pgm (void) { /* * Catches all remaining signals not otherwise handled */ -static void sig_abexit (int sig) NORETURN; static void sig_abexit (int sig) { sigset_t ss; sigfillset(&ss); sigprocmask(SIG_BLOCK, &ss, NULL); - bye_bye(fmtmk(N_fmt(EXIT_signals_fmt), sig, signal_number_to_name(sig), Myname)); + at_eoj(); // restore tty in preparation for exit + fprintf(stderr, N_fmt(EXIT_signals_fmt) + , sig, signal_number_to_name(sig), Myname); + signal(sig, SIG_DFL); // allow core dumps, if applicable + raise(sig); // ( plus set proper return code ) } // end: sig_abexit diff --git a/top/top.h b/top/top.h index 7f8e96f0..9f052305 100644 --- a/top/top.h +++ b/top/top.h @@ -600,6 +600,7 @@ typedef struct WIN_t { //atic inline char *scat (char *dst, const char *src); //atic const char *tg2 (int x, int y); /*------ Exit/Interrput routines ---------------------------------------*/ +//atic void at_eoj (void); //atic void bye_bye (const char *str); //atic void error_exit (const char *str); //atic void library_err (const char *fmts, ...); diff --git a/top/top_nls.c b/top/top_nls.c index 16ce5fb8..80d9b080 100644 --- a/top/top_nls.c +++ b/top/top_nls.c @@ -273,7 +273,7 @@ static void build_norm_nlstab (void) { . c-code logic changes. . */ - Norm_nlstab[EXIT_signals_fmt] = _("\n" + Norm_nlstab[EXIT_signals_fmt] = _("" "\tsignal %d (%s) was caught by %s, please\n" "\tsee http://www.debian.org/Bugs/Reporting\n"); Norm_nlstab[WRONG_switch_fmt] = _("" -- 2.40.0