[gnome-menus/wip/gobject-review: 18/38] layout: Use thread-default main context for callbacks
- From: Vincent Untz <vuntz src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-menus/wip/gobject-review: 18/38] layout: Use thread-default main context for callbacks
- Date: Sun, 12 Jun 2011 10:00:46 +0000 (UTC)
commit 8d23812c0406fc59a548980d1cd594eed6569bdd
Author: Colin Walters <walters verbum org>
Date: Mon Apr 18 10:10:53 2011 -0400
layout: Use thread-default main context for callbacks
Rather than hardcoding g_idle_add(); this gives us future
flexibility for thread support.
https://bugzilla.gnome.org/show_bug.cgi?id=647968
libmenu/menu-layout.c | 29 ++++++++++++++++++++++-------
1 files changed, 22 insertions(+), 7 deletions(-)
---
diff --git a/libmenu/menu-layout.c b/libmenu/menu-layout.c
index 8439bca..57c5660 100644
--- a/libmenu/menu-layout.c
+++ b/libmenu/menu-layout.c
@@ -64,8 +64,10 @@ struct MenuLayoutNodeRoot
char *basedir;
char *name;
+ GMainContext *main_context;
+
GSList *monitors;
- guint monitors_idle_handler;
+ GSource *monitors_idle_handler;
};
struct MenuLayoutNodeMenu
@@ -141,7 +143,7 @@ menu_layout_invoke_monitors (MenuLayoutNodeRoot *nr)
g_assert (nr->node.type == MENU_LAYOUT_NODE_ROOT);
- nr->monitors_idle_handler = 0;
+ nr->monitors_idle_handler = NULL;
tmp = nr->monitors;
while (tmp != NULL)
@@ -167,9 +169,13 @@ handle_entry_directory_changed (EntryDirectory *dir,
nr = (MenuLayoutNodeRoot *) menu_layout_node_get_root (node);
- if (nr->monitors_idle_handler == 0)
+ if (nr->monitors_idle_handler == NULL)
{
- nr->monitors_idle_handler = g_idle_add ((GSourceFunc) menu_layout_invoke_monitors, nr);
+ nr->monitors_idle_handler = g_idle_source_new ();
+ g_source_set_callback (nr->monitors_idle_handler,
+ (GSourceFunc) menu_layout_invoke_monitors, nr, NULL);
+ g_source_attach (nr->monitors_idle_handler, nr->main_context);
+ g_source_unref (nr->monitors_idle_handler);
}
}
@@ -241,9 +247,13 @@ menu_layout_node_unref (MenuLayoutNode *node)
g_slist_foreach (nr->monitors, (GFunc) g_free, NULL);
g_slist_free (nr->monitors);
- if (nr->monitors_idle_handler != 0)
- g_source_remove (nr->monitors_idle_handler);
- nr->monitors_idle_handler = 0;
+ if (nr->main_context != NULL)
+ g_main_context_unref (nr->main_context);
+ nr->main_context = NULL;
+
+ if (nr->monitors_idle_handler != NULL)
+ g_source_destroy (nr->monitors_idle_handler);
+ nr->monitors_idle_handler = NULL;
g_free (nr->basedir);
g_free (nr->name);
@@ -2287,6 +2297,7 @@ menu_layout_load (const char *filename,
const char *non_prefixed_basename,
GError **err)
{
+ GMainContext *main_context;
GMarkupParseContext *context;
MenuLayoutNodeRoot *root;
MenuLayoutNode *retval;
@@ -2302,6 +2313,8 @@ menu_layout_load (const char *filename,
retval = NULL;
context = NULL;
+ main_context = g_main_context_get_thread_default ();
+
menu_verbose ("Loading \"%s\" from disk\n", filename);
if (!g_file_get_contents (filename,
@@ -2349,6 +2362,8 @@ menu_layout_load (const char *filename,
error = NULL;
g_markup_parse_context_end_parse (context, &error);
+ root->main_context = main_context ? g_main_context_ref (main_context) : NULL;
+
out:
if (context)
g_markup_parse_context_free (context);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]