diff options
Diffstat (limited to 'gtk/a11y/gtkrangeaccessible.c')
-rw-r--r-- | gtk/a11y/gtkrangeaccessible.c | 305 |
1 files changed, 0 insertions, 305 deletions
diff --git a/gtk/a11y/gtkrangeaccessible.c b/gtk/a11y/gtkrangeaccessible.c deleted file mode 100644 index a004979143..0000000000 --- a/gtk/a11y/gtkrangeaccessible.c +++ /dev/null @@ -1,305 +0,0 @@ -/* GTK+ - accessibility implementations - * Copyright 2001, 2002, 2003 Sun Microsystems Inc. - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library. If not, see <http://www.gnu.org/licenses/>. - */ - -#include "config.h" - -#include <string.h> -#include <gtk/gtk.h> -#include "gtkrangeaccessible.h" - -typedef struct -{ - GtkAdjustment *adjustment; - - gulong value_changed_id; -} GtkRangeAccessiblePrivate; - -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 -gtk_range_accessible_value_changed (GtkAdjustment *adjustment, - gpointer data) -{ - g_object_notify (G_OBJECT (data), "accessible-value"); -} - -static void -gtk_range_accessible_widget_set (GtkAccessible *accessible) -{ - GtkRangeAccessible *self = GTK_RANGE_ACCESSIBLE (accessible); - GtkRangeAccessiblePrivate *priv = gtk_range_accessible_get_instance_private (self); - GtkWidget *range; - GtkAdjustment *adj; - - range = gtk_accessible_get_widget (accessible); - adj = gtk_range_get_adjustment (GTK_RANGE (range)); - if (adj != NULL) - { - priv->adjustment = g_object_ref (adj); - priv->value_changed_id = - g_signal_connect (priv->adjustment, "value-changed", - G_CALLBACK (gtk_range_accessible_value_changed), - self); - } -} - -static void -gtk_range_accessible_widget_unset (GtkAccessible *accessible) -{ - GtkRangeAccessible *self = GTK_RANGE_ACCESSIBLE (accessible); - GtkRangeAccessiblePrivate *priv = gtk_range_accessible_get_instance_private (self); - - if (priv->adjustment != NULL && - priv->value_changed_id != 0) - { - g_signal_handler_disconnect (priv->adjustment, priv->value_changed_id); - priv->value_changed_id = 0; - } - - g_clear_object (&priv->adjustment); -} - -void -gtk_range_accessible_update_adjustment (GtkRangeAccessible *self) -{ - gtk_range_accessible_widget_unset (GTK_ACCESSIBLE (self)); - gtk_range_accessible_widget_set (GTK_ACCESSIBLE (self)); -} - -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 -gtk_range_accessible_dispose (GObject *gobject) -{ - GtkRangeAccessible *self = GTK_RANGE_ACCESSIBLE (gobject); - GtkRangeAccessiblePrivate *priv = gtk_range_accessible_get_instance_private (self); - - if (priv->adjustment != NULL && priv->value_changed_id != 0) - { - g_signal_handler_disconnect (priv->adjustment, priv->value_changed_id); - priv->value_changed_id = 0; - } - - g_clear_object (&priv->adjustment); - - G_OBJECT_CLASS (gtk_range_accessible_parent_class)->dispose (gobject); -} - -static void -gtk_range_accessible_class_init (GtkRangeAccessibleClass *klass) -{ - GObjectClass *gobject_class = G_OBJECT_CLASS (klass); - AtkObjectClass *atkobject_class = ATK_OBJECT_CLASS (klass); - GtkAccessibleClass *accessible_class = (GtkAccessibleClass*)klass; - - gobject_class->dispose = gtk_range_accessible_dispose; - - atkobject_class->initialize = gtk_range_accessible_initialize; - - accessible_class->widget_set = gtk_range_accessible_widget_set; - accessible_class->widget_unset = gtk_range_accessible_widget_unset; -} - -static void -gtk_range_accessible_init (GtkRangeAccessible *range) -{ -} - -static void -gtk_range_accessible_get_current_value (AtkValue *obj, - GValue *value) -{ - GtkWidget *widget; - GtkAdjustment *adjustment; - - widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (obj)); - adjustment = gtk_range_get_adjustment (GTK_RANGE (widget)); - if (adjustment == NULL) - return; - - memset (value, 0, sizeof (GValue)); - g_value_init (value, G_TYPE_DOUBLE); - g_value_set_double (value, gtk_adjustment_get_value (adjustment)); -} - -static void -gtk_range_accessible_get_maximum_value (AtkValue *obj, - GValue *value) -{ - GtkWidget *widget; - GtkAdjustment *adjustment; - double max; - - widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (obj)); - adjustment = gtk_range_get_adjustment (GTK_RANGE (widget)); - if (adjustment == NULL) - return; - - max = gtk_adjustment_get_upper (adjustment) - - gtk_adjustment_get_page_size (adjustment); - - if (gtk_range_get_restrict_to_fill_level (GTK_RANGE (widget))) - max = MIN (max, gtk_range_get_fill_level (GTK_RANGE (widget))); - - memset (value, 0, sizeof (GValue)); - g_value_init (value, G_TYPE_DOUBLE); - g_value_set_double (value, max); -} - -static void -gtk_range_accessible_get_minimum_value (AtkValue *obj, - GValue *value) -{ - GtkWidget *widget; - GtkAdjustment *adjustment; - - widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (obj)); - adjustment = gtk_range_get_adjustment (GTK_RANGE (widget)); - if (adjustment == NULL) - return; - - memset (value, 0, sizeof (GValue)); - g_value_init (value, G_TYPE_DOUBLE); - g_value_set_double (value, gtk_adjustment_get_lower (adjustment)); -} - -static void -gtk_range_accessible_get_minimum_increment (AtkValue *obj, - GValue *value) -{ - GtkWidget *widget; - GtkAdjustment *adjustment; - - widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (obj)); - adjustment = gtk_range_get_adjustment (GTK_RANGE (widget)); - if (adjustment == NULL) - return; - - memset (value, 0, sizeof (GValue)); - g_value_init (value, G_TYPE_DOUBLE); - g_value_set_double (value, gtk_adjustment_get_minimum_increment (adjustment)); -} - -static gboolean -gtk_range_accessible_set_current_value (AtkValue *obj, - const GValue *value) -{ - GtkWidget *widget; - GtkAdjustment *adjustment; - - widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (obj)); - adjustment = gtk_range_get_adjustment (GTK_RANGE (widget)); - if (adjustment == NULL) - return FALSE; - - gtk_adjustment_set_value (adjustment, g_value_get_double (value)); - - return TRUE; -} - -static void -gtk_range_accessible_get_value_and_text (AtkValue *obj, - double *value, - char **text) -{ - GtkWidget *widget; - GtkAdjustment *adjustment; - - widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (obj)); - adjustment = gtk_range_get_adjustment (GTK_RANGE (widget)); - if (adjustment == NULL) - return; - - *value = gtk_adjustment_get_value (adjustment); - *text = NULL; -} - -static AtkRange * -gtk_range_accessible_get_range (AtkValue *obj) -{ - GtkWidget *widget; - GtkAdjustment *adjustment; - double min, max; - - widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (obj)); - adjustment = gtk_range_get_adjustment (GTK_RANGE (widget)); - if (adjustment == NULL) - return NULL; - - min = gtk_adjustment_get_lower (adjustment); - max = gtk_adjustment_get_upper (adjustment) - - gtk_adjustment_get_page_size (adjustment); - - if (gtk_range_get_restrict_to_fill_level (GTK_RANGE (widget))) - max = MIN (max, gtk_range_get_fill_level (GTK_RANGE (widget))); - - return atk_range_new (min, max, NULL); -} - -static void -gtk_range_accessible_set_value (AtkValue *obj, - const double value) -{ - GtkWidget *widget; - GtkAdjustment *adjustment; - - widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (obj)); - adjustment = gtk_range_get_adjustment (GTK_RANGE (widget)); - if (adjustment == NULL) - return; - - gtk_adjustment_set_value (adjustment, value); -} - -static double -gtk_range_accessible_get_increment (AtkValue *obj) -{ - GtkWidget *widget; - GtkAdjustment *adjustment; - - widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (obj)); - adjustment = gtk_range_get_adjustment (GTK_RANGE (widget)); - if (adjustment == NULL) - return 0; - - return gtk_adjustment_get_minimum_increment (adjustment); -} - -static void -atk_value_interface_init (AtkValueIface *iface) -{ - iface->get_current_value = gtk_range_accessible_get_current_value; - iface->get_maximum_value = gtk_range_accessible_get_maximum_value; - iface->get_minimum_value = gtk_range_accessible_get_minimum_value; - iface->get_minimum_increment = gtk_range_accessible_get_minimum_increment; - iface->set_current_value = gtk_range_accessible_set_current_value; - - iface->get_value_and_text = gtk_range_accessible_get_value_and_text; - iface->get_range = gtk_range_accessible_get_range; - iface->set_value = gtk_range_accessible_set_value; - iface->get_increment = gtk_range_accessible_get_increment; -} |