[gtk+] window: Emit a11y signals directly on popover added/removed
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+] window: Emit a11y signals directly on popover added/removed
- Date: Mon, 10 Mar 2014 22:05:50 +0000 (UTC)
commit 168e4faf508cdded8227d633152657fa663b3a96
Author: Carlos Garnacho <carlosg gnome org>
Date: Mon Mar 10 12:27:50 2014 +0100
window: Emit a11y signals directly on popover added/removed
As those are internal children, there's no signal that GtkWindowAccessible
could catch when those are added or removed, so make GtkWindow use the private
GtkContainerAccessible methods to add/remove the child accessible when that
happens.
https://bugzilla.gnome.org/show_bug.cgi?id=725864
gtk/gtkwindow.c | 11 +++++++++++
1 files changed, 11 insertions(+), 0 deletions(-)
---
diff --git a/gtk/gtkwindow.c b/gtk/gtkwindow.c
index d996af1..56955e4 100644
--- a/gtk/gtkwindow.c
+++ b/gtk/gtkwindow.c
@@ -57,6 +57,7 @@
#include "gtkheaderbar.h"
#include "gtkheaderbarprivate.h"
#include "a11y/gtkwindowaccessible.h"
+#include "a11y/gtkcontaineraccessibleprivate.h"
#include "gtkapplicationprivate.h"
#ifdef GDK_WINDOWING_X11
@@ -12236,6 +12237,7 @@ _gtk_window_add_popover (GtkWindow *window,
{
GtkWindowPrivate *priv;
GtkWindowPopover *data;
+ AtkObject *accessible;
g_return_if_fail (GTK_IS_WINDOW (window));
g_return_if_fail (GTK_IS_WIDGET (popover));
@@ -12254,6 +12256,10 @@ _gtk_window_add_popover (GtkWindow *window,
popover_realize (popover, data, window);
gtk_widget_set_parent (popover, GTK_WIDGET (window));
+
+ accessible = gtk_widget_get_accessible (GTK_WIDGET (window));
+ _gtk_container_accessible_add_child (GTK_CONTAINER_ACCESSIBLE (accessible),
+ gtk_widget_get_accessible (popover), -1);
}
void
@@ -12262,6 +12268,7 @@ _gtk_window_remove_popover (GtkWindow *window,
{
GtkWindowPrivate *priv;
GtkWindowPopover *data;
+ AtkObject *accessible;
g_return_if_fail (GTK_IS_WINDOW (window));
g_return_if_fail (GTK_IS_WIDGET (popover));
@@ -12277,6 +12284,10 @@ _gtk_window_remove_popover (GtkWindow *window,
popover_unrealize (popover, data, window);
priv->popovers = g_list_remove (priv->popovers, data);
+
+ accessible = gtk_widget_get_accessible (GTK_WIDGET (window));
+ _gtk_container_accessible_remove_child (GTK_CONTAINER_ACCESSIBLE (accessible),
+ gtk_widget_get_accessible (popover), -1);
popover_destroy (data);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]