1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-23 15:07:03 +01:00

common,w32: Make use of default_errsource in exechelp.

* common/exechelp-posix.c (my_error_from_syserror, my_error): New.
Use them instead of gpg_error and gpg_error_from_syserror.

Fixes-commit: 96c7901ec1c79be732570811223d3ea54875abfe
Signed-off-by: Justus Winter <justus@g10code.com>
This commit is contained in:
Justus Winter 2016-10-18 14:01:53 +02:00
parent 34439da2d6
commit 727ca74bb9

View File

@ -84,6 +84,20 @@
# define handle_to_pid(a) ((int)(a)) # define handle_to_pid(a) ((int)(a))
/* Helper */
static inline gpg_error_t
my_error_from_syserror (void)
{
return gpg_err_make (default_errsource, gpg_err_code_from_syserror ());
}
static inline gpg_error_t
my_error (int errcode)
{
return gpg_err_make (default_errsource, errcode);
}
/* Return the maximum number of currently allowed open file /* Return the maximum number of currently allowed open file
descriptors. Only useful on POSIX systems but returns a value on descriptors. Only useful on POSIX systems but returns a value on
other systems too. */ other systems too. */
@ -219,7 +233,7 @@ build_w32_commandline (const char *pgmname, const char * const *argv,
buf = p = xtrymalloc (n); buf = p = xtrymalloc (n);
if (!buf) if (!buf)
return gpg_error_from_syserror (); return my_error_from_syserror ();
p = build_w32_commandline_copy (p, pgmname); p = build_w32_commandline_copy (p, pgmname);
for (i=0; argv[i]; i++) for (i=0; argv[i]; i++)
@ -293,7 +307,7 @@ do_create_pipe (int filedes[2], int flags)
HANDLE fds[2]; HANDLE fds[2];
filedes[0] = filedes[1] = -1; filedes[0] = filedes[1] = -1;
err = gpg_error (GPG_ERR_GENERAL); err = my_error (GPG_ERR_GENERAL);
if (!create_inheritable_pipe (fds, flags)) if (!create_inheritable_pipe (fds, flags))
{ {
filedes[0] = _open_osfhandle (handle_to_fd (fds[0]), O_RDONLY); filedes[0] = _open_osfhandle (handle_to_fd (fds[0]), O_RDONLY);
@ -662,7 +676,7 @@ gnupg_spawn_process_fd (const char *pgmname, const char *argv[],
)) ))
{ {
log_error ("CreateProcess failed: %s\n", w32_strerror (-1)); log_error ("CreateProcess failed: %s\n", w32_strerror (-1));
err = gpg_error (GPG_ERR_GENERAL); err = my_error (GPG_ERR_GENERAL);
} }
else else
err = 0; err = 0;
@ -707,7 +721,7 @@ gnupg_wait_processes (const char **pgmnames, pid_t *pids, size_t count,
procs = xtrycalloc (count, sizeof *procs); procs = xtrycalloc (count, sizeof *procs);
if (procs == NULL) if (procs == NULL)
return gpg_error_from_syserror (); return my_error_from_syserror ();
for (i = 0; i < count; i++) for (i = 0; i < count; i++)
{ {
@ -715,7 +729,7 @@ gnupg_wait_processes (const char **pgmnames, pid_t *pids, size_t count,
r_exitcodes[i] = -1; r_exitcodes[i] = -1;
if (pids[i] == (pid_t)(-1)) if (pids[i] == (pid_t)(-1))
return gpg_error (GPG_ERR_INV_VALUE); return my_error (GPG_ERR_INV_VALUE);
procs[i] = fd_to_handle (pids[i]); procs[i] = fd_to_handle (pids[i]);
} }
@ -818,7 +832,7 @@ gnupg_spawn_process_detached (const char *pgmname, const char *argv[],
(void)envp; (void)envp;
if (access (pgmname, X_OK)) if (access (pgmname, X_OK))
return gpg_error_from_syserror (); return my_error_from_syserror ();
/* Prepare security attributes. */ /* Prepare security attributes. */
memset (&sec_attr, 0, sizeof sec_attr ); memset (&sec_attr, 0, sizeof sec_attr );
@ -856,7 +870,7 @@ gnupg_spawn_process_detached (const char *pgmname, const char *argv[],
{ {
log_error ("CreateProcess(detached) failed: %s\n", w32_strerror (-1)); log_error ("CreateProcess(detached) failed: %s\n", w32_strerror (-1));
xfree (cmdline); xfree (cmdline);
return gpg_error (GPG_ERR_GENERAL); return my_error (GPG_ERR_GENERAL);
} }
xfree (cmdline); xfree (cmdline);
cmdline = NULL; cmdline = NULL;