summaryrefslogtreecommitdiff
path: root/modules/other/gail/gailpaned.c
diff options
context:
space:
mode:
authorChristian Persch <chpe@src.gnome.org>2007-12-18 13:51:12 +0000
committerChristian Persch <chpe@src.gnome.org>2007-12-18 13:51:12 +0000
commita8e6ee33b1ae23caeb1c21218fb2f2a94d945e08 (patch)
tree4b502b15beed1cd3d8cdb49944453b9d33878898 /modules/other/gail/gailpaned.c
parentf8a1be3a0401f42f84b83a85a1fb6ac69e6ffd47 (diff)
downloadgtk+-a8e6ee33b1ae23caeb1c21218fb2f2a94d945e08.tar.gz
Integrate gail into gtk+. Bug #169488.
* configure.in: * docs/reference/Makefile.am: * docs/reference/libgail-util/*: * gail-uninstalled.pc.in: * gail.pc.in: * modules/Makefile.am: * modules/other/Makefile.am: * modules/other/gail/*: * modules/other/gail/libgail-util/*: * po/POTFILES.skip: Integrate gail into gtk+. Bug #169488. svn path=/trunk/; revision=19196
Diffstat (limited to 'modules/other/gail/gailpaned.c')
-rw-r--r--modules/other/gail/gailpaned.c247
1 files changed, 247 insertions, 0 deletions
diff --git a/modules/other/gail/gailpaned.c b/modules/other/gail/gailpaned.c
new file mode 100644
index 0000000000..a3ac815a49
--- /dev/null
+++ b/modules/other/gail/gailpaned.c
@@ -0,0 +1,247 @@
+/* GAIL - The GNOME Accessibility Enabling Library
+ * 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, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#include <string.h>
+#include <gtk/gtk.h>
+#include "gailpaned.h"
+
+static void gail_paned_class_init (GailPanedClass *klass);
+
+static void gail_paned_real_initialize (AtkObject *obj,
+ gpointer data);
+static void gail_paned_size_allocate_gtk (GtkWidget *widget,
+ GtkAllocation *allocation);
+
+static AtkStateSet* gail_paned_ref_state_set (AtkObject *accessible);
+
+static void atk_value_interface_init (AtkValueIface *iface);
+static void gail_paned_get_current_value (AtkValue *obj,
+ GValue *value);
+static void gail_paned_get_maximum_value (AtkValue *obj,
+ GValue *value);
+static void gail_paned_get_minimum_value (AtkValue *obj,
+ GValue *value);
+static gboolean gail_paned_set_current_value (AtkValue *obj,
+ const GValue *value);
+
+static GailContainerClass *parent_class = NULL;
+
+GType
+gail_paned_get_type (void)
+{
+ static GType type = 0;
+
+ if (!type)
+ {
+ static const GTypeInfo tinfo =
+ {
+ sizeof (GailPanedClass),
+ (GBaseInitFunc) NULL, /* base init */
+ (GBaseFinalizeFunc) NULL, /* base finalize */
+ (GClassInitFunc) gail_paned_class_init, /* class init */
+ (GClassFinalizeFunc) NULL, /* class finalize */
+ NULL, /* class data */
+ sizeof (GailPaned), /* instance size */
+ 0, /* nb preallocs */
+ (GInstanceInitFunc) NULL, /* instance init */
+ NULL /* value table */
+ };
+
+ static const GInterfaceInfo atk_value_info =
+ {
+ (GInterfaceInitFunc) atk_value_interface_init,
+ (GInterfaceFinalizeFunc) NULL,
+ NULL
+ };
+
+ type = g_type_register_static (GAIL_TYPE_CONTAINER,
+ "GailPaned", &tinfo, 0);
+
+ g_type_add_interface_static (type, ATK_TYPE_VALUE,
+ &atk_value_info);
+ }
+ return type;
+}
+
+static void
+gail_paned_class_init (GailPanedClass *klass)
+{
+ AtkObjectClass *class = ATK_OBJECT_CLASS (klass);
+
+ parent_class = g_type_class_peek_parent (klass);
+
+ class->ref_state_set = gail_paned_ref_state_set;
+ class->initialize = gail_paned_real_initialize;
+}
+
+AtkObject*
+gail_paned_new (GtkWidget *widget)
+{
+ GObject *object;
+ AtkObject *accessible;
+
+ g_return_val_if_fail (GTK_IS_PANED (widget), NULL);
+
+ object = g_object_new (GAIL_TYPE_PANED, NULL);
+
+ accessible = ATK_OBJECT (object);
+ atk_object_initialize (accessible, widget);
+
+ return accessible;
+}
+
+static AtkStateSet*
+gail_paned_ref_state_set (AtkObject *accessible)
+{
+ AtkStateSet *state_set;
+ GtkWidget *widget;
+
+ state_set = ATK_OBJECT_CLASS (parent_class)->ref_state_set (accessible);
+ widget = GTK_ACCESSIBLE (accessible)->widget;
+
+ if (widget == NULL)
+ return state_set;
+
+ if (GTK_IS_VPANED (widget))
+ atk_state_set_add_state (state_set, ATK_STATE_VERTICAL);
+ else if (GTK_IS_HPANED (widget))
+ atk_state_set_add_state (state_set, ATK_STATE_HORIZONTAL);
+
+ return state_set;
+}
+
+static void
+gail_paned_real_initialize (AtkObject *obj,
+ gpointer data)
+{
+ ATK_OBJECT_CLASS (parent_class)->initialize (obj, data);
+
+ g_signal_connect (data,
+ "size_allocate",
+ G_CALLBACK (gail_paned_size_allocate_gtk),
+ NULL);
+
+ obj->role = ATK_ROLE_SPLIT_PANE;
+}
+
+static void
+gail_paned_size_allocate_gtk (GtkWidget *widget,
+ GtkAllocation *allocation)
+{
+ AtkObject *obj = gtk_widget_get_accessible (widget);
+
+ g_object_notify (G_OBJECT (obj), "accessible-value");
+}
+
+
+static void
+atk_value_interface_init (AtkValueIface *iface)
+{
+ g_return_if_fail (iface != NULL);
+
+ iface->get_current_value = gail_paned_get_current_value;
+ iface->get_maximum_value = gail_paned_get_maximum_value;
+ iface->get_minimum_value = gail_paned_get_minimum_value;
+ iface->set_current_value = gail_paned_set_current_value;
+
+}
+
+static void
+gail_paned_get_current_value (AtkValue *obj,
+ GValue *value)
+{
+ GtkWidget* widget;
+ gint current_value;
+
+ widget = GTK_ACCESSIBLE (obj)->widget;
+ if (widget == NULL)
+ /* State is defunct */
+ return;
+
+ current_value = gtk_paned_get_position (GTK_PANED (widget));
+ memset (value, 0, sizeof (GValue));
+ g_value_init (value, G_TYPE_INT);
+ g_value_set_int (value,current_value);
+}
+
+static void
+gail_paned_get_maximum_value (AtkValue *obj,
+ GValue *value)
+{
+ GtkWidget* widget;
+ gint maximum_value;
+
+ widget = GTK_ACCESSIBLE (obj)->widget;
+ if (widget == NULL)
+ /* State is defunct */
+ return;
+
+ maximum_value = GTK_PANED (widget)->max_position;
+ memset (value, 0, sizeof (GValue));
+ g_value_init (value, G_TYPE_INT);
+ g_value_set_int (value, maximum_value);
+}
+
+static void
+gail_paned_get_minimum_value (AtkValue *obj,
+ GValue *value)
+{
+ GtkWidget* widget;
+ gint minimum_value;
+
+ widget = GTK_ACCESSIBLE (obj)->widget;
+ if (widget == NULL)
+ /* State is defunct */
+ return;
+
+ minimum_value = GTK_PANED (widget)->min_position;
+ memset (value, 0, sizeof (GValue));
+ g_value_init (value, G_TYPE_INT);
+ g_value_set_int (value, minimum_value);
+}
+
+/*
+ * Calling atk_value_set_current_value() is no guarantee that the value is
+ * acceptable; it is necessary to listen for accessible-value signals
+ * and check whether the current value has been changed or check what the
+ * maximum and minimum values are.
+ */
+
+static gboolean
+gail_paned_set_current_value (AtkValue *obj,
+ const GValue *value)
+{
+ GtkWidget* widget;
+ gint new_value;
+
+ widget = GTK_ACCESSIBLE (obj)->widget;
+ if (widget == NULL)
+ /* State is defunct */
+ return FALSE;
+
+ if (G_VALUE_HOLDS_INT (value))
+ {
+ new_value = g_value_get_int (value);
+ gtk_paned_set_position (GTK_PANED (widget), new_value);
+
+ return TRUE;
+ }
+ else
+ return FALSE;
+}