diff options
author | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2011-08-30 19:25:35 +0800 |
---|---|---|
committer | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2011-08-30 20:04:45 +0800 |
commit | dd7043a57b488e1cac84c36fba72dea3d220ea41 (patch) | |
tree | 373fff1b1c014d040ae2103c34e320bf52200d3a /src/empathy.c | |
parent | c079bd6891e308a63f9f920e9cbaf001e993f471 (diff) | |
download | gsoc2013-empathy-dd7043a57b488e1cac84c36fba72dea3d220ea41.tar gsoc2013-empathy-dd7043a57b488e1cac84c36fba72dea3d220ea41.tar.gz gsoc2013-empathy-dd7043a57b488e1cac84c36fba72dea3d220ea41.tar.bz2 gsoc2013-empathy-dd7043a57b488e1cac84c36fba72dea3d220ea41.tar.lz gsoc2013-empathy-dd7043a57b488e1cac84c36fba72dea3d220ea41.tar.xz gsoc2013-empathy-dd7043a57b488e1cac84c36fba72dea3d220ea41.tar.zst gsoc2013-empathy-dd7043a57b488e1cac84c36fba72dea3d220ea41.zip |
Don't update presence on session changes if the Shell is running
The Shell does it for us.
https://bugzilla.gnome.org/show_bug.cgi?id=656631
Diffstat (limited to 'src/empathy.c')
-rw-r--r-- | src/empathy.c | 47 |
1 files changed, 27 insertions, 20 deletions
diff --git a/src/empathy.c b/src/empathy.c index c3de8594a..9294557ec 100644 --- a/src/empathy.c +++ b/src/empathy.c @@ -245,6 +245,17 @@ empathy_app_local_command_line (GApplication *app, gchar ***arguments, gint *exit_status); +static void +empathy_presence_manager_set_auto_away_cb (GSettings *gsettings, + const gchar *key, + gpointer user_data) +{ + EmpathyPresenceManager *presence_mgr = user_data; + + empathy_presence_manager_set_auto_away (presence_mgr, + g_settings_get_boolean (gsettings, key)); +} + #define GNOME_SHELL_BUS_NAME "org.gnome.Shell" static void @@ -273,11 +284,27 @@ out: if (self->shell_running) { DEBUG ("GNOME Shell is running, don't create status icon"); + + /* Rely on GNOME Shell to watch session state */ + empathy_presence_manager_set_auto_away (self->presence_mgr, FALSE); } else { + gboolean autoaway; + self->icon = empathy_status_icon_new (GTK_WINDOW (self->window), self->start_hidden); + + /* Allow Empathy to watch session state */ + autoaway = g_settings_get_boolean (self->gsettings, + EMPATHY_PREFS_AUTOAWAY); + + g_signal_connect (self->gsettings, + "changed::" EMPATHY_PREFS_AUTOAWAY, + G_CALLBACK (empathy_presence_manager_set_auto_away_cb), + self->presence_mgr); + + empathy_presence_manager_set_auto_away (self->presence_mgr, autoaway); } } @@ -726,22 +753,10 @@ chatroom_manager_ready_cb (EmpathyChatroomManager *chatroom_manager, } static void -empathy_presence_manager_set_auto_away_cb (GSettings *gsettings, - const gchar *key, - gpointer user_data) -{ - EmpathyPresenceManager *presence_mgr = user_data; - - empathy_presence_manager_set_auto_away (presence_mgr, - g_settings_get_boolean (gsettings, key)); -} - -static void empathy_app_constructed (GObject *object) { EmpathyApp *self = (EmpathyApp *) object; gboolean chatroom_manager_ready; - gboolean autoaway; g_set_application_name (_(PACKAGE_NAME)); @@ -760,14 +775,6 @@ empathy_app_constructed (GObject *object) self->presence_mgr = empathy_presence_manager_dup_singleton (); self->gsettings = g_settings_new (EMPATHY_PREFS_SCHEMA); - autoaway = g_settings_get_boolean (self->gsettings, EMPATHY_PREFS_AUTOAWAY); - - g_signal_connect (self->gsettings, - "changed::" EMPATHY_PREFS_AUTOAWAY, - G_CALLBACK (empathy_presence_manager_set_auto_away_cb), - self->presence_mgr); - - empathy_presence_manager_set_auto_away (self->presence_mgr, autoaway); /* Setting up Connectivity */ self->connectivity = empathy_connectivity_dup_singleton (); |