Blame SOURCES/mksh-55-waitfail.patch

60a801
diff -up mksh/jobs.c.waitfail mksh/jobs.c
60a801
--- mksh/jobs.c.waitfail	2017-08-09 10:06:36.500591694 +0200
60a801
+++ mksh/jobs.c	2017-08-09 10:08:34.325534710 +0200
60a801
@@ -1009,8 +1009,14 @@ j_notify(void)
60a801
 	}
60a801
 	for (j = job_list; j; j = tmp) {
60a801
 		tmp = j->next;
60a801
-		if (j->flags & JF_REMOVE)
60a801
-			remove_job(j, "notify");
60a801
+		if (j->flags & JF_REMOVE) {
60a801
+			if (j == async_job || (j->flags & JF_KNOWN)) {
60a801
+				j->flags = (j->flags & ~JF_REMOVE) | JF_ZOMBIE;
60a801
+				j->job = -1;
60a801
+				nzombie++;
60a801
+			} else
60a801
+				remove_job(j, "notify");
60a801
+		}
60a801
 	}
60a801
 	shf_flush(shl_out);
60a801
 #ifndef MKSH_NOPROSPECTOFWORK