Adds -n option: wait on finnishing grandchild process
https://github.com/cronie-crond/cronie/pull/163
This commit is contained in:
		
							parent
							
								
									550f5c0f69
								
							
						
					
					
						commit
						c47c5cbbbe
					
				| @ -11,6 +11,9 @@ License:   GPL-2.0-or-later AND BSD-3-Clause AND BSD-2-Clause AND ISC AND LGPL-2 | |||||||
| URL:       https://github.com/cronie-crond/cronie | URL:       https://github.com/cronie-crond/cronie | ||||||
| Source0:   https://github.com/cronie-crond/cronie/releases/download/cronie-%{version}/cronie-%{version}.tar.gz | Source0:   https://github.com/cronie-crond/cronie/releases/download/cronie-%{version}/cronie-%{version}.tar.gz | ||||||
| 
 | 
 | ||||||
|  | # https://github.com/cronie-crond/cronie/pull/163 | ||||||
|  | Patch:     n_option_wait_on_finnishing_grandchild_process.patch | ||||||
|  | 
 | ||||||
| Requires:  dailyjobs | Requires:  dailyjobs | ||||||
| 
 | 
 | ||||||
| %if %{with selinux} | %if %{with selinux} | ||||||
|  | |||||||
							
								
								
									
										25
									
								
								n_option_wait_on_finnishing_grandchild_process.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								n_option_wait_on_finnishing_grandchild_process.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,25 @@ | |||||||
|  | From 5cf85f8cbb816ff1df5b317d6f8559b67e1993dd Mon Sep 17 00:00:00 2001 | ||||||
|  | From: =?UTF-8?q?Ond=C5=99ej=20Poho=C5=99elsk=C3=BD?= <opohorel@redhat.com> | ||||||
|  | Date: Wed, 25 Oct 2023 10:58:46 +0200 | ||||||
|  | Subject: [PATCH] -n option: wait on finnishing grandchild process | ||||||
|  | 
 | ||||||
|  | With `WNOHANG` we skip sending the email when waitpid() returns 0, | ||||||
|  | which happens if the process is still running. Instead, using `0` | ||||||
|  | parameter will wait for the process to actually stop running. | ||||||
|  | ---
 | ||||||
|  |  src/do_command.c | 2 +- | ||||||
|  |  1 file changed, 1 insertion(+), 1 deletion(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/src/do_command.c b/src/do_command.c
 | ||||||
|  | index d7ca840..2ada913 100644
 | ||||||
|  | --- a/src/do_command.c
 | ||||||
|  | +++ b/src/do_command.c
 | ||||||
|  | @@ -579,7 +579,7 @@ static int child_process(entry * e, char **jobenv) {
 | ||||||
|  |  			if (mail && e->flags & MAIL_WHEN_ERR) { | ||||||
|  |  				int jobstatus = -1; | ||||||
|  |  				if (jobpid > 0) { | ||||||
|  | -					while (waitpid(jobpid, &jobstatus, WNOHANG) == -1) {
 | ||||||
|  | +					while (waitpid(jobpid, &jobstatus, 0) == -1) {
 | ||||||
|  |  						if (errno == EINTR) continue; | ||||||
|  |  						log_it("CRON", getpid(), "error", "invalid job pid", errno); | ||||||
|  |  						break; | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user