[evolution/gnome-3-6] Bug 691133 - Evolution creates 'highlight' zombies
- From: Matthew Barnes <mbarnes src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution/gnome-3-6] Bug 691133 - Evolution creates 'highlight' zombies
- Date: Fri, 4 Jan 2013 16:53:51 +0000 (UTC)
commit a2783c0a48318a88b1e72120d4fa6adad3b87e8f
Author: Matthew Barnes <mbarnes redhat com>
Date: Fri Jan 4 10:50:12 2013 -0500
Bug 691133 - Evolution creates 'highlight' zombies
Evolution spawns the 'highlight' program with these flags:
G_SPAWN_SEARCH_PATH
G_SPAWN_DO_NOT_REAP_CHILD
G_SPAWN_DO_NOT_REAP_CHILD results in zombie 'highlight' processes.
Note, G_SPAWN_SEARCH_PATH is still needed on the gnome-3-6 branch.
In later versions we have configure determine the absolute path to
the 'highlight' program to avoid depending on the user's $PATH.
.../e-mail-formatter-text-highlight.c | 22 ++++++++++++-------
1 files changed, 14 insertions(+), 8 deletions(-)
---
diff --git a/modules/text-highlight/e-mail-formatter-text-highlight.c b/modules/text-highlight/e-mail-formatter-text-highlight.c
index e0a892c..3c71aea 100644
--- a/modules/text-highlight/e-mail-formatter-text-highlight.c
+++ b/modules/text-highlight/e-mail-formatter-text-highlight.c
@@ -189,14 +189,14 @@ emfe_text_highlight_format (EMailFormatterExtension *extension,
} else if (context->mode == E_MAIL_FORMATTER_MODE_RAW) {
gint pipe_stdin, pipe_stdout;
GPid pid;
- CamelStream *read, *write, *utf8;
CamelDataWrapper *dw;
- gchar *font_family, *font_size, *syntax, *tmp;
- GByteArray *ba;
+ gchar *font_family, *font_size, *syntax;
gboolean use_custom_font;
EShell *shell;
EShellSettings *settings;
PangoFontDescription *fd;
+ gboolean success;
+
const gchar *argv[] = { "highlight",
NULL, /* --font= */
NULL, /* --font-size= */
@@ -258,11 +258,17 @@ emfe_text_highlight_format (EMailFormatterExtension *extension,
argv[3] = g_strdup_printf ("--syntax=%s", syntax);
g_free (syntax);
- if (g_spawn_async_with_pipes (
- NULL, (gchar **) argv, NULL,
- G_SPAWN_SEARCH_PATH |
- G_SPAWN_DO_NOT_REAP_CHILD,
- NULL, NULL, &pid, &pipe_stdin, &pipe_stdout, NULL, NULL)) {
+ success = g_spawn_async_with_pipes (
+ NULL, (gchar **) argv, NULL,
+ G_SPAWN_SEARCH_PATH, NULL, NULL, &pid,
+ &pipe_stdin, &pipe_stdout, NULL, NULL);
+
+ if (success) {
+ CamelStream *read;
+ CamelStream *write;
+ CamelStream *utf8;
+ GByteArray *ba;
+ gchar *tmp;
write = camel_stream_fs_new_with_fd (pipe_stdin);
read = camel_stream_fs_new_with_fd (pipe_stdout);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]