BASH PATCH REPORT
			     =================

Bash-Release:	5.2
Patch-ID:	bash52-035

Bug-Reported-by:	Henry Bent <henry.r.bent@gmail.com>
Bug-Reference-ID:	<CAEdTPBdD0WOW2n0-y-XyZ_VwhbiG-oS3bXfGkOPPG617rGH-Ww@mail.gmail.com>
Bug-Reference-URL:	https://lists.gnu.org/archive/html/bug-bash/2022-11/msg00044.html

Bug-Description:

There are systems that supply one of select or pselect, but not both.

Patch (apply with `patch -p0'):

https://lists.gnu.org/archive/html/bug-bash/2022-11/msg00058.html

*** ../bash/bash-5.2-patched/lib/readline/input.c	2022-04-08 15:43:24.000000000 -0400
--- lib/readline/input.c	2022-11-16 09:10:41.000000000 -0500
***************
*** 152,156 ****
--- 152,158 ----
  int _rl_timeout_init (void);
  int _rl_timeout_sigalrm_handler (void);
+ #if defined (RL_TIMEOUT_USE_SELECT)
  int _rl_timeout_select (int, fd_set *, fd_set *, fd_set *, const struct timeval *, const sigset_t *);
+ #endif
  
  static void _rl_timeout_handle (void);
***************
*** 249,253 ****
    int chars_avail, k;
    char input;
! #if defined(HAVE_SELECT)
    fd_set readfds, exceptfds;
    struct timeval timeout;
--- 251,255 ----
    int chars_avail, k;
    char input;
! #if defined (HAVE_PSELECT) || defined (HAVE_SELECT)
    fd_set readfds, exceptfds;
    struct timeval timeout;
***************
*** 806,810 ****
    unsigned char c;
    int fd;
! #if defined (HAVE_PSELECT)
    sigset_t empty_set;
    fd_set readfds;
--- 808,812 ----
    unsigned char c;
    int fd;
! #if defined (HAVE_PSELECT) || defined (HAVE_SELECT)
    sigset_t empty_set;
    fd_set readfds;
*** ../bash-5.2-patched/lib/sh/input_avail.c	2021-05-24 11:16:33.000000000 -0400
--- lib/sh/input_avail.c	2022-11-16 09:12:48.000000000 -0500
***************
*** 34,40 ****
  #endif /* HAVE_SYS_FILE_H */
  
! #if defined (HAVE_PSELECT)
! #  include <signal.h>
! #endif
  
  #if defined (HAVE_UNISTD_H)
--- 34,38 ----
  #endif /* HAVE_SYS_FILE_H */
  
! #include <signal.h>
  
  #if defined (HAVE_UNISTD_H)
***************
*** 108,115 ****
  {
    int result, chars_avail;
- #if defined(HAVE_SELECT)
-   fd_set readfds, exceptfds;
- #endif
  #if defined (HAVE_PSELECT) || defined (HAVE_SELECT)
    sigset_t set, oset;
  #endif
--- 106,111 ----
  {
    int result, chars_avail;
  #if defined (HAVE_PSELECT) || defined (HAVE_SELECT)
+   fd_set readfds, exceptfds;
    sigset_t set, oset;
  #endif
***************
*** 122,132 ****
    chars_avail = 0;
  
! #if defined (HAVE_SELECT)
    FD_ZERO (&readfds);
    FD_ZERO (&exceptfds);
    FD_SET (fd, &readfds);
    FD_SET (fd, &exceptfds);
- #endif
- #if defined (HAVE_SELECT) || defined (HAVE_PSELECT)
    sigprocmask (SIG_BLOCK, (sigset_t *)NULL, &set);
  #  ifdef SIGCHLD
--- 115,123 ----
    chars_avail = 0;
  
! #if defined (HAVE_PSELECT) || defined (HAVE_SELECT)
    FD_ZERO (&readfds);
    FD_ZERO (&exceptfds);
    FD_SET (fd, &readfds);
    FD_SET (fd, &exceptfds);
    sigprocmask (SIG_BLOCK, (sigset_t *)NULL, &set);
  #  ifdef SIGCHLD

*** ../bash-5.2/patchlevel.h	2020-06-22 14:51:03.000000000 -0400
--- patchlevel.h	2020-10-01 11:01:28.000000000 -0400
***************
*** 26,30 ****
     looks for to find the patch level (for the sccs version string). */
  
! #define PATCHLEVEL 34
  
  #endif /* _PATCHLEVEL_H_ */
--- 26,30 ----
     looks for to find the patch level (for the sccs version string). */
  
! #define PATCHLEVEL 35
  
  #endif /* _PATCHLEVEL_H_ */