[evolution/gnome-3-20] Bug 765636 - Runtime warning from spi_register_deregister_object() on quit
- From: Milan Crha <mcrha src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution/gnome-3-20] Bug 765636 - Runtime warning from spi_register_deregister_object() on quit
- Date: Thu, 28 Apr 2016 10:57:07 +0000 (UTC)
commit 6cb9f909112c5499705cf913cdb7c79b3a33982e
Author: Milan Crha <mcrha redhat com>
Date: Thu Apr 28 12:50:42 2016 +0200
Bug 765636 - Runtime warning from spi_register_deregister_object() on quit
e-util/gal-a11y-e-table-item.c | 28 ++++++++++++++++++++++++++--
1 files changed, 26 insertions(+), 2 deletions(-)
---
diff --git a/e-util/gal-a11y-e-table-item.c b/e-util/gal-a11y-e-table-item.c
index 84dbf1c..c94b2cb 100644
--- a/e-util/gal-a11y-e-table-item.c
+++ b/e-util/gal-a11y-e-table-item.c
@@ -120,8 +120,8 @@ item_finalized (gpointer user_data,
}
g_object_set_data (G_OBJECT (a11y), "gail-focus-object", NULL);
- atk_state_set_add_state (priv->state_set, ATK_STATE_DEFUNCT);
- atk_object_notify_state_change (ATK_OBJECT (a11y), ATK_STATE_DEFUNCT, TRUE);
+ if (atk_state_set_add_state (priv->state_set, ATK_STATE_DEFUNCT))
+ atk_object_notify_state_change (ATK_OBJECT (a11y), ATK_STATE_DEFUNCT, TRUE);
if (priv->selection)
gal_a11y_e_table_item_unref_selection (a11y);
@@ -129,6 +129,28 @@ item_finalized (gpointer user_data,
g_object_unref (a11y);
}
+static void
+gal_a11y_e_table_item_state_change_cb (AtkObject *atkobject,
+ const gchar *state_name,
+ gboolean was_set,
+ gpointer user_data)
+{
+ g_return_if_fail (GAL_A11Y_IS_E_TABLE_ITEM (atkobject));
+
+ if (atk_state_type_for_name (state_name) == ATK_STATE_DEFUNCT) {
+ GalA11yETableItemPrivate *priv;
+
+ priv = GET_PRIVATE (atkobject);
+
+ g_return_if_fail (priv != NULL);
+
+ if (was_set)
+ atk_state_set_add_state (priv->state_set, ATK_STATE_DEFUNCT);
+ else
+ atk_state_set_remove_state (priv->state_set, ATK_STATE_DEFUNCT);
+ }
+}
+
static AtkStateSet *
eti_ref_state_set (AtkObject *accessible)
{
@@ -1139,6 +1161,8 @@ gal_a11y_e_table_item_new (ETableItem *item)
atk_state_set_add_state (GET_PRIVATE (a11y)->state_set, ATK_STATE_SHOWING);
atk_state_set_add_state (GET_PRIVATE (a11y)->state_set, ATK_STATE_VISIBLE);
+ g_signal_connect (a11y, "state-change", G_CALLBACK (gal_a11y_e_table_item_state_change_cb), NULL);
+
accessible = ATK_OBJECT (a11y);
GET_PRIVATE (a11y)->item = item;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]