X-Git-Url: http://git.maemo.org/git/?p=modest;a=blobdiff_plain;f=src%2Fmodest-ui-dimming-manager.c;h=f7e82d1461b154796226b848b401a717b761c637;hp=be768979db005e810b8f1f83cce7877317eb7c27;hb=f3d0a6c5a9dd68e70ce914d66814330aabf33d37;hpb=62773cefa3cd99e91d6ed3230b685a46b5997915 diff --git a/src/modest-ui-dimming-manager.c b/src/modest-ui-dimming-manager.c index be76897..f7e82d1 100644 --- a/src/modest-ui-dimming-manager.c +++ b/src/modest-ui-dimming-manager.c @@ -144,7 +144,7 @@ modest_ui_dimming_manager_dispose (GObject *obj) priv = MODEST_UI_DIMMING_MANAGER_GET_PRIVATE(obj); - if (priv->delayed_calls != NULL) { + if (priv->delayed_calls != NULL && (g_hash_table_size (priv->delayed_calls) > 0)) { /* Remove all pending calls */ g_hash_table_foreach (priv->delayed_calls, remove_all_timeouts, @@ -208,6 +208,7 @@ typedef struct ModestDimmingRulesGroup *group; ModestUIDimmingManager *manager; gchar *name; + gboolean delete; } DelayedDimmingRules; static gboolean @@ -217,6 +218,9 @@ process_dimming_rules_delayed (gpointer data) gpointer timeout_handler; ModestUIDimmingManagerPrivate *priv; + /* Let the destroyer remove it from the hash table */ + helper->delete = TRUE; + /* We remove the timeout here because the execute action could take too much time, and so this will be called again */ priv = MODEST_UI_DIMMING_MANAGER_GET_PRIVATE(helper->manager); @@ -240,7 +244,15 @@ process_dimming_rules_delayed_destroyer (gpointer data) ModestUIDimmingManagerPrivate *priv; priv = MODEST_UI_DIMMING_MANAGER_GET_PRIVATE(helper->manager); - g_hash_table_remove (priv->delayed_calls, helper->name); + + /* We can only destroy it if we had really executed it. If the + source is removed because the manager is finalized then we + cannot remove it because it removes the sources in a + foreach, that does not allow you to modify the hash table + in the mean time */ + if (helper->delete) + g_hash_table_remove (priv->delayed_calls, helper->name); + g_free (helper->name); g_object_unref (helper->manager); g_slice_free (DelayedDimmingRules, helper); @@ -254,7 +266,7 @@ modest_ui_dimming_manager_process_dimming_rules_group (ModestUIDimmingManager *s ModestUIDimmingManagerPrivate *priv; guint *handler, new_handler; DelayedDimmingRules *helper; - + g_return_if_fail (group_name != NULL); priv = MODEST_UI_DIMMING_MANAGER_GET_PRIVATE(self); @@ -271,9 +283,13 @@ modest_ui_dimming_manager_process_dimming_rules_group (ModestUIDimmingManager *s helper->group = group; helper->manager = g_object_ref (self); helper->name = g_strdup (group_name); - new_handler = g_timeout_add_full (G_PRIORITY_DEFAULT, 100, process_dimming_rules_delayed, + helper->delete = FALSE; + new_handler = g_timeout_add_full (G_PRIORITY_DEFAULT, 100, + process_dimming_rules_delayed, helper, process_dimming_rules_delayed_destroyer); - g_hash_table_insert (priv->delayed_calls, g_strdup (group_name), GINT_TO_POINTER (new_handler)); + g_hash_table_insert (priv->delayed_calls, + g_strdup (group_name), + GINT_TO_POINTER (new_handler)); MODEST_DEBUG_BLOCK(g_print ("---------------------Adding %d\n", new_handler);); } else { MODEST_DEBUG_BLOCK(g_print ("---------------------Ignoring\n");); @@ -285,7 +301,7 @@ static void _process_all_rules (gpointer key, gpointer value, gpointer user_data) { g_return_if_fail (MODEST_IS_DIMMING_RULES_GROUP (value)); - + modest_dimming_rules_group_execute (MODEST_DIMMING_RULES_GROUP (value)); }