From: Christian Kampka Date: Tue, 30 Mar 2010 12:23:49 +0000 (+0200) Subject: add gconf key to disable auto-away (#613603) X-Git-Url: https://git.0d.be/?p=empathy.git;a=commitdiff_plain;h=597aeabb364bc04027209e0a37fae53a7d4208b8 add gconf key to disable auto-away (#613603) --- diff --git a/data/empathy.schemas.in b/data/empathy.schemas.in index e151fb5f..5ed04e75 100644 --- a/data/empathy.schemas.in +++ b/data/empathy.schemas.in @@ -521,6 +521,20 @@ + + /schemas/apps/empathy/autoaway + /apps/empathy/autoaway + empathy + bool + true + + Empathy should auto-away when idle + + Whether Empathy should go into away mode automatically if user is idle. + + + + /schemas/apps/empathy/import_asked /apps/empathy/import_asked diff --git a/libempathy-gtk/empathy-conf.h b/libempathy-gtk/empathy-conf.h index 21e3b381..78d0bbd6 100644 --- a/libempathy-gtk/empathy-conf.h +++ b/libempathy-gtk/empathy-conf.h @@ -81,6 +81,7 @@ struct _EmpathyConfClass { #define EMPATHY_PREFS_HINTS_CLOSE_MAIN_WINDOW EMPATHY_PREFS_PATH "/hints/close_main_window" #define EMPATHY_PREFS_USE_CONN EMPATHY_PREFS_PATH "/use_conn" #define EMPATHY_PREFS_AUTOCONNECT EMPATHY_PREFS_PATH "/autoconnect" +#define EMPATHY_PREFS_AUTOAWAY EMPATHY_PREFS_PATH "/autoaway" #define EMPATHY_PREFS_IMPORT_ASKED EMPATHY_PREFS_PATH "/import_asked" #define EMPATHY_PREFS_BUTTERFLY_LOGS_MIGRATED EMPATHY_PREFS_PATH "/butterfly_logs_migrated" #define EMPATHY_PREFS_FILE_TRANSFER_DEFAULT_FOLDER EMPATHY_PREFS_PATH "/file_transfer/default_folder" diff --git a/src/empathy.c b/src/empathy.c index 377feea3..8b2869ad 100644 --- a/src/empathy.c +++ b/src/empathy.c @@ -549,6 +549,18 @@ chatroom_manager_ready_cb (EmpathyChatroomManager *chatroom_manager, account_manager_chatroom_ready_cb, chatroom_manager); } +static void +empathy_idle_set_auto_away_cb (EmpathyConf *conf, + const gchar *key, + gpointer user_data) +{ + gboolean autoaway; + EmpathyIdle *idle = user_data; + + empathy_conf_get_bool (conf, key, &autoaway); + empathy_idle_set_auto_away (idle, autoaway); +} + int main (int argc, char *argv[]) { @@ -572,7 +584,7 @@ main (int argc, char *argv[]) GError *error = NULL; UniqueApp *unique_app; gboolean chatroom_manager_ready; - + gboolean autoaway = TRUE; #ifdef ENABLE_DEBUG TpDebugSender *debug_sender; #endif /* ENABLE_TPL */ @@ -641,7 +653,16 @@ main (int argc, char *argv[]) /* Setting up Idle */ idle = empathy_idle_dup_singleton (); - empathy_idle_set_auto_away (idle, TRUE); + + empathy_conf_get_bool (empathy_conf_get (), + EMPATHY_PREFS_AUTOAWAY, &autoaway); + + empathy_conf_notify_add (empathy_conf_get (), + EMPATHY_PREFS_AUTOAWAY, + empathy_idle_set_auto_away_cb, + idle); + + empathy_idle_set_auto_away (idle, autoaway); /* Setting up Connectivity */ connectivity = empathy_connectivity_dup_singleton ();