From 8aebf54b4716c7ca443851c1c72e6bc926e03371 Mon Sep 17 00:00:00 2001 From: Dimitar Zhekov Date: Fri, 26 Jun 2015 18:44:56 +0300 Subject: [PATCH 1/2] Fix spawn_async_with_pipes() to work without watch for child_pid=NULL On child_pid=NULL, the Windows process handle is now closed ASAP, so no main glib event loop is required. --- src/spawn.c | 18 ++++++------------ 1 file changed, 6 insertions(+), 12 deletions(-) diff --git a/src/spawn.c b/src/spawn.c index d1ff510e..9e7f09dd 100644 --- a/src/spawn.c +++ b/src/spawn.c @@ -360,7 +360,11 @@ static gchar *spawn_create_process_with_pipes(char *command_line, const char *wo { failed = NULL; CloseHandle(process.hThread); /* we don't need this */ - *hprocess = process.hProcess; + + if (hprocess) + *hprocess = process.hProcess; + else + CloseHandle(process.hProcess); } leave: @@ -444,12 +448,6 @@ static void spawn_append_argument(GString *command, const char *text) g_string_append_c(command, '"'); } } - - -static void spawn_close_pid(GPid pid, G_GNUC_UNUSED gint status, G_GNUC_UNUSED gpointer data) -{ - g_spawn_close_pid(pid); -} #endif /* G_OS_WIN32 */ @@ -491,7 +489,6 @@ gboolean spawn_async_with_pipes(const gchar *working_directory, const gchar *com #ifdef G_OS_WIN32 GString *command; GArray *environment; - GPid pid; gchar *failure; if (command_line) @@ -539,8 +536,7 @@ gboolean spawn_async_with_pipes(const gchar *working_directory, const gchar *com } failure = spawn_create_process_with_pipes(command->str, working_directory, - envp ? environment->data : NULL, child_pid ? child_pid : &pid, - stdin_fd, stdout_fd, stderr_fd); + envp ? environment->data : NULL, child_pid, stdin_fd, stdout_fd, stderr_fd); g_string_free(command, TRUE); g_array_free(environment, TRUE); @@ -551,8 +547,6 @@ gboolean spawn_async_with_pipes(const gchar *working_directory, const gchar *com g_free(failure); return FALSE; } - else if (!child_pid) - g_child_watch_add(pid, spawn_close_pid, NULL); return TRUE; #else /* G_OS_WIN32 */ From fc82f9d9e1bc3077f7d36feb690a7f90bba1399d Mon Sep 17 00:00:00 2001 From: Dimitar Zhekov Date: Fri, 26 Jun 2015 18:57:44 +0300 Subject: [PATCH 2/2] Fix spawn with -DSPAWN_TEST not to require GEANY_API_SYMBOL As stated in spawn.c, "This module does not depend on Geany when compiled for testing (-DSPAWN_TEST)." --- src/spawn.c | 1 + 1 file changed, 1 insertion(+) diff --git a/src/spawn.c b/src/spawn.c index 9e7f09dd..207ed305 100644 --- a/src/spawn.c +++ b/src/spawn.c @@ -59,6 +59,7 @@ #ifdef SPAWN_TEST # define _ +# define GEANY_API_SYMBOL #else # include "support.h" #endif