Clean up gailutil.c a bit

This commit is contained in:
Matthias Clasen 2011-07-08 23:05:51 -04:00
parent 4c76d9fe31
commit d7ded58f51

View File

@ -26,22 +26,7 @@
#include "gtktoplevelaccessible.h" #include "gtktoplevelaccessible.h"
#include "gtkwindowaccessible.h" #include "gtkwindowaccessible.h"
static void gail_util_class_init (GailUtilClass *klass);
static void gail_util_init (GailUtil *utils);
/* atkutil.h */
static guint gail_util_add_global_event_listener (GSignalEmissionHook listener,
const gchar* event_type);
static void gail_util_remove_global_event_listener (guint remove_listener);
static guint gail_util_add_key_event_listener (AtkKeySnoopFunc listener,
gpointer data);
static void gail_util_remove_key_event_listener (guint remove_listener);
static AtkObject* gail_util_get_root (void);
static const gchar *gail_util_get_toolkit_name (void);
static const gchar *gail_util_get_toolkit_version (void);
static void _listener_info_destroy (gpointer data);
static guint add_listener (GSignalEmissionHook listener, static guint add_listener (GSignalEmissionHook listener,
const gchar *object_type, const gchar *object_type,
const gchar *signal, const gchar *signal,
@ -89,28 +74,6 @@ struct _GailKeyEventInfo
G_DEFINE_TYPE (GailUtil, gail_util, ATK_TYPE_UTIL) G_DEFINE_TYPE (GailUtil, gail_util, ATK_TYPE_UTIL)
static void
gail_util_class_init (GailUtilClass *klass)
{
AtkUtilClass *atk_class = ATK_UTIL_CLASS (klass);
atk_class->add_global_event_listener = gail_util_add_global_event_listener;
atk_class->remove_global_event_listener = gail_util_remove_global_event_listener;
atk_class->add_key_event_listener = gail_util_add_key_event_listener;
atk_class->remove_key_event_listener = gail_util_remove_key_event_listener;
atk_class->get_root = gail_util_get_root;
atk_class->get_toolkit_name = gail_util_get_toolkit_name;
atk_class->get_toolkit_version = gail_util_get_toolkit_version;
listener_list = g_hash_table_new_full (g_int_hash, g_int_equal,
NULL, _listener_info_destroy);
}
static void
gail_util_init (GailUtil *utils)
{
}
static guint static guint
gail_util_add_global_event_listener (GSignalEmissionHook listener, gail_util_add_global_event_listener (GSignalEmissionHook listener,
const gchar *event_type) const gchar *event_type)
@ -185,9 +148,7 @@ gail_util_remove_global_event_listener (guint remove_listener)
} }
} }
static AtkKeyEventStruct *
static
AtkKeyEventStruct *
atk_key_event_from_gdk_event_key (GdkEventKey *key) atk_key_event_from_gdk_event_key (GdkEventKey *key)
{ {
AtkKeyEventStruct *event = g_new0 (AtkKeyEventStruct, 1); AtkKeyEventStruct *event = g_new0 (AtkKeyEventStruct, 1);
@ -236,7 +197,9 @@ typedef struct {
} KeyEventListener; } KeyEventListener;
static gint static gint
gail_key_snooper (GtkWidget *the_widget, GdkEventKey *event, gpointer data) gail_key_snooper (GtkWidget *the_widget,
GdkEventKey *event,
gpointer data)
{ {
GSList *l; GSList *l;
AtkKeyEventStruct *atk_event; AtkKeyEventStruct *atk_event;
@ -325,19 +288,9 @@ gail_util_get_toolkit_name (void)
static const gchar * static const gchar *
gail_util_get_toolkit_version (void) gail_util_get_toolkit_version (void)
{ {
/*
* Version is passed in as a -D flag when this file is
* compiled.
*/
return GTK_VERSION; return GTK_VERSION;
} }
static void
_listener_info_destroy (gpointer data)
{
g_free(data);
}
static guint static guint
add_listener (GSignalEmissionHook listener, add_listener (GSignalEmissionHook listener,
const gchar *object_type, const gchar *object_type,
@ -358,7 +311,7 @@ add_listener (GSignalEmissionHook listener,
rc = listener_idx; rc = listener_idx;
listener_info = g_malloc(sizeof(GailUtilListenerInfo)); listener_info = g_new (GailUtilListenerInfo, 1);
listener_info->key = listener_idx; listener_info->key = listener_idx;
listener_info->hook_id = listener_info->hook_id =
g_signal_add_emission_hook (signal_id, 0, listener, g_signal_add_emission_hook (signal_id, 0, listener,
@ -386,9 +339,6 @@ do_window_event_initialization (void)
{ {
AtkObject *root; AtkObject *root;
/*
* Ensure that GtkWindowAccessibleClass exists.
*/
g_type_class_ref (GTK_TYPE_WINDOW_ACCESSIBLE); g_type_class_ref (GTK_TYPE_WINDOW_ACCESSIBLE);
g_signal_add_emission_hook (g_signal_lookup ("window-state-event", GTK_TYPE_WIDGET), g_signal_add_emission_hook (g_signal_lookup ("window-state-event", GTK_TYPE_WIDGET),
0, state_event_watcher, NULL, (GDestroyNotify) NULL); 0, state_event_watcher, NULL, (GDestroyNotify) NULL);
@ -414,12 +364,8 @@ state_event_watcher (GSignalInvocationHint *hint,
AtkObject *parent; AtkObject *parent;
GdkEventWindowState *event; GdkEventWindowState *event;
gchar *signal_name; gchar *signal_name;
guint signal_id;
object = g_value_get_object (param_values + 0); object = g_value_get_object (param_values + 0);
/*
* The object can be a GtkMenu when it is popped up; we ignore this
*/
if (!GTK_IS_WINDOW (object)) if (!GTK_IS_WINDOW (object))
return FALSE; return FALSE;
@ -429,38 +375,26 @@ state_event_watcher (GSignalInvocationHint *hint,
widget = GTK_WIDGET (object); widget = GTK_WIDGET (object);
if (event->new_window_state & GDK_WINDOW_STATE_MAXIMIZED) if (event->new_window_state & GDK_WINDOW_STATE_MAXIMIZED)
{
signal_name = "maximize"; signal_name = "maximize";
}
else if (event->new_window_state & GDK_WINDOW_STATE_ICONIFIED) else if (event->new_window_state & GDK_WINDOW_STATE_ICONIFIED)
{
signal_name = "minimize"; signal_name = "minimize";
}
else if (event->new_window_state == 0) else if (event->new_window_state == 0)
{
signal_name = "restore"; signal_name = "restore";
}
else else
return TRUE; return TRUE;
atk_obj = gtk_widget_get_accessible (widget); atk_obj = gtk_widget_get_accessible (widget);
if (GTK_IS_WINDOW_ACCESSIBLE (atk_obj)) if (GTK_IS_WINDOW_ACCESSIBLE (atk_obj))
{ {
parent = atk_object_get_parent (atk_obj); parent = atk_object_get_parent (atk_obj);
if (parent == atk_get_root ()) if (parent == atk_get_root ())
{ g_signal_emit_by_name (atk_obj, signal_name);
signal_id = g_signal_lookup (signal_name, GTK_TYPE_WINDOW_ACCESSIBLE);
g_signal_emit (atk_obj, signal_id, 0);
}
return TRUE; return TRUE;
} }
else
{
return FALSE; return FALSE;
} }
}
static void static void
window_added (AtkObject *atk_obj, window_added (AtkObject *atk_obj,
@ -469,7 +403,8 @@ window_added (AtkObject *atk_obj,
{ {
GtkWidget *widget; GtkWidget *widget;
if (!GTK_IS_WINDOW_ACCESSIBLE (child)) return; if (!GTK_IS_WINDOW_ACCESSIBLE (child))
return;
widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (child)); widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (child));
if (!widget) if (!widget)
@ -477,7 +412,7 @@ window_added (AtkObject *atk_obj,
g_signal_connect (widget, "focus-in-event", (GCallback) window_focus, NULL); g_signal_connect (widget, "focus-in-event", (GCallback) window_focus, NULL);
g_signal_connect (widget, "focus-out-event", (GCallback) window_focus, NULL); g_signal_connect (widget, "focus-out-event", (GCallback) window_focus, NULL);
g_signal_emit (child, g_signal_lookup ("create", GTK_TYPE_WINDOW_ACCESSIBLE), 0); g_signal_emit_by_name (child, "create");
} }
@ -489,7 +424,8 @@ window_removed (AtkObject *atk_obj,
GtkWidget *widget; GtkWidget *widget;
GtkWindow *window; GtkWindow *window;
if (!GTK_IS_WINDOW_ACCESSIBLE (child)) return; if (!GTK_IS_WINDOW_ACCESSIBLE (child))
return;
widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (child)); widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (child));
if (!widget) if (!widget)
@ -503,30 +439,26 @@ window_removed (AtkObject *atk_obj,
if (gtk_window_is_active (window) && if (gtk_window_is_active (window) &&
gtk_window_has_toplevel_focus (window)) gtk_window_has_toplevel_focus (window))
{ {
gchar *signal_name;
AtkObject *atk_obj; AtkObject *atk_obj;
atk_obj = gtk_widget_get_accessible (widget); atk_obj = gtk_widget_get_accessible (widget);
signal_name = "deactivate"; g_signal_emit_by_name (atk_obj, "deactivate");
g_signal_emit (atk_obj, g_signal_lookup (signal_name, GTK_TYPE_WINDOW_ACCESSIBLE), 0);
} }
g_signal_handlers_disconnect_by_func (widget, (gpointer) window_focus, NULL); g_signal_handlers_disconnect_by_func (widget, (gpointer) window_focus, NULL);
g_signal_emit (child, g_signal_lookup ("destroy", GTK_TYPE_WINDOW_ACCESSIBLE), 0); g_signal_emit_by_name (child, "destroy");
} }
static gboolean static gboolean
window_focus (GtkWidget *widget, window_focus (GtkWidget *widget,
GdkEventFocus *event) GdkEventFocus *event)
{ {
gchar *signal_name;
AtkObject *atk_obj; AtkObject *atk_obj;
g_return_val_if_fail (GTK_IS_WIDGET (widget), FALSE); g_return_val_if_fail (GTK_IS_WIDGET (widget), FALSE);
atk_obj = gtk_widget_get_accessible (widget); atk_obj = gtk_widget_get_accessible (widget);
signal_name = (event->in) ? "activate" : "deactivate"; g_signal_emit_by_name (atk_obj, event->in ? "activate" : "deactivate");
g_signal_emit (atk_obj, g_signal_lookup (signal_name, GTK_TYPE_WINDOW_ACCESSIBLE), 0);
return FALSE; return FALSE;
} }
@ -544,13 +476,9 @@ configure_event_watcher (GSignalInvocationHint *hint,
AtkObject *parent; AtkObject *parent;
GdkEvent *event; GdkEvent *event;
gchar *signal_name; gchar *signal_name;
guint signal_id;
object = g_value_get_object (param_values + 0); object = g_value_get_object (param_values + 0);
if (!GTK_IS_WINDOW (object)) if (!GTK_IS_WINDOW (object))
/*
* GtkDrawingArea can send a GDK_CONFIGURE event but we ignore here
*/
return FALSE; return FALSE;
event = g_value_get_boxed (param_values + 1); event = g_value_get_boxed (param_values + 1);
@ -566,28 +494,40 @@ configure_event_watcher (GSignalInvocationHint *hint,
if (allocation.width != ((GdkEventConfigure *)event)->width || if (allocation.width != ((GdkEventConfigure *)event)->width ||
allocation.height != ((GdkEventConfigure *)event)->height) allocation.height != ((GdkEventConfigure *)event)->height)
{
signal_name = "resize"; signal_name = "resize";
}
else else
{
signal_name = "move"; signal_name = "move";
}
atk_obj = gtk_widget_get_accessible (widget); atk_obj = gtk_widget_get_accessible (widget);
if (GTK_IS_WINDOW_ACCESSIBLE (atk_obj)) if (GTK_IS_WINDOW_ACCESSIBLE (atk_obj))
{ {
parent = atk_object_get_parent (atk_obj); parent = atk_object_get_parent (atk_obj);
if (parent == atk_get_root ()) if (parent == atk_get_root ())
{ g_signal_emit_by_name (atk_obj, signal_name);
signal_id = g_signal_lookup (signal_name, GTK_TYPE_WINDOW_ACCESSIBLE);
g_signal_emit (atk_obj, signal_id, 0);
}
return TRUE; return TRUE;
} }
else
{
return FALSE; return FALSE;
} }
static void
gail_util_class_init (GailUtilClass *klass)
{
AtkUtilClass *atk_class = ATK_UTIL_CLASS (klass);
atk_class->add_global_event_listener = gail_util_add_global_event_listener;
atk_class->remove_global_event_listener = gail_util_remove_global_event_listener;
atk_class->add_key_event_listener = gail_util_add_key_event_listener;
atk_class->remove_key_event_listener = gail_util_remove_key_event_listener;
atk_class->get_root = gail_util_get_root;
atk_class->get_toolkit_name = gail_util_get_toolkit_name;
atk_class->get_toolkit_version = gail_util_get_toolkit_version;
listener_list = g_hash_table_new_full (g_int_hash, g_int_equal, NULL, g_free);
}
static void
gail_util_init (GailUtil *utils)
{
} }