summaryrefslogtreecommitdiff
path: root/src/spawn-w32.c
diff options
context:
space:
mode:
authorNIIBE Yutaka <gniibe@fsij.org>2022-10-31 11:07:57 +0900
committerNIIBE Yutaka <gniibe@fsij.org>2022-10-31 11:07:57 +0900
commit6c20e8393eba4a9f330143b2158e28ea594cbadd (patch)
treee36258183639ef2df818806168e3ea34351ec89e /src/spawn-w32.c
parent43c1e85fe29a52a9debc068d97c5860a4694b821 (diff)
downloadlibgpg-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.c22
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;
+}