Blame SOURCES/ksh-20140801-diskfull.patch

e096b8
diff -up ksh-20120801/src/cmd/ksh93/sh/main.c.orig ksh-20120801/src/cmd/ksh93/sh/main.c
e096b8
--- ksh-20120801/src/cmd/ksh93/sh/main.c.orig	2015-04-29 16:49:11.502958000 -0300
e096b8
+++ ksh-20120801/src/cmd/ksh93/sh/main.c	2015-05-08 18:19:55.688776922 -0300
e096b8
@@ -423,7 +423,7 @@ static void	exfile(register Shell_t *shp
e096b8
 		sfsync(shp->outpool);
e096b8
 		shp->st.execbrk = shp->st.breakcnt = 0;
e096b8
 		/* check for return from profile or env file */
e096b8
-		if(sh_isstate(SH_PROFILE) && (jmpval==SH_JMPFUN || jmpval==SH_JMPEXIT))
e096b8
+		if(sh_isstate(SH_PROFILE) && (jmpval==SH_JMPFUN || jmpval==SH_JMPEXIT || jmpval==SH_JMPERREXIT))
e096b8
 		{
e096b8
 			sh_setstate(states);
e096b8
 			goto done;
e096b8
@@ -598,7 +598,7 @@ done:
e096b8
 	}
e096b8
 	if(jmpval == SH_JMPSCRIPT)
e096b8
 		siglongjmp(*shp->jmplist,jmpval);
e096b8
-	else if(jmpval == SH_JMPEXIT)
e096b8
+	else if(jmpval == SH_JMPEXIT || jmpval == SH_JMPERREXIT)
e096b8
 		sh_done(shp,0);
e096b8
 	if(fno>0)
e096b8
 		sh_close(fno);