summaryrefslogtreecommitdiff
path: root/gtk/a11y/gtkswitchaccessible.c
diff options
context:
space:
mode:
authorBenjamin Otte <otte@redhat.com>2011-07-05 14:39:12 +0200
committerBenjamin Otte <otte@redhat.com>2011-07-06 16:40:04 +0200
commit659d24c9ab03738f6c701e92456bd2fdae76e835 (patch)
treecd47c73eeecd11afc214e6f39ff7d6438738299a /gtk/a11y/gtkswitchaccessible.c
parent8efc350127b83b7bc55d67dc6744bef654765c3a (diff)
downloadgtk+-659d24c9ab03738f6c701e92456bd2fdae76e835.tar.gz
a11y: Remove idle handler for switch action handling
Diffstat (limited to 'gtk/a11y/gtkswitchaccessible.c')
-rw-r--r--gtk/a11y/gtkswitchaccessible.c44
1 files changed, 3 insertions, 41 deletions
diff --git a/gtk/a11y/gtkswitchaccessible.c b/gtk/a11y/gtkswitchaccessible.c
index 71e9e913df..2ca045185b 100644
--- a/gtk/a11y/gtkswitchaccessible.c
+++ b/gtk/a11y/gtkswitchaccessible.c
@@ -56,17 +56,6 @@ gtk_switch_accessible_ref_state_set (AtkObject *accessible)
}
static void
-gtk_switch_accessible_finalize (GObject *obj)
-{
- GtkSwitchAccessible *accessible = (GtkSwitchAccessible *)obj;
-
- if (accessible->action_idle)
- g_source_remove (accessible->action_idle);
-
- G_OBJECT_CLASS (gtk_switch_accessible_parent_class)->finalize (obj);
-}
-
-static void
gtk_switch_accessible_initialize (AtkObject *accessible,
gpointer widget)
{
@@ -80,11 +69,8 @@ gtk_switch_accessible_initialize (AtkObject *accessible,
static void
gtk_switch_accessible_class_init (GtkSwitchAccessibleClass *klass)
{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
AtkObjectClass *atk_class = ATK_OBJECT_CLASS (klass);
- object_class->finalize = gtk_switch_accessible_finalize;
-
atk_class->initialize = gtk_switch_accessible_initialize;
atk_class->ref_state_set = gtk_switch_accessible_ref_state_set;
}
@@ -92,7 +78,6 @@ gtk_switch_accessible_class_init (GtkSwitchAccessibleClass *klass)
static void
gtk_switch_accessible_init (GtkSwitchAccessible *self)
{
- self->action_idle = 0;
}
static gint
@@ -112,31 +97,10 @@ gtk_switch_action_get_name (AtkAction *action,
}
static gboolean
-idle_do_action (gpointer data)
-{
- GtkSwitchAccessible *accessible = data;
- GtkWidget *widget;
- GtkSwitch *sw;
-
- widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (data));
- sw = GTK_SWITCH (widget);
-
- accessible->action_idle = 0;
-
- if (widget == NULL ||
- !gtk_widget_is_sensitive (widget) || !gtk_widget_get_visible (widget))
- return FALSE;
-
- gtk_switch_set_active (sw, !gtk_switch_get_active (sw));
-
- return FALSE;
-}
-
-static gboolean
gtk_switch_action_do_action (AtkAction *action,
gint i)
{
- GtkSwitchAccessible *accessible;
+ GtkSwitch *sw;
GtkWidget *widget;
widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (action));
@@ -149,10 +113,8 @@ gtk_switch_action_do_action (AtkAction *action,
if (!gtk_widget_is_sensitive (widget) || !gtk_widget_get_visible (widget))
return FALSE;
- accessible = (GtkSwitchAccessible *)action;
-
- if (!accessible->action_idle)
- accessible->action_idle = gdk_threads_add_idle (idle_do_action, accessible);
+ sw = GTK_SWITCH (widget);
+ gtk_switch_set_active (sw, !gtk_switch_get_active (sw));
return TRUE;
}