63 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| 			     BASH PATCH REPORT
 | |
| 			     =================
 | |
| 
 | |
| Bash-Release:	4.2
 | |
| Patch-ID:	bash42-023
 | |
| 
 | |
| Bug-Reported-by:	Ewan Mellor <Ewan.Mellor@eu.citrix.com>
 | |
| Bug-Reference-ID:	<6005BE083BF501439A84DC3523BAC82DC4B964FD12@LONPMAILBOX01.citrite.net>
 | |
| Bug-Reference-URL:	
 | |
| 
 | |
| Bug-Description:
 | |
| 
 | |
| Under some circumstances, an exit trap triggered by a bad substitution
 | |
| error when errexit is enabled will cause the shell to exit with an
 | |
| incorrect exit status (0).
 | |
| 
 | |
| Patch (apply with `patch -p0'):
 | |
| 
 | |
| *** ../bash-4.2-patched/subst.c	2011-11-21 12:04:38.000000000 -0500
 | |
| --- subst.c	2012-02-08 13:36:28.000000000 -0500
 | |
| ***************
 | |
| *** 7275,7278 ****
 | |
| --- 7281,7285 ----
 | |
|       case '\0':
 | |
|       bad_substitution:
 | |
| +       last_command_exit_value = EXECUTION_FAILURE;
 | |
|         report_error (_("%s: bad substitution"), string ? string : "??");
 | |
|         FREE (value);
 | |
| *** ../bash-4.2-patched/error.c	2009-08-21 22:31:31.000000000 -0400
 | |
| --- error.c	2012-02-25 15:54:40.000000000 -0500
 | |
| ***************
 | |
| *** 201,205 ****
 | |
|     va_end (args);
 | |
|     if (exit_immediately_on_error)
 | |
| !     exit_shell (1);
 | |
|   }
 | |
|   
 | |
| --- 201,209 ----
 | |
|     va_end (args);
 | |
|     if (exit_immediately_on_error)
 | |
| !     {
 | |
| !       if (last_command_exit_value == 0)
 | |
| ! 	last_command_exit_value = 1;
 | |
| !       exit_shell (last_command_exit_value);
 | |
| !     }
 | |
|   }
 | |
|   
 | |
| *** ../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 22
 | |
|   
 | |
|   #endif /* _PATCHLEVEL_H_ */
 | |
| --- 26,30 ----
 | |
|      looks for to find the patch level (for the sccs version string). */
 | |
|   
 | |
| ! #define PATCHLEVEL 23
 | |
|   
 | |
|   #endif /* _PATCHLEVEL_H_ */
 |