mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-08 19:50:21 +00:00
a11y: Hack around infinite loops in parent setting
This is kind of a hack to get rid of infinite loops that occur when child accessibles try to set their parent upon creation but the parent accessible creates its children in the initialize vfunc. Because in that case, the parent will not have an accessible set when the child tries to access it, because it is still initializing itself. Which will cause a new accessible to be created. https://bugzilla.gnome.org/show_bug.cgi?id=660687
This commit is contained in:
parent
7d165b67f9
commit
b195c7dbb2
@ -12088,12 +12088,6 @@ gtk_widget_real_get_accessible (GtkWidget *widget)
|
|||||||
accessible =
|
accessible =
|
||||||
atk_object_factory_create_accessible (factory,
|
atk_object_factory_create_accessible (factory,
|
||||||
G_OBJECT (widget));
|
G_OBJECT (widget));
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
accessible = g_object_new (priv->accessible_type, NULL);
|
|
||||||
atk_object_initialize (accessible, widget);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (priv->accessible_role != ATK_ROLE_INVALID)
|
if (priv->accessible_role != ATK_ROLE_INVALID)
|
||||||
atk_object_set_role (accessible, priv->accessible_role);
|
atk_object_set_role (accessible, priv->accessible_role);
|
||||||
@ -12102,6 +12096,20 @@ gtk_widget_real_get_accessible (GtkWidget *widget)
|
|||||||
quark_accessible_object,
|
quark_accessible_object,
|
||||||
accessible);
|
accessible);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
accessible = g_object_new (priv->accessible_type, NULL);
|
||||||
|
|
||||||
|
if (priv->accessible_role != ATK_ROLE_INVALID)
|
||||||
|
atk_object_set_role (accessible, priv->accessible_role);
|
||||||
|
|
||||||
|
g_object_set_qdata (G_OBJECT (widget),
|
||||||
|
quark_accessible_object,
|
||||||
|
accessible);
|
||||||
|
|
||||||
|
atk_object_initialize (accessible, widget);
|
||||||
|
}
|
||||||
|
}
|
||||||
return accessible;
|
return accessible;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user