Siteshwar Vashisht f3b443
From c9f1b04651dae16e33f0aa8974c5122e26b362ae Mon Sep 17 00:00:00 2001
Siteshwar Vashisht f3b443
From: Chet Ramey <chet.ramey@case.edu>
Siteshwar Vashisht f3b443
Date: Mon, 29 Jan 2018 16:04:20 -0500
Siteshwar Vashisht f3b443
Subject: [PATCH] Bash-4.4 patch 16
Siteshwar Vashisht f3b443
Siteshwar Vashisht f3b443
---
Siteshwar Vashisht f3b443
 lib/sh/zread.c | 23 +++++++++--------------
Siteshwar Vashisht f3b443
 patchlevel.h   |  2 +-
Siteshwar Vashisht f3b443
 2 files changed, 10 insertions(+), 15 deletions(-)
Siteshwar Vashisht f3b443
Siteshwar Vashisht f3b443
diff --git a/lib/sh/zread.c b/lib/sh/zread.c
Siteshwar Vashisht f3b443
index 868f9705..496f20b8 100644
Siteshwar Vashisht f3b443
--- a/lib/sh/zread.c
Siteshwar Vashisht f3b443
+++ b/lib/sh/zread.c
Siteshwar Vashisht f3b443
@@ -37,7 +37,10 @@ extern int errno;
Siteshwar Vashisht f3b443
 #  define SEEK_CUR 1
Siteshwar Vashisht f3b443
 #endif
Siteshwar Vashisht f3b443
 
Siteshwar Vashisht f3b443
+extern int executing_builtin;
Siteshwar Vashisht f3b443
+
Siteshwar Vashisht f3b443
 extern void check_signals_and_traps (void);
Siteshwar Vashisht f3b443
+extern void check_signals (void);
Siteshwar Vashisht f3b443
 extern int signal_is_trapped (int);
Siteshwar Vashisht f3b443
 
Siteshwar Vashisht f3b443
 /* Read LEN bytes from FD into BUF.  Retry the read on EINTR.  Any other
Siteshwar Vashisht f3b443
@@ -50,21 +53,13 @@ zread (fd, buf, len)
Siteshwar Vashisht f3b443
 {
Siteshwar Vashisht f3b443
   ssize_t r;
Siteshwar Vashisht f3b443
 
Siteshwar Vashisht f3b443
-#if 0
Siteshwar Vashisht f3b443
-#if defined (HAVE_SIGINTERRUPT)
Siteshwar Vashisht f3b443
-  if (signal_is_trapped (SIGCHLD))
Siteshwar Vashisht f3b443
-    siginterrupt (SIGCHLD, 1);
Siteshwar Vashisht f3b443
-#endif
Siteshwar Vashisht f3b443
-#endif
Siteshwar Vashisht f3b443
-
Siteshwar Vashisht f3b443
   while ((r = read (fd, buf, len)) < 0 && errno == EINTR)
Siteshwar Vashisht f3b443
-    check_signals_and_traps ();	/* XXX - should it be check_signals()? */
Siteshwar Vashisht f3b443
-
Siteshwar Vashisht f3b443
-#if 0 
Siteshwar Vashisht f3b443
-#if defined (HAVE_SIGINTERRUPT)
Siteshwar Vashisht f3b443
-  siginterrupt (SIGCHLD, 0);
Siteshwar Vashisht f3b443
-#endif
Siteshwar Vashisht f3b443
-#endif
Siteshwar Vashisht f3b443
+    /* XXX - bash-5.0 */
Siteshwar Vashisht f3b443
+    /* We check executing_builtin and run traps here for backwards compatibility */
Siteshwar Vashisht f3b443
+    if (executing_builtin)
Siteshwar Vashisht f3b443
+      check_signals_and_traps ();	/* XXX - should it be check_signals()? */
Siteshwar Vashisht f3b443
+    else
Siteshwar Vashisht f3b443
+      check_signals ();
Siteshwar Vashisht f3b443
 
Siteshwar Vashisht f3b443
   return r;
Siteshwar Vashisht f3b443
 }
Siteshwar Vashisht f3b443
diff --git a/patchlevel.h b/patchlevel.h
Siteshwar Vashisht f3b443
index 6e9ed3fc..9074f4dd 100644
Siteshwar Vashisht f3b443
--- a/patchlevel.h
Siteshwar Vashisht f3b443
+++ b/patchlevel.h
Siteshwar Vashisht f3b443
@@ -25,6 +25,6 @@
Siteshwar Vashisht f3b443
    regexp `^#define[ 	]*PATCHLEVEL', since that's what support/mkversion.sh
Siteshwar Vashisht f3b443
    looks for to find the patch level (for the sccs version string). */
Siteshwar Vashisht f3b443
 
Siteshwar Vashisht f3b443
-#define PATCHLEVEL 15
Siteshwar Vashisht f3b443
+#define PATCHLEVEL 16
Siteshwar Vashisht f3b443
 
Siteshwar Vashisht f3b443
 #endif /* _PATCHLEVEL_H_ */
Siteshwar Vashisht f3b443
-- 
Siteshwar Vashisht f3b443
2.13.6
Siteshwar Vashisht f3b443