Merge branch 'window-activate' into 'master'

a11y: restore window:activate/deactivate emission

Closes #127

See merge request GNOME/gtk!77
This commit is contained in:
Benjamin Otte 2018-04-05 14:36:13 +00:00
commit 8cb0df7554
3 changed files with 22 additions and 3 deletions

View File

@ -28,6 +28,9 @@ void _gtk_accessibility_init (void);
gboolean _gtk_accessibility_key_snooper (GtkWidget *widget,
GdkEventKey *event);
void _gtk_window_accessible_set_is_active (GtkWindow *window,
gboolean is_active);
G_END_DECLS
#endif /* __GTK_ACCESSIBILITY_H__ */

View File

@ -20,9 +20,11 @@
#include <gtk/gtk.h>
#include "gtkaccessibility.h"
#include "gtkwidgetaccessibleprivate.h"
#include "gtkwindowaccessible.h"
#include "gtktoplevelaccessible.h"
#include "gtkwidgetprivate.h"
#include "gtkwindowprivate.h"
/* atkcomponent.h */
@ -442,6 +444,19 @@ gtk_window_accessible_get_size (AtkComponent *component,
*height = rect.height;
}
void
_gtk_window_accessible_set_is_active (GtkWindow *window,
gboolean is_active)
{
AtkObject *accessible = _gtk_widget_peek_accessible (GTK_WIDGET (window));
if (accessible == NULL)
return;
g_signal_emit_by_name (accessible, is_active ? "activate" : "deactivate");
}
static void
atk_component_interface_init (AtkComponentIface *iface)
{

View File

@ -10461,6 +10461,7 @@ _gtk_window_set_is_active (GtkWindow *window,
}
g_object_notify_by_pspec (G_OBJECT (window), window_props[PROP_IS_ACTIVE]);
_gtk_window_accessible_set_is_active (window, is_active);
}
}