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
|
||||
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
|
||||
|
||||
%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