summaryrefslogtreecommitdiff
path: root/gtk/a11y
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2013-08-13 23:54:53 -0400
committerMatthias Clasen <mclasen@redhat.com>2013-08-14 00:04:05 -0400
commitb9a6e012d546fe10c977b89cbb3a0a33cff29e82 (patch)
tree83407825f48a5a35429c78a1c2f8508906e9cdd2 /gtk/a11y
parent38e51b27c2b95782a5f6500d357e5120db4c76c2 (diff)
downloadgtk+-b9a6e012d546fe10c977b89cbb3a0a33cff29e82.tar.gz
GtkRange: disconnect signals in the accessible
We were only disconnecting the signal in finalize, when the widget was already unset. Instead, override the widget_set and widget_unset vfuncs of GtkAccessible, and keep a reference to the adjustment. https://bugzilla.gnome.org/show_bug.cgi?id=705692
Diffstat (limited to 'gtk/a11y')
-rw-r--r--gtk/a11y/gtkrangeaccessible.c78
1 files changed, 40 insertions, 38 deletions
diff --git a/gtk/a11y/gtkrangeaccessible.c b/gtk/a11y/gtkrangeaccessible.c
index b3ccacb921..1af428aa99 100644
--- a/gtk/a11y/gtkrangeaccessible.c
+++ b/gtk/a11y/gtkrangeaccessible.c
@@ -21,10 +21,15 @@
#include <gtk/gtk.h>
#include "gtkrangeaccessible.h"
+struct _GtkRangeAccessiblePrivate
+{
+ GtkAdjustment *adjustment;
+};
static void atk_value_interface_init (AtkValueIface *iface);
G_DEFINE_TYPE_WITH_CODE (GtkRangeAccessible, gtk_range_accessible, GTK_TYPE_WIDGET_ACCESSIBLE,
+ G_ADD_PRIVATE (GtkRangeAccessible)
G_IMPLEMENT_INTERFACE (ATK_TYPE_VALUE, atk_value_interface_init))
static void
@@ -35,47 +40,45 @@ gtk_range_accessible_value_changed (GtkAdjustment *adjustment,
}
static void
-gtk_range_accessible_initialize (AtkObject *obj,
- gpointer data)
+gtk_range_accessible_widget_set (GtkAccessible *accessible)
{
- GtkRangeAccessible *range = GTK_RANGE_ACCESSIBLE (obj);
+ GtkRangeAccessiblePrivate *priv = GTK_RANGE_ACCESSIBLE (accessible)->priv;
+ GtkWidget *range;
GtkAdjustment *adj;
- GtkRange *gtk_range;
- ATK_OBJECT_CLASS (gtk_range_accessible_parent_class)->initialize (obj, data);
-
- gtk_range = GTK_RANGE (data);
- /*
- * If a GtkAdjustment already exists for the GtkRange,
- * create the GailAdjustment
- */
- adj = gtk_range_get_adjustment (gtk_range);
+ range = gtk_accessible_get_widget (accessible);
+ adj = gtk_range_get_adjustment (GTK_RANGE (range));
if (adj)
- g_signal_connect (adj, "value-changed",
- G_CALLBACK (gtk_range_accessible_value_changed),
- range);
-
- obj->role = ATK_ROLE_SLIDER;
+ {
+ priv->adjustment = adj;
+ g_object_ref (priv->adjustment);
+ g_signal_connect (priv->adjustment, "value-changed",
+ G_CALLBACK (gtk_range_accessible_value_changed),
+ accessible);
+ }
}
static void
-gtk_range_accessible_finalize (GObject *object)
+gtk_range_accessible_widget_unset (GtkAccessible *accessible)
{
- GtkRangeAccessible *range = GTK_RANGE_ACCESSIBLE (object);
- GtkWidget *widget;
- GtkAdjustment *adj;
+ GtkRangeAccessiblePrivate *priv = GTK_RANGE_ACCESSIBLE (accessible)->priv;
- widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (object));
- if (widget)
+ if (priv->adjustment)
{
- adj = gtk_range_get_adjustment (GTK_RANGE (widget));
- if (adj)
- g_signal_handlers_disconnect_by_func (adj,
- gtk_range_accessible_value_changed,
- range);
+ g_signal_handlers_disconnect_by_func (priv->adjustment,
+ G_CALLBACK (gtk_range_accessible_value_changed),
+ accessible);
+ g_object_unref (priv->adjustment);
+ priv->adjustment = NULL;
}
+}
- G_OBJECT_CLASS (gtk_range_accessible_parent_class)->finalize (object);
+static void
+gtk_range_accessible_initialize (AtkObject *obj,
+ gpointer data)
+{
+ ATK_OBJECT_CLASS (gtk_range_accessible_parent_class)->initialize (obj, data);
+ obj->role = ATK_ROLE_SLIDER;
}
static void
@@ -83,16 +86,13 @@ gtk_range_accessible_notify_gtk (GObject *obj,
GParamSpec *pspec)
{
GtkWidget *widget = GTK_WIDGET (obj);
- GtkAdjustment *adj;
AtkObject *range;
if (strcmp (pspec->name, "adjustment") == 0)
{
range = gtk_widget_get_accessible (widget);
- adj = gtk_range_get_adjustment (GTK_RANGE (widget));
- g_signal_connect (adj, "value-changed",
- G_CALLBACK (gtk_range_accessible_value_changed),
- range);
+ gtk_range_accessible_widget_unset (GTK_ACCESSIBLE (range));
+ gtk_range_accessible_widget_set (GTK_ACCESSIBLE (range));
}
else
GTK_WIDGET_ACCESSIBLE_CLASS (gtk_range_accessible_parent_class)->notify_gtk (obj, pspec);
@@ -102,20 +102,22 @@ gtk_range_accessible_notify_gtk (GObject *obj,
static void
gtk_range_accessible_class_init (GtkRangeAccessibleClass *klass)
{
- GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
AtkObjectClass *class = ATK_OBJECT_CLASS (klass);
+ GtkAccessibleClass *accessible_class = (GtkAccessibleClass*)klass;
GtkWidgetAccessibleClass *widget_class = (GtkWidgetAccessibleClass*)klass;
- widget_class->notify_gtk = gtk_range_accessible_notify_gtk;
-
class->initialize = gtk_range_accessible_initialize;
- gobject_class->finalize = gtk_range_accessible_finalize;
+ accessible_class->widget_set = gtk_range_accessible_widget_set;
+ accessible_class->widget_unset = gtk_range_accessible_widget_unset;
+
+ widget_class->notify_gtk = gtk_range_accessible_notify_gtk;
}
static void
gtk_range_accessible_init (GtkRangeAccessible *range)
{
+ range->priv = gtk_range_accessible_get_instance_private (range);
}
static void