1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- BASH PATCH REPORT
- =================
- Bash-Release: 4.2
- Patch-ID: bash42-008
- Bug-Reported-by: Doug McMahon <mc2man@optonline.net>
- Bug-Reference-ID: <1299441211.2535.11.camel@doug-XPS-M1330>
- Bug-Reference-URL: http://lists.gnu.org/archive/html/bug-bash/2011-03/msg00050.html
- Bug-Description:
- Bash-4.2 does not attempt to save the shell history on receipt of a
- terminating signal that is handled synchronously. Unfortunately, the
- `close' button on most X11 terminal emulators sends SIGHUP, which
- kills the shell.
- This is a very small patch to save the history in the case that an
- interactive shell receives a SIGHUP or SIGTERM while in readline and
- reading a command.
- The next version of bash will do this differently.
- Patch (apply with `patch -p0'):
- *** ../bash-4.2-patched/sig.c Tue Nov 23 08:21:22 2010
- --- ./sig.c Tue Mar 8 21:28:32 2011
- ***************
- *** 47,50 ****
- --- 47,51 ----
- #if defined (READLINE)
- # include "bashline.h"
- + # include <readline/readline.h>
- #endif
-
- ***************
- *** 63,66 ****
- --- 64,68 ----
- extern int history_lines_this_session;
- #endif
- + extern int no_line_editing;
-
- extern void initialize_siglist ();
- ***************
- *** 506,510 ****
- #if defined (HISTORY)
- /* XXX - will inhibit history file being written */
- ! history_lines_this_session = 0;
- #endif
- terminate_immediately = 0;
- --- 508,515 ----
- #if defined (HISTORY)
- /* XXX - will inhibit history file being written */
- ! # if defined (READLINE)
- ! if (interactive_shell == 0 || interactive == 0 || (sig != SIGHUP && sig != SIGTERM) || no_line_editing || (RL_ISSTATE (RL_STATE_READCMD) == 0))
- ! # endif
- ! history_lines_this_session = 0;
- #endif
- terminate_immediately = 0;
- *** ../bash-4.2-patched/patchlevel.h Sat Jun 12 20:14:48 2010
- --- ./patchlevel.h Thu Feb 24 21:41:34 2011
- ***************
- *** 26,30 ****
- looks for to find the patch level (for the sccs version string). */
-
- ! #define PATCHLEVEL 7
-
- #endif /* _PATCHLEVEL_H_ */
- --- 26,30 ----
- looks for to find the patch level (for the sccs version string). */
-
- ! #define PATCHLEVEL 8
-
- #endif /* _PATCHLEVEL_H_ */
|