From df645e2acdb9b914fe214cbc5d436006a442fcbc Mon Sep 17 00:00:00 2001 From: Jaromir Capik Date: Mon, 1 Jul 2013 19:19:45 +0200 Subject: [PATCH] - Disabling screen content restoration when exiting 'top' (#977561) - Enabling SIGWINCH flood prevention --- ...n-contents-preservation-at-end-of-jo.patch | 150 ++++++++++++++++++ procps-ng.spec | 11 +- 2 files changed, 159 insertions(+), 2 deletions(-) create mode 100644 0001-top-enable-screen-contents-preservation-at-end-of-jo.patch diff --git a/0001-top-enable-screen-contents-preservation-at-end-of-jo.patch b/0001-top-enable-screen-contents-preservation-at-end-of-jo.patch new file mode 100644 index 0000000..131da97 --- /dev/null +++ b/0001-top-enable-screen-contents-preservation-at-end-of-jo.patch @@ -0,0 +1,150 @@ +From b765e587bf737efffbfe4fff087452de7a090708 Mon Sep 17 00:00:00 2001 +From: Jim Warner +Date: Fri, 28 Jun 2013 00:00:00 -0500 +Subject: [PATCH] top: enable screen contents preservation at end-of-job + +The title of this commit is actually quite misleading. + +Were it more accurate, it would at least mention a tty +emulator's scrollback buffer, which was the cumulation +of a long pursuit to reduce the SIGWINCH overhead when +a window manager carelessly floods an application with +that signal *while* a user is still resizing a window! + +Disabling and enabling that scrollback buffer resulted +in the final top display replaced with original screen +contents, a phenomenon acknowledged at the time but it +also represented a user interface change which has now +produced the first request for return to old behavior. + +After the SIGWINCH dust settled, another problem arose +regarding behaviors under the 'screen' window manager. +In response, top was refactored a bit to avoid display +corruption. That was before discovering 'screen' could +duplicate the scrollback buffer behavior top expected. + +As it turns out, the 'screen' refactoring had probably +made scrollback buffer manipulation unnecessary. Still +one could argue that a window should not be allowed to +scroll while a constantly updating program was active. + +The solution represented in this commit returns former +behavior at program end (retaining top's last screen). +And if we ever wish to disable scrollback buffers, the +associated logic was retained but made conditional. It +is not reflected in configure.ac but might be someday. + +Lastly, this commit corrects cursor positioning when a +^C is issued under 'Fields Management' at any terminal +that didn't have a scrollback buffer (i.e. a console). + +Reference(s): +https://bugzilla.redhat.com/show_bug.cgi?id=977561 +http://www.freelists.org/post/procps/top-library-miscellaneous-tweaks,1 +. screen program refactor +commit 0fe393ff270922cd4f6edbcaabba006314e73a37 +. scrollback buffer disabled +commit dedaf6e1a81738ff08ee8e8523871e12f555ad6d +. sigwinch management defines +commit adca737758e5afc7be344a736953931894cbc19f +commit 4f33b6b8c56464b4044deb29a3bb0e32622e108f + +Signed-off-by: Jim Warner +--- + top/top.c | 18 +++++++++++------- + top/top.h | 1 + + 2 files changed, 12 insertions(+), 7 deletions(-) + +diff --git a/top/top.c b/top/top.c +index 1d38c0f..cdcf3c0 100644 +--- a/top/top.c ++++ b/top/top.c +@@ -72,8 +72,9 @@ static struct termios Tty_original, // our inherited terminal definition + Tty_raw; // for unsolicited input + static int Ttychanged = 0; + +- /* Last established cursor state/shape */ ++ /* Last established cursor state/shape, and is re-position needed */ + static const char *Cursor_state = ""; ++static int Cursor_repos; + + /* Program name used in error messages and local 'rc' file name */ + static char *Myname; +@@ -350,12 +351,15 @@ static void at_eoj (void) { + if (Ttychanged) { + tcsetattr(STDIN_FILENO, TCSAFLUSH, &Tty_original); + if (keypad_local) putp(keypad_local); ++ if (Cursor_repos) putp(tg2(0, Screen_rows)); + putp("\n"); ++#ifdef OFF_SCROLLBK + if (exit_ca_mode) { + // this next will also replace top's most recent screen with the + // original display contents that were visible at our invocation + putp(exit_ca_mode); + } ++#endif + putp(Cap_curs_norm); + putp(Cap_clr_eol); + #ifndef RMAN_IGNORED +@@ -591,17 +595,13 @@ static void sig_endpgm (int dont_care_sig) { + + /* + * Catches: +- * SIGTSTP, SIGTTIN and SIGTTOU +- * note: +- * we don't fiddle with with those enter/exit_ca_mode strings +- * because we want to retain most of the last screen contents +- * as a visual reminder this program is suspended, not ended! */ ++ * SIGTSTP, SIGTTIN and SIGTTOU */ + static void sig_paused (int dont_care_sig) { + // POSIX.1-2004 async-signal-safe: tcsetattr, tcdrain, raise + if (-1 == tcsetattr(STDIN_FILENO, TCSAFLUSH, &Tty_original)) + error_exit(fmtmk(N_fmt(FAIL_tty_set_fmt), strerror(errno))); + if (keypad_local) putp(keypad_local); +- putp(tg2(0, Screen_rows)); ++ if (Cursor_repos) putp(tg2(0, Screen_rows)); + putp(Cap_curs_norm); + #ifndef RMAN_IGNORED + putp(Cap_smam); +@@ -2120,6 +2120,7 @@ static void fields_utility (void) { + int i, key; + FLG_t f; + ++ Cursor_repos = 1; + spewFI + signify_that: + putp(Cap_clr_scr); +@@ -2180,6 +2181,7 @@ signify_that: + break; + } + } while (key != 'q' && key != kbd_ESC); ++ Cursor_repos = 0; + #undef unSCRL + #undef swapEM + #undef spewFI +@@ -3768,8 +3770,10 @@ static void whack_terminal (void) { + // thanks anyway stdio, but we'll manage buffering at the frame level... + setbuffer(stdout, Stdout_buf, sizeof(Stdout_buf)); + #endif ++#ifdef OFF_SCROLLBK + // this has the effect of disabling any troublesome scrollback buffer... + if (enter_ca_mode) putp(enter_ca_mode); ++#endif + // and don't forget to ask iokey to initialize his tinfo_tab + iokey(0); + } // end: whack_terminal +diff --git a/top/top.h b/top/top.h +index f356798..a8a7357 100644 +--- a/top/top.h ++++ b/top/top.h +@@ -41,6 +41,7 @@ + //#define INSP_SAVEBUF /* preserve 'Insp_buf' contents in a file */ + //#define INSP_SLIDE_1 /* when scrolling left/right don't move 8 */ + //#define OFF_HST_HASH /* use BOTH qsort+bsrch vs. hashing scheme */ ++//#define OFF_SCROLLBK /* disable tty emulators scrollback buffer */ + //#define OFF_STDIOLBF /* disable our own stdout _IOFBF override */ + //#define PRETEND2_5_X /* pretend we're linux 2.5.x (for IO-wait) */ + //#define PRETEND8CPUS /* pretend we're smp with 8 ticsers (sic) */ +-- +1.8.1.2 + diff --git a/procps-ng.spec b/procps-ng.spec index 0a1ad4c..aac7e34 100644 --- a/procps-ng.spec +++ b/procps-ng.spec @@ -4,7 +4,7 @@ Summary: System and process monitoring utilities Name: procps-ng Version: 3.3.8 -Release: 6%{?dist} +Release: 7%{?dist} License: GPLv2+ and LGPLv2+ Group: Applications/System URL: https://sourceforge.net/projects/procps-ng/ @@ -13,6 +13,7 @@ Source: http://downloads.sourceforge.net/%{name}/%{name}-%{version}.tar.xz Patch0: 0001-top-add-the-major-version-to-dlopen-of-libnuma-sonam.patch Patch1: 0002-library-for-atexit-support-fix-fileutils-for-EPIPE.patch +Patch2: 0001-top-enable-screen-contents-preservation-at-end-of-jo.patch Requires(post): /sbin/ldconfig Requires(postun): /sbin/ldconfig @@ -70,6 +71,7 @@ System and process monitoring utilities development headers %patch0 -p1 %patch1 -p1 +%patch2 -p1 %build # The following stuff is needed for git archives only @@ -91,7 +93,8 @@ autoreconf --verbose --force --install --disable-kill \ --disable-rpath \ --enable-watch8bit \ - --enable-skill + --enable-skill \ + --enable-sigwinch make CFLAGS="%{optflags}" @@ -134,6 +137,10 @@ mkdir -p %{buildroot}%{_sysconfdir}/sysctl.d %{_includedir}/proc %changelog +* Mon Jul 01 2013 Jaromir Capik - 3.3.8-7 +- Disabling screen content restoration when exiting 'top' (#977561) +- Enabling SIGWINCH flood prevention + * Wed Jun 26 2013 Jaromir Capik - 3.3.8-6 - Avoiding "write error" messages when piping to grep (#976199)