diff options
author | Justus Winter <justus@g10code.com> | 2016-09-05 15:34:44 +0200 |
---|---|---|
committer | Justus Winter <justus@g10code.com> | 2016-09-05 17:26:50 +0200 |
commit | c97bde2dfeab23a84b4788d998934ac49ff5b797 (patch) | |
tree | 39c4b3324d7ea42d3b567e460088532c61f0df53 /common | |
parent | common: Fix error handling. (diff) | |
download | gnupg2-c97bde2dfeab23a84b4788d998934ac49ff5b797.tar.xz gnupg2-c97bde2dfeab23a84b4788d998934ac49ff5b797.zip |
common: Restore a simpler variant of 'gnupg_wait_process'.
* common/exechelp-posix.c (gnupg_wait_process): Use the code prior to
5ba4f604.
Signed-off-by: Justus Winter <justus@g10code.com>
Diffstat (limited to 'common')
-rw-r--r-- | common/exechelp-posix.c | 54 |
1 files changed, 53 insertions, 1 deletions
diff --git a/common/exechelp-posix.c b/common/exechelp-posix.c index 56380f2c5..f19dda2ac 100644 --- a/common/exechelp-posix.c +++ b/common/exechelp-posix.c @@ -647,7 +647,59 @@ get_result (pid_t pid, int *r_exitcode) gpg_error_t gnupg_wait_process (const char *pgmname, pid_t pid, int hang, int *r_exitcode) { - return gnupg_wait_processes (&pgmname, &pid, 1, hang, r_exitcode); + gpg_err_code_t ec; + int i, status; + + if (r_exitcode) + *r_exitcode = -1; + + if (pid == (pid_t)(-1)) + return gpg_error (GPG_ERR_INV_VALUE); + +#ifdef USE_NPTH + i = npth_waitpid (pid, &status, hang? 0:WNOHANG); +#else + while ((i=waitpid (pid, &status, hang? 0:WNOHANG)) == (pid_t)(-1) + && errno == EINTR); +#endif + + if (i == (pid_t)(-1)) + { + ec = gpg_err_code_from_errno (errno); + log_error (_("waiting for process %d to terminate failed: %s\n"), + (int)pid, strerror (errno)); + } + else if (!i) + { + ec = GPG_ERR_TIMEOUT; /* Still running. */ + } + else if (WIFEXITED (status) && WEXITSTATUS (status) == 127) + { + log_error (_("error running '%s': probably not installed\n"), pgmname); + ec = GPG_ERR_CONFIGURATION; + } + else if (WIFEXITED (status) && WEXITSTATUS (status)) + { + if (!r_exitcode) + log_error (_("error running '%s': exit status %d\n"), pgmname, + WEXITSTATUS (status)); + else + *r_exitcode = WEXITSTATUS (status); + ec = GPG_ERR_GENERAL; + } + else if (!WIFEXITED (status)) + { + log_error (_("error running '%s': terminated\n"), pgmname); + ec = GPG_ERR_GENERAL; + } + else + { + if (r_exitcode) + *r_exitcode = 0; + ec = 0; + } + + return gpg_err_make (GPG_ERR_SOURCE_DEFAULT, ec); } /* See exechelp.h for a description. */ |