From 5bb98fd170f62423ed936fd19bab72f0ee118d81 Mon Sep 17 00:00:00 2001 From: Ted Gould Date: Tue, 16 Mar 2010 15:44:41 -0500 Subject: Tracking the notifications, so that we can unregister them with new menus. --- src/gconf-helper.c | 27 +++++++++++++++++++++++---- 1 file changed, 23 insertions(+), 4 deletions(-) diff --git a/src/gconf-helper.c b/src/gconf-helper.c index 588b11c..77fde1d 100644 --- a/src/gconf-helper.c +++ b/src/gconf-helper.c @@ -34,6 +34,8 @@ with this program. If not, see . #include "gconf-helper.h" static GConfClient * gconf_client = NULL; +static guint confirmation_notify = 0; +static guint logout_notify = 0; gboolean supress_confirmations (void) { @@ -82,14 +84,31 @@ update_logout_callback (GConfClient *client, guint cnxn_id, GConfEntry *entry, void update_menu_entries(RestartShutdownLogoutMenuItems * restart_shutdown_logout_mi, DbusmenuMenuitem * logoutitem) { + /* If we don't have a client, build one. */ if(!gconf_client) { gconf_client = gconf_client_get_default (); } - gconf_client_add_dir (gconf_client, GLOBAL_DIR, - GCONF_CLIENT_PRELOAD_ONELEVEL, NULL); - gconf_client_notify_add (gconf_client, SUPPRESS_KEY, + + /* If we've not gotten any notifications, then we need + to add the directory for notifications to come from. */ + if (confirmation_notify == 0 || logout_notify == 0) { + gconf_client_add_dir (gconf_client, GLOBAL_DIR, + GCONF_CLIENT_PRELOAD_ONELEVEL, NULL); + } + + if (confirmation_notify != 0) { + gconf_client_notify_remove (gconf_client, confirmation_notify); + confirmation_notify = 0; + } + + if (logout_notify != 0) { + gconf_client_notify_remove (gconf_client, logout_notify); + logout_notify = 0; + } + + confirmation_notify = gconf_client_notify_add (gconf_client, SUPPRESS_KEY, update_menu_entries_callback, restart_shutdown_logout_mi, NULL, NULL); - gconf_client_notify_add (gconf_client, LOGOUT_KEY, + logout_notify = gconf_client_notify_add (gconf_client, LOGOUT_KEY, update_logout_callback, logoutitem, NULL, NULL); } -- cgit v1.2.3