[gtk+] window: Emit a11y signals directly on popover added/removed



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]