summaryrefslogtreecommitdiff
path: root/gtk/a11y/gtkrangeaccessible.c
diff options
context:
space:
mode:
Diffstat (limited to 'gtk/a11y/gtkrangeaccessible.c')
-rw-r--r--gtk/a11y/gtkrangeaccessible.c305
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;
-}