aboutsummaryrefslogtreecommitdiff
path: root/src/gconf-helper.c
diff options
context:
space:
mode:
authorSebastien Bacher <seb128@ubuntu.com>2010-04-09 20:59:20 +0200
committerSebastien Bacher <seb128@ubuntu.com>2010-04-09 20:59:20 +0200
commitef92fb6b07220aea130c9a32890c56623e393a45 (patch)
tree75c5ec3c6753057bcfa68703e206d2a6c2c3ee26 /src/gconf-helper.c
parent81db14844ae153486cd472e1186d98b33865a23a (diff)
parentdda06df8cd9fd0186d81701c72ff2e6fa36f5658 (diff)
downloadayatana-indicator-session-ef92fb6b07220aea130c9a32890c56623e393a45.tar.gz
ayatana-indicator-session-ef92fb6b07220aea130c9a32890c56623e393a45.tar.bz2
ayatana-indicator-session-ef92fb6b07220aea130c9a32890c56623e393a45.zip
releasing version 0.2.8-0ubuntu1~ppa1
Diffstat (limited to 'src/gconf-helper.c')
-rw-r--r--src/gconf-helper.c60
1 files changed, 58 insertions, 2 deletions
diff --git a/src/gconf-helper.c b/src/gconf-helper.c
index 29d8526..4911dcb 100644
--- a/src/gconf-helper.c
+++ b/src/gconf-helper.c
@@ -36,6 +36,8 @@ with this program. If not, see <http://www.gnu.org/licenses/>.
static GConfClient * gconf_client = NULL;
static guint confirmation_notify = 0;
static guint logout_notify = 0;
+static guint restart_notify = 0;
+static guint shutdown_notify = 0;
gboolean
supress_confirmations (void) {
@@ -53,6 +55,22 @@ show_logout (void) {
return !gconf_client_get_bool (gconf_client, LOGOUT_KEY, NULL) ;
}
+gboolean
+show_restart (void) {
+ if(!gconf_client) {
+ gconf_client = gconf_client_get_default ();
+ }
+ return !gconf_client_get_bool (gconf_client, RESTART_KEY, NULL) ;
+}
+
+gboolean
+show_shutdown (void) {
+ if(!gconf_client) {
+ gconf_client = gconf_client_get_default ();
+ }
+ return !gconf_client_get_bool (gconf_client, SHUTDOWN_KEY, NULL) ;
+}
+
static void update_menu_entries_callback (GConfClient *client, guint cnxn_id, GConfEntry *entry, gpointer data) {
RestartShutdownLogoutMenuItems * restart_shutdown_logout_mi = (RestartShutdownLogoutMenuItems*) data;
GConfValue * value = gconf_entry_get_value (entry);
@@ -82,8 +100,30 @@ update_logout_callback (GConfClient *client, guint cnxn_id, GConfEntry *entry,
}
}
+static void
+update_restart_callback (GConfClient *client, guint cnxn_id, GConfEntry *entry, gpointer data) {
+ DbusmenuMenuitem * mi = (DbusmenuMenuitem*) data;
+ GConfValue * value = gconf_entry_get_value (entry);
+ const gchar * key = gconf_entry_get_key (entry);
+
+ if(g_strcmp0 (key, RESTART_KEY) == 0) {
+ dbusmenu_menuitem_property_set_bool(mi, DBUSMENU_MENUITEM_PROP_VISIBLE, !gconf_value_get_bool(value));
+ }
+}
+
+static void
+update_shutdown_callback (GConfClient *client, guint cnxn_id, GConfEntry *entry, gpointer data) {
+ DbusmenuMenuitem * mi = (DbusmenuMenuitem*) data;
+ GConfValue * value = gconf_entry_get_value (entry);
+ const gchar * key = gconf_entry_get_key (entry);
+
+ if(g_strcmp0 (key, SHUTDOWN_KEY) == 0) {
+ dbusmenu_menuitem_property_set_bool(mi, DBUSMENU_MENUITEM_PROP_VISIBLE, !gconf_value_get_bool(value));
+ }
+}
+
void
-update_menu_entries(RestartShutdownLogoutMenuItems * restart_shutdown_logout_mi, DbusmenuMenuitem * logoutitem) {
+update_menu_entries(RestartShutdownLogoutMenuItems * restart_shutdown_logout_mi) {
/* If we don't have a client, build one. */
if(!gconf_client) {
gconf_client = gconf_client_get_default ();
@@ -106,9 +146,25 @@ update_menu_entries(RestartShutdownLogoutMenuItems * restart_shutdown_logout_mi,
logout_notify = 0;
}
+ if (restart_notify != 0) {
+ gconf_client_notify_remove (gconf_client, restart_notify);
+ restart_notify = 0;
+ }
+
+ if (shutdown_notify != 0) {
+ gconf_client_notify_remove (gconf_client, shutdown_notify);
+ shutdown_notify = 0;
+ }
+
confirmation_notify = gconf_client_notify_add (gconf_client, SUPPRESS_KEY,
update_menu_entries_callback, restart_shutdown_logout_mi, NULL, NULL);
logout_notify = gconf_client_notify_add (gconf_client, LOGOUT_KEY,
- update_logout_callback, logoutitem, NULL, NULL);
+ update_logout_callback, restart_shutdown_logout_mi->logout_mi, NULL, NULL);
+ restart_notify = gconf_client_notify_add (gconf_client, RESTART_KEY,
+ update_restart_callback, restart_shutdown_logout_mi->restart_mi, NULL, NULL);
+ shutdown_notify = gconf_client_notify_add (gconf_client, SHUTDOWN_KEY,
+ update_shutdown_callback, restart_shutdown_logout_mi->shutdown_mi, NULL, NULL);
+
+ return;
}