diff options
author | NIIBE Yutaka <gniibe@fsij.org> | 2022-10-31 11:07:57 +0900 |
---|---|---|
committer | NIIBE Yutaka <gniibe@fsij.org> | 2022-10-31 11:07:57 +0900 |
commit | 6c20e8393eba4a9f330143b2158e28ea594cbadd (patch) | |
tree | e36258183639ef2df818806168e3ea34351ec89e /src/spawn-w32.c | |
parent | 43c1e85fe29a52a9debc068d97c5860a4694b821 (diff) | |
download | libgpg-error-6c20e8393eba4a9f330143b2158e28ea594cbadd.tar.gz |
spawn: Fix spawn_cb of gpgrt_spawn_process_fd.
* src/gpg-error.def.in (gpgrt_close_all_fds): New.
* src/gpg-error.vers (gpgrt_close_all_fds): New.
* src/gpg-error.h.in (GPGRT_SPAWN_INHERIT_FILE): New.
(gpgrt_spawn_process_fd): SPAWN_CB having return value.
* src/gpgrt-int.h (_gpgrt_spawn_process_fd): SPAWN_CB change.
* src/spawn-posix.c (_gpgrt_close_all_fds): Rename from close_all_fds,
and export it.
(do_exec): Support the case not closing fds.
(_gpgrt_spawn_process_fd): Handle return value of SPAWN_CB to
determine closing all fds or not.
* src/spawn-w32.c (_gpgrt_spawn_process_fd): Run SPAWN_CB.
(_gpgrt_close_all_fds): New.
* src/visibility.c (gpgrt_close_all_fds): New.
* src/visibility.h (gpgrt_close_all_fds): New.
--
Now, we have the API of gpgrt_spawn_process_fd for POSIX and Windows.
Giving portable semantics for spawning a process is difficult, and it
is still difficult for users to writing a function for SPAWN_CB with
portability, but gpgrt_spawn_process_fd gives the feature of spawning
a process.
GnuPG-bug-id: 6249
Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
Diffstat (limited to 'src/spawn-w32.c')
-rw-r--r-- | src/spawn-w32.c | 22 |
1 files changed, 17 insertions, 5 deletions
diff --git a/src/spawn-w32.c b/src/spawn-w32.c index 963b6a5..d17f971 100644 --- a/src/spawn-w32.c +++ b/src/spawn-w32.c @@ -642,8 +642,8 @@ _gpgrt_spawn_process (const char *pgmname, const char *argv[], gpg_err_code_t _gpgrt_spawn_process_fd (const char *pgmname, const char *argv[], int infd, int outfd, int errfd, - void (*after_fork_cb)(void *), - void *after_fork_cb_arg, + int (*spawn_cb) (void *), + void *spawn_cb_arg, pid_t *pid) { gpg_err_code_t err; @@ -653,9 +653,10 @@ _gpgrt_spawn_process_fd (const char *pgmname, const char *argv[], char *cmdline; int ret, i; HANDLE stdhd[3]; + int ask_inherit = 0; - (void)after_fork_cb; - (void)after_fork_cb_arg; + if (spawn_cb) + ask_inherit = (*spawn_cb) (spawn_cb_arg); /* Setup return values. */ *pid = (pid_t)INVALID_HANDLE_VALUE; @@ -663,7 +664,11 @@ _gpgrt_spawn_process_fd (const char *pgmname, const char *argv[], /* Prepare security attributes. */ memset (&sec_attr, 0, sizeof sec_attr ); sec_attr.nLength = sizeof sec_attr; - sec_attr.bInheritHandle = FALSE; + + if (ask_inherit) + sec_attr.bInheritHandle = TRUE; + else + sec_attr.bInheritHandle = FALSE; /* Build the command line. */ err = build_w32_commandline (pgmname, argv, &cmdline); @@ -926,3 +931,10 @@ _gpgrt_release_process (pid_t pid) CloseHandle (process); } } + +void +_gpgrt_close_all_fds (int from, int *keep_fds) +{ + (void)from; + (void)keep_fds; +} |