75 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| 			     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_ */
 | 
