summaryrefslogtreecommitdiffstats
path: root/source/a/bash/bash-5.0-patches/bash50-007
blob: b9eb4150a2b54124228d0e3e8171771f1aef5f74 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
			     BASH PATCH REPORT
			     =================

Bash-Release:	5.0
Patch-ID:	bash50-007

Bug-Reported-by:	Grisha Levit <grishalevit@gmail.com>
Bug-Reference-ID:	<CAMu=BroHapG1AS3xB5SQaCX2XKu=-E2Ob9uW6LNuHvd=YohrDw@mail.gmail.com>
Bug-Reference-URL:	http://lists.gnu.org/archive/html/bug-bash/2019-02/msg00067.html

Bug-Description:

Running `exec' when job control was disabled, even temporarily, but after it
had been initialized, could leave the terminal in the wrong process group for
the executed process.

Patch (apply with `patch -p0'):

*** ../bash-5.0-patched/jobs.c	2018-12-06 11:44:34.000000000 -0500
--- jobs.c	2019-04-12 15:15:10.000000000 -0400
***************
*** 4838,4850 ****
  {
    if (job_control)
!     {
!       terminate_stopped_jobs ();
  
!       if (original_pgrp >= 0)
! 	give_terminal_to (original_pgrp, 1);
!     }
  
!   if (original_pgrp >= 0)
!     setpgid (0, original_pgrp);
  }
  
--- 4838,4848 ----
  {
    if (job_control)
!     terminate_stopped_jobs ();
  
!   if (original_pgrp >= 0 && terminal_pgrp != original_pgrp)
!     give_terminal_to (original_pgrp, 1);
  
!   if (original_pgrp >= 0 && setpgid (0, original_pgrp) == 0)
!     shell_pgrp = original_pgrp;
  }
  
*** ../bash-5.0/patchlevel.h	2016-06-22 14:51:03.000000000 -0400
--- patchlevel.h	2016-10-01 11:01:28.000000000 -0400
***************
*** 26,30 ****
     looks for to find the patch level (for the sccs version string). */
  
! #define PATCHLEVEL 6
  
  #endif /* _PATCHLEVEL_H_ */
--- 26,30 ----
     looks for to find the patch level (for the sccs version string). */
  
! #define PATCHLEVEL 7
  
  #endif /* _PATCHLEVEL_H_ */