Blame SPECS/ksh-20120801-memlik3.patch

Packit 992a25
diff -up ksh-20120801/src/cmd/ksh93/include/name.h.memlik3 ksh-20120801/src/cmd/ksh93/include/name.h
Packit 992a25
--- ksh-20120801/src/cmd/ksh93/include/name.h.memlik3	2012-05-10 18:33:41.000000000 +0200
Packit 992a25
+++ ksh-20120801/src/cmd/ksh93/include/name.h	2014-01-22 14:14:32.774483776 +0100
Packit 992a25
@@ -215,7 +215,7 @@ extern Namval_t		*nv_mount(Namval_t*, co
Packit 992a25
 extern Namval_t		*nv_arraychild(Namval_t*, Namval_t*, int);
Packit 992a25
 extern int		nv_compare(Dt_t*, Void_t*, Void_t*, Dtdisc_t*);
Packit 992a25
 extern void		nv_outnode(Namval_t*,Sfio_t*, int, int);
Packit 992a25
-extern int		nv_subsaved(Namval_t*);
Packit 992a25
+extern int		nv_subsaved(Namval_t*,int);
Packit 992a25
 extern void		nv_typename(Namval_t*, Sfio_t*);
Packit 992a25
 extern void		nv_newtype(Namval_t*);
Packit 992a25
 extern int		nv_istable(Namval_t*);
Packit 992a25
diff -up ksh-20120801/src/cmd/ksh93/sh/name.c.memlik3 ksh-20120801/src/cmd/ksh93/sh/name.c
Packit 992a25
--- ksh-20120801/src/cmd/ksh93/sh/name.c.memlik3	2014-01-22 14:14:32.751483987 +0100
Packit 992a25
+++ ksh-20120801/src/cmd/ksh93/sh/name.c	2014-01-22 14:14:32.775483767 +0100
Packit 992a25
@@ -1297,7 +1297,7 @@ void nv_delete(Namval_t* np, Dt_t *root,
Packit 992a25
 	{
Packit 992a25
 		if(dtdelete(root,np))
Packit 992a25
 		{
Packit 992a25
-			if(!(flags&NV_NOFREE) && ((flags&NV_FUNCTION) || !nv_subsaved(np)))
Packit 992a25
+			if(!(flags&NV_NOFREE) && ((flags&NV_FUNCTION) || !nv_subsaved(np,flags&NV_TABLE)))
Packit 992a25
 				free((void*)np);
Packit 992a25
 		}
Packit 992a25
 #if 0
Packit 992a25
@@ -2461,14 +2461,14 @@ static void table_unset(Shell_t *shp, re
Packit 992a25
 			{
Packit 992a25
 				_nv_unset(nq,flags);
Packit 992a25
 				npnext = (Namval_t*)dtnext(root,nq);
Packit 992a25
-				nv_delete(nq,root,0);
Packit 992a25
+				nv_delete(nq,root,NV_TABLE);
Packit 992a25
 			}
Packit 992a25
 		}
Packit 992a25
 		npnext = (Namval_t*)dtnext(root,np);
Packit 992a25
                if(nv_arrayptr(np))
Packit 992a25
                        nv_putsub(np,NIL(char*),ARRAY_SCAN);
Packit 992a25
 		_nv_unset(np,flags);
Packit 992a25
-		nv_delete(np,root,0);
Packit 992a25
+		nv_delete(np,root,NV_TABLE);
Packit 992a25
 	}
Packit 992a25
 }
Packit 992a25
 
Packit 992a25
diff -up ksh-20120801/src/cmd/ksh93/sh/subshell.c.memlik3 ksh-20120801/src/cmd/ksh93/sh/subshell.c
Packit 992a25
--- ksh-20120801/src/cmd/ksh93/sh/subshell.c.memlik3	2014-01-22 14:14:32.768483831 +0100
Packit 992a25
+++ ksh-20120801/src/cmd/ksh93/sh/subshell.c	2014-01-22 14:20:50.810236676 +0100
Packit 992a25
@@ -218,16 +218,28 @@ void sh_subfork(void)
Packit 992a25
 	}
Packit 992a25
 }
Packit 992a25
 
Packit 992a25
-int nv_subsaved(register Namval_t *np)
Packit 992a25
+int nv_subsaved(register Namval_t *np,int table)
Packit 992a25
 {
Packit 992a25
 	register struct subshell	*sp;
Packit 992a25
-	register struct Link		*lp;
Packit 992a25
+	register struct Link		*lp, *lpprev;
Packit 992a25
 	for(sp = (struct subshell*)subshell_data; sp; sp=sp->prev)
Packit 992a25
 	{
Packit 992a25
-		for(lp=sp->svar; lp; lp = lp->next)
Packit 992a25
+		lpprev = 0;
Packit 992a25
+		for(lp=sp->svar; lp; lpprev=lp, lp=lp->next)
Packit 992a25
 		{
Packit 992a25
 			if(lp->node==np)
Packit 992a25
+			{
Packit 992a25
+				if(table&NV_TABLE)
Packit 992a25
+				{
Packit 992a25
+					if(lpprev)
Packit 992a25
+						lpprev->next = lp->next;
Packit 992a25
+					else
Packit 992a25
+						sp->svar = lp->next;
Packit 992a25
+					free((void*)np);
Packit 992a25
+					free((void*)lp);
Packit 992a25
+				}
Packit 992a25
 				return(1);
Packit 992a25
+			}
Packit 992a25
 		}
Packit 992a25
 	}
Packit 992a25
 	return(0);