fix running the ERR and EXIT traps in case of set -e and/or eval (includes Debian #696823)
This commit is contained in:
		
							
								
								
									
										96
									
								
								check.t
									
									
									
									
									
								
							
							
						
						
									
										96
									
								
								check.t
									
									
									
									
									
								
							| @@ -1,10 +1,10 @@ | ||||
| # $MirOS: src/bin/mksh/check.t,v 1.583 2013/01/01 03:32:41 tg Exp $ | ||||
| # $MirOS: src/bin/mksh/check.t,v 1.584 2013/01/01 20:45:00 tg Exp $ | ||||
| # $OpenBSD: bksl-nl.t,v 1.2 2001/01/28 23:04:56 niklas Exp $ | ||||
| # $OpenBSD: history.t,v 1.5 2001/01/28 23:04:56 niklas Exp $ | ||||
| # $OpenBSD: read.t,v 1.3 2003/03/10 03:48:16 david Exp $ | ||||
| #- | ||||
| # Copyright © 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, | ||||
| #	      2011, 2012 | ||||
| #	      2011, 2012, 2013 | ||||
| #	Thorsten Glaser <tg@mirbsd.org> | ||||
| # | ||||
| # Provided that these terms and disclaimer and all copyright notices | ||||
| @@ -29,7 +29,7 @@ | ||||
| # http://www.freebsd.org/cgi/cvsweb.cgi/src/tools/regression/bin/test/regress.sh?rev=HEAD | ||||
|  | ||||
| expected-stdout: | ||||
| 	@(#)MIRBSD KSH R41 2012/12/31 | ||||
| 	@(#)MIRBSD KSH R41 2013/01/01 | ||||
| description: | ||||
| 	Check version of shell. | ||||
| stdin: | ||||
| @@ -38,7 +38,7 @@ name: KSH_VERSION | ||||
| category: shell:legacy-no | ||||
| --- | ||||
| expected-stdout: | ||||
| 	@(#)LEGACY KSH R41 2012/12/31 | ||||
| 	@(#)LEGACY KSH R41 2013/01/01 | ||||
| description: | ||||
| 	Check version of legacy shell. | ||||
| stdin: | ||||
| @@ -5821,6 +5821,94 @@ expected-stdout: | ||||
| 	hi | ||||
| expected-exit: 9 | ||||
| --- | ||||
| name: exit-trap-2 | ||||
| description: | ||||
| 	Check that ERR and EXIT traps are run just like ksh93 does. | ||||
| 	GNU bash does not run ERtrap in eval-undef. | ||||
| file-setup: file 644 "x" | ||||
| 	v=; unset v | ||||
| 	trap 'echo EXtrap' EXIT | ||||
| 	trap 'echo ERtrap' ERR | ||||
| 	set -e | ||||
| 	echo "and run $1" | ||||
| 	eval $1 | ||||
| 	echo and out | ||||
| file-setup: file 644 "xt" | ||||
| 	v=; unset v | ||||
| 	trap 'echo EXtrap' EXIT | ||||
| 	trap 'echo ERtrap' ERR | ||||
| 	set -e | ||||
| 	echo 'and run true' | ||||
| 	true | ||||
| 	echo and out | ||||
| file-setup: file 644 "xf" | ||||
| 	v=; unset v | ||||
| 	trap 'echo EXtrap' EXIT | ||||
| 	trap 'echo ERtrap' ERR | ||||
| 	set -e | ||||
| 	echo 'and run false' | ||||
| 	false | ||||
| 	echo and out | ||||
| file-setup: file 644 "xu" | ||||
| 	v=; unset v | ||||
| 	trap 'echo EXtrap' EXIT | ||||
| 	trap 'echo ERtrap' ERR | ||||
| 	set -e | ||||
| 	echo 'and run ${v?}' | ||||
| 	${v?} | ||||
| 	echo and out | ||||
| stdin: | ||||
| 	runtest() { | ||||
| 		rm -f rc | ||||
| 		( | ||||
| 			"$__progname" "$@" | ||||
| 			echo $? >rc | ||||
| 		) 2>&1 | sed \ | ||||
| 		    -e 's/parameter not set/parameter null or not set/' \ | ||||
| 		    -e 's/[[]6]//' -e 's/: eval: line 1//' -e 's/: line 6//' \ | ||||
| 		    -e "s^${__progname%.exe}\.*e*x*e*: <stdin>\[[0-9]*]PROG" | ||||
| 	} | ||||
| 	echo : | ||||
| 	runtest x true | ||||
| 	echo = eval-true $(<rc) . | ||||
| 	runtest x false | ||||
| 	echo = eval-false $(<rc) . | ||||
| 	runtest x '${v?}' | ||||
| 	echo = eval-undef $(<rc) . | ||||
| 	runtest xt | ||||
| 	echo = noeval-true $(<rc) . | ||||
| 	runtest xf | ||||
| 	echo = noeval-false $(<rc) . | ||||
| 	runtest xu | ||||
| 	echo = noeval-undef $(<rc) . | ||||
| expected-stdout: | ||||
| 	: | ||||
| 	and run true | ||||
| 	and out | ||||
| 	EXtrap | ||||
| 	= eval-true 0 . | ||||
| 	and run false | ||||
| 	ERtrap | ||||
| 	EXtrap | ||||
| 	= eval-false 1 . | ||||
| 	and run ${v?} | ||||
| 	x: v: parameter null or not set | ||||
| 	ERtrap | ||||
| 	EXtrap | ||||
| 	= eval-undef 1 . | ||||
| 	and run true | ||||
| 	and out | ||||
| 	EXtrap | ||||
| 	= noeval-true 0 . | ||||
| 	and run false | ||||
| 	ERtrap | ||||
| 	EXtrap | ||||
| 	= noeval-false 1 . | ||||
| 	and run ${v?} | ||||
| 	xu: v: parameter null or not set | ||||
| 	EXtrap | ||||
| 	= noeval-undef 1 . | ||||
| --- | ||||
| name: test-stlt-1 | ||||
| description: | ||||
| 	Check that test also can handle string1 < string2 etc. | ||||
|   | ||||
							
								
								
									
										9
									
								
								exec.c
									
									
									
									
									
								
							
							
						
						
									
										9
									
								
								exec.c
									
									
									
									
									
								
							| @@ -2,7 +2,7 @@ | ||||
|  | ||||
| /*- | ||||
|  * Copyright (c) 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, | ||||
|  *		 2011, 2012 | ||||
|  *		 2011, 2012, 2013 | ||||
|  *	Thorsten Glaser <tg@mirbsd.org> | ||||
|  * | ||||
|  * Provided that these terms and disclaimer and all copyright notices | ||||
| @@ -23,7 +23,7 @@ | ||||
|  | ||||
| #include "sh.h" | ||||
|  | ||||
| __RCSID("$MirOS: src/bin/mksh/exec.c,v 1.110 2012/12/22 00:03:41 tg Exp $"); | ||||
| __RCSID("$MirOS: src/bin/mksh/exec.c,v 1.111 2013/01/01 20:45:02 tg Exp $"); | ||||
|  | ||||
| #ifndef MKSH_DEFAULT_EXECSHELL | ||||
| #define MKSH_DEFAULT_EXECSHELL	"/bin/sh" | ||||
| @@ -479,10 +479,15 @@ execute(struct op * volatile t, | ||||
| 		unwind(LEXIT); | ||||
| 	if (rv != 0 && !(flags & XERROK) && | ||||
| 	    (xerrok == NULL || !*xerrok)) { | ||||
| 		if (Flag(FERREXIT) & 0x80) { | ||||
| 			/* inside eval */ | ||||
| 			Flag(FERREXIT) = 0; | ||||
| 		} else { | ||||
| 			trapsig(ksh_SIGERR); | ||||
| 			if (Flag(FERREXIT)) | ||||
| 				unwind(LERROR); | ||||
| 		} | ||||
| 	} | ||||
| 	return (rv); | ||||
| } | ||||
|  | ||||
|   | ||||
							
								
								
									
										6
									
								
								funcs.c
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								funcs.c
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | ||||
|  | ||||
| /*- | ||||
|  * Copyright (c) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, | ||||
|  *		 2010, 2011, 2012 | ||||
|  *		 2010, 2011, 2012, 2013 | ||||
|  *	Thorsten Glaser <tg@mirbsd.org> | ||||
|  * | ||||
|  * Provided that these terms and disclaimer and all copyright notices | ||||
| @@ -38,7 +38,7 @@ | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| __RCSID("$MirOS: src/bin/mksh/funcs.c,v 1.236 2012/12/28 02:28:34 tg Exp $"); | ||||
| __RCSID("$MirOS: src/bin/mksh/funcs.c,v 1.237 2013/01/01 20:45:02 tg Exp $"); | ||||
|  | ||||
| #if HAVE_KILLPG | ||||
| /* | ||||
| @@ -2216,7 +2216,7 @@ c_eval(const char **wp) | ||||
| 	exstat |= 0x4000; | ||||
|  | ||||
| 	savef = Flag(FERREXIT); | ||||
| 	Flag(FERREXIT) = 0; | ||||
| 	Flag(FERREXIT) |= 0x80; | ||||
| 	rv = shell(s, false); | ||||
| 	Flag(FERREXIT) = savef; | ||||
| 	source = saves; | ||||
|   | ||||
							
								
								
									
										27
									
								
								main.c
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								main.c
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | ||||
|  | ||||
| /*- | ||||
|  * Copyright (c) 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, | ||||
|  *		 2011, 2012 | ||||
|  *		 2011, 2012, 2013 | ||||
|  *	Thorsten Glaser <tg@mirbsd.org> | ||||
|  * | ||||
|  * Provided that these terms and disclaimer and all copyright notices | ||||
| @@ -34,7 +34,7 @@ | ||||
| #include <locale.h> | ||||
| #endif | ||||
|  | ||||
| __RCSID("$MirOS: src/bin/mksh/main.c,v 1.249 2012/12/17 23:18:07 tg Exp $"); | ||||
| __RCSID("$MirOS: src/bin/mksh/main.c,v 1.250 2013/01/01 20:45:03 tg Exp $"); | ||||
|  | ||||
| extern char **environ; | ||||
|  | ||||
| @@ -873,18 +873,35 @@ void | ||||
| unwind(int i) | ||||
| { | ||||
| 	/* ordering for EXIT vs ERR is a bit odd (this is what AT&T ksh does) */ | ||||
| 	if (i == LEXIT || (Flag(FERREXIT) && (i == LERROR || i == LINTR) && | ||||
| 	    sigtraps[ksh_SIGEXIT].trap)) { | ||||
| 	if (i == LEXIT || (Flag(FERREXIT) == 1 && | ||||
| 	    (i == LERROR || i == LINTR) && sigtraps[ksh_SIGEXIT].trap)) { | ||||
| 		++trap_nested; | ||||
| 		runtrap(&sigtraps[ksh_SIGEXIT], trap_nested == 1); | ||||
| 		--trap_nested; | ||||
| 		i = LLEAVE; | ||||
| 	} else if (Flag(FERREXIT) && (i == LERROR || i == LINTR)) { | ||||
| 	} else if (Flag(FERREXIT) == 1 && (i == LERROR || i == LINTR)) { | ||||
| 		++trap_nested; | ||||
| 		runtrap(&sigtraps[ksh_SIGERR], trap_nested == 1); | ||||
| 		--trap_nested; | ||||
| 		i = LLEAVE; | ||||
| 	} | ||||
|  | ||||
| 	/* | ||||
| 	 * This is a kludge. We need to restore everything that was | ||||
| 	 * changed in the new environment, see cid 1005090337C7A669439 | ||||
| 	 * and 10050903386452ACBF1, but fail to even save things most of | ||||
| 	 * the time. funcs.c:c_eval() changes FERREXIT temporarily to 0, | ||||
| 	 * which needs to be restored thus (related to Debian #696823). | ||||
| 	 * We did not save the shell flags, so we use a special or'd | ||||
| 	 * value here... this is mostly to clean up behind *other* | ||||
| 	 * callers of unwind(LERROR) here; exec.c has the regular case. | ||||
| 	 */ | ||||
| 	if (Flag(FERREXIT) & 0x80) { | ||||
| 		/* GNU bash does not run this trapsig */ | ||||
| 		trapsig(ksh_SIGERR); | ||||
| 		Flag(FERREXIT) &= ~0x80; | ||||
| 	} | ||||
|  | ||||
| 	while (/* CONSTCOND */ 1) { | ||||
| 		switch (e->type) { | ||||
| 		case E_PARSE: | ||||
|   | ||||
							
								
								
									
										6
									
								
								sh.h
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								sh.h
									
									
									
									
									
								
							| @@ -10,7 +10,7 @@ | ||||
|  | ||||
| /*- | ||||
|  * Copyright © 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, | ||||
|  *	       2011, 2012 | ||||
|  *	       2011, 2012, 2013 | ||||
|  *	Thorsten Glaser <tg@mirbsd.org> | ||||
|  * | ||||
|  * Provided that these terms and disclaimer and all copyright notices | ||||
| @@ -164,9 +164,9 @@ | ||||
| #endif | ||||
|  | ||||
| #ifdef EXTERN | ||||
| __RCSID("$MirOS: src/bin/mksh/sh.h,v 1.625 2013/01/01 03:32:43 tg Exp $"); | ||||
| __RCSID("$MirOS: src/bin/mksh/sh.h,v 1.626 2013/01/01 20:45:04 tg Exp $"); | ||||
| #endif | ||||
| #define MKSH_VERSION "R41 2012/12/31" | ||||
| #define MKSH_VERSION "R41 2013/01/01" | ||||
|  | ||||
| /* arithmetic types: C implementation */ | ||||
| #if !HAVE_CAN_INTTYPES | ||||
|   | ||||
		Reference in New Issue
	
	Block a user