diff options
author | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2010-11-30 18:48:04 +0800 |
---|---|---|
committer | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2010-11-30 18:48:04 +0800 |
commit | 24f77567c932c7693b3051156f8d5ca4499c6d8c (patch) | |
tree | f5112cd6468fbe3c7497153cb84e9a14233a6eb4 | |
parent | 7c0d36e3d1604a4056934bc1a44e89d0e0875051 (diff) | |
download | gsoc2013-empathy-24f77567c932c7693b3051156f8d5ca4499c6d8c.tar gsoc2013-empathy-24f77567c932c7693b3051156f8d5ca4499c6d8c.tar.gz gsoc2013-empathy-24f77567c932c7693b3051156f8d5ca4499c6d8c.tar.bz2 gsoc2013-empathy-24f77567c932c7693b3051156f8d5ca4499c6d8c.tar.lz gsoc2013-empathy-24f77567c932c7693b3051156f8d5ca4499c6d8c.tar.xz gsoc2013-empathy-24f77567c932c7693b3051156f8d5ca4499c6d8c.tar.zst gsoc2013-empathy-24f77567c932c7693b3051156f8d5ca4499c6d8c.zip |
sound-manager: cache the sound GSettings
-rw-r--r-- | libempathy-gtk/empathy-sound-manager.c | 39 |
1 files changed, 15 insertions, 24 deletions
diff --git a/libempathy-gtk/empathy-sound-manager.c b/libempathy-gtk/empathy-sound-manager.c index d98b7ea79..45987957e 100644 --- a/libempathy-gtk/empathy-sound-manager.c +++ b/libempathy-gtk/empathy-sound-manager.c @@ -78,6 +78,7 @@ struct _EmpathySoundManagerPrivate * Key: An EmpathySound * Value : The EmpathyRepeatableSound associated with that EmpathySound. */ GHashTable *repeating_sounds; + GSettings *gsettings_sound; }; static void @@ -86,6 +87,7 @@ empathy_sound_manager_dispose (GObject *object) EmpathySoundManager *self = (EmpathySoundManager *) object; tp_clear_pointer (&self->priv->repeating_sounds, g_hash_table_unref); + tp_clear_object (&self->priv->gsettings_sound); G_OBJECT_CLASS (empathy_sound_manager_parent_class)->dispose (object); } @@ -140,6 +142,8 @@ empathy_sound_manager_init (EmpathySoundManager *self) self->priv->repeating_sounds = g_hash_table_new_full (NULL, NULL, NULL, repeating_sounds_item_delete); + + self->priv->gsettings_sound = g_settings_new (EMPATHY_PREFS_SOUNDS_SCHEMA); } EmpathySoundManager * @@ -157,42 +161,29 @@ empathy_sound_manager_dup_singleton (void) } static gboolean -empathy_sound_pref_is_enabled (EmpathySound sound_id) +empathy_sound_pref_is_enabled (EmpathySoundManager *self, + EmpathySound sound_id) { EmpathySoundEntry *entry; - GSettings *gsettings = g_settings_new (EMPATHY_PREFS_SOUNDS_SCHEMA); - gboolean res; entry = &(sound_entries[sound_id]); g_return_val_if_fail (entry->sound_id == sound_id, FALSE); if (entry->key == NULL) - { - res = TRUE; - goto finally; - } - - res = g_settings_get_boolean (gsettings, EMPATHY_PREFS_SOUNDS_ENABLED); + return TRUE; - if (!res) - goto finally; + if (! g_settings_get_boolean (self->priv->gsettings_sound, + EMPATHY_PREFS_SOUNDS_ENABLED)) + return FALSE; if (!empathy_check_available_state ()) { - if (g_settings_get_boolean (gsettings, + if (g_settings_get_boolean (self->priv->gsettings_sound, EMPATHY_PREFS_SOUNDS_DISABLED_AWAY)) - { - res = FALSE; - goto finally; - } + return FALSE; } - res = g_settings_get_boolean (gsettings, entry->key); - -finally: - g_object_unref (gsettings); - - return res; + return g_settings_get_boolean (self->priv->gsettings_sound, entry->key); } /** @@ -310,7 +301,7 @@ empathy_sound_manager_play_full (EmpathySoundManager *self, g_return_val_if_fail (GTK_IS_WIDGET (widget), FALSE); g_return_val_if_fail (sound_id < LAST_EMPATHY_SOUND, FALSE); - if (!empathy_sound_pref_is_enabled (sound_id)) + if (!empathy_sound_pref_is_enabled (self, sound_id)) return FALSE; /* The sound might already be playing repeatedly. If it's the case, we @@ -413,7 +404,7 @@ empathy_sound_manager_start_playing (EmpathySoundManager *self, g_return_val_if_fail (GTK_IS_WIDGET (widget), FALSE); g_return_val_if_fail (sound_id < LAST_EMPATHY_SOUND, FALSE); - if (!empathy_sound_pref_is_enabled (sound_id)) + if (!empathy_sound_pref_is_enabled (self, sound_id)) return FALSE; if (g_hash_table_lookup (self->priv->repeating_sounds, |