[gtk+] Fix build of gail after GtkItem removal
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+] Fix build of gail after GtkItem removal
- Date: Thu, 9 Sep 2010 04:52:06 +0000 (UTC)
commit 91d0728dfaa3fd5d67c4f072601ecba44b5fd473
Author: Matthias Clasen <mclasen redhat com>
Date: Thu Sep 9 00:51:08 2010 -0400
Fix build of gail after GtkItem removal
modules/other/gail/Makefile.am | 2 -
modules/other/gail/gailitem.c | 707 -------------------------------------
modules/other/gail/gailitem.h | 56 ---
modules/other/gail/gailmenuitem.c | 532 +++++++++++++++++++++++++++-
modules/other/gail/gailmenuitem.h | 11 +-
5 files changed, 531 insertions(+), 777 deletions(-)
---
diff --git a/modules/other/gail/Makefile.am b/modules/other/gail/Makefile.am
index 4745347..a734ec2 100644
--- a/modules/other/gail/Makefile.am
+++ b/modules/other/gail/Makefile.am
@@ -30,7 +30,6 @@ gail_c_sources = \
gailframe.c \
gailimage.c \
gailimagecell.c \
- gailitem.c \
gaillabel.c \
gailmenu.c \
gailmenushell.c \
@@ -85,7 +84,6 @@ gail_private_h_sources = \
gailframe.h \
gailimage.h \
gailimagecell.h \
- gailitem.h \
gaillabel.h \
gailmenu.h \
gailmenushell.h \
diff --git a/modules/other/gail/gailmenuitem.c b/modules/other/gail/gailmenuitem.c
index 17008ce..6df6cf5 100644
--- a/modules/other/gail/gailmenuitem.c
+++ b/modules/other/gail/gailmenuitem.c
@@ -17,6 +17,7 @@
* Boston, MA 02111-1307, USA.
*/
+#include <string.h>
#include <gtk/gtk.h>
#include <gdk/gdkkeysyms.h>
#include "gailmenuitem.h"
@@ -35,6 +36,14 @@ static AtkObject* gail_menu_item_ref_child (AtkObject *obj,
gint i);
static AtkStateSet* gail_menu_item_ref_state_set (AtkObject *obj);
static void gail_menu_item_finalize (GObject *object);
+static void gail_menu_item_label_map_gtk (GtkWidget *widget,
+ gpointer data);
+static void gail_menu_item_init_textutil (GailMenuItem *item,
+ GtkWidget *label);
+static void gail_menu_item_notify_label_gtk (GObject *obj,
+ GParamSpec *pspec,
+ gpointer data);
+
static void atk_action_interface_init (AtkActionIface *iface);
static gboolean gail_menu_item_do_action (AtkAction *action,
@@ -50,9 +59,9 @@ static G_CONST_RETURN gchar* gail_menu_item_get_keybinding (AtkAction *acti
static gboolean gail_menu_item_set_description(AtkAction *action,
gint i,
const gchar *desc);
-static void menu_item_select (GtkItem *item);
-static void menu_item_deselect (GtkItem *item);
-static void menu_item_selection (GtkItem *item,
+static void menu_item_select (GtkMenuItem *item);
+static void menu_item_deselect (GtkMenuItem *item);
+static void menu_item_selection (GtkMenuItem *item,
gboolean selected);
static gboolean find_accel (GtkAccelKey *key,
GClosure *closure,
@@ -60,9 +69,52 @@ static gboolean find_accel (GtkAccelKey *key,
static gboolean find_accel_new (GtkAccelKey *key,
GClosure *closure,
gpointer data);
-
-G_DEFINE_TYPE_WITH_CODE (GailMenuItem, gail_menu_item, GAIL_TYPE_ITEM,
- G_IMPLEMENT_INTERFACE (ATK_TYPE_ACTION, atk_action_interface_init))
+/* atktext.h */
+static void atk_text_interface_init (AtkTextIface *iface);
+
+static gchar* gail_menu_item_get_text (AtkText *text,
+ gint start_pos,
+ gint end_pos);
+static gunichar gail_menu_item_get_character_at_offset (AtkText *text,
+ gint offset);
+static gchar* gail_menu_item_get_text_before_offset (AtkText *text,
+ gint offset,
+ AtkTextBoundary boundary_type,
+ gint *start_offset,
+ gint *end_offset);
+static gchar* gail_menu_item_get_text_at_offset (AtkText *text,
+ gint offset,
+ AtkTextBoundary boundary_type,
+ gint *start_offset,
+ gint *end_offset);
+static gchar* gail_menu_item_get_text_after_offset (AtkText *text,
+ gint offset,
+ AtkTextBoundary boundary_type,
+ gint *start_offset,
+ gint *end_offset);
+static gint gail_menu_item_get_character_count (AtkText *text);
+static void gail_menu_item_get_character_extents (AtkText *text,
+ gint offset,
+ gint *x,
+ gint *y,
+ gint *width,
+ gint *height,
+ AtkCoordType coords);
+static gint gail_menu_item_get_offset_at_point (AtkText *text,
+ gint x,
+ gint y,
+ AtkCoordType coords);
+static AtkAttributeSet* gail_menu_item_get_run_attributes (AtkText *text,
+ gint offset,
+ gint *start_offset,
+ gint *end_offset);
+static AtkAttributeSet* gail_menu_item_get_default_attributes (AtkText *text);
+static GtkWidget* get_label_from_container (GtkWidget *container);
+
+
+G_DEFINE_TYPE_WITH_CODE (GailMenuItem, gail_menu_item, GAIL_TYPE_CONTAINER,
+ G_IMPLEMENT_INTERFACE (ATK_TYPE_ACTION, atk_action_interface_init)
+ G_IMPLEMENT_INTERFACE (ATK_TYPE_TEXT, atk_text_interface_init))
static void
gail_menu_item_class_init (GailMenuItemClass *klass)
@@ -84,9 +136,26 @@ gail_menu_item_real_initialize (AtkObject *obj,
{
GtkWidget *widget;
GtkWidget *parent;
+ GailMenuItem *item = GAIL_MENU_ITEM (obj);
+ GtkWidget *label;
ATK_OBJECT_CLASS (gail_menu_item_parent_class)->initialize (obj, data);
+ item->textutil = NULL;
+ item->text = NULL;
+
+ label = get_label_from_container (GTK_WIDGET (data));
+ if (GTK_IS_LABEL (label))
+ {
+ if (gtk_widget_get_mapped (label))
+ gail_menu_item_init_textutil (item, label);
+ else
+ g_signal_connect (label,
+ "map",
+ G_CALLBACK (gail_menu_item_label_map_gtk),
+ item);
+ }
+
g_signal_connect (data,
"select",
G_CALLBACK (menu_item_select),
@@ -128,6 +197,441 @@ gail_menu_item_init (GailMenuItem *menu_item)
menu_item->click_description = NULL;
}
+static void
+gail_menu_item_label_map_gtk (GtkWidget *widget,
+ gpointer data)
+{
+ GailMenuItem *item;
+
+ item = GAIL_MENU_ITEM (data);
+ gail_menu_item_init_textutil (item, widget);
+}
+
+static void
+gail_menu_item_notify_label_gtk (GObject *obj,
+ GParamSpec *pspec,
+ gpointer data)
+{
+ AtkObject* atk_obj = ATK_OBJECT (data);
+ GtkLabel *label;
+ GailMenuItem *menu_item;
+
+ if (strcmp (pspec->name, "label") == 0)
+ {
+ const gchar* label_text;
+
+ label = GTK_LABEL (obj);
+
+ label_text = gtk_label_get_text (label);
+
+ menu_item = GAIL_MENU_ITEM (atk_obj);
+ gail_text_util_text_setup (menu_item->textutil, label_text);
+
+ if (atk_obj->name == NULL)
+ {
+ /*
+ * The label has changed so notify a change in accessible-name
+ */
+ g_object_notify (G_OBJECT (atk_obj), "accessible-name");
+ }
+ /*
+ * The label is the only property which can be changed
+ */
+ g_signal_emit_by_name (atk_obj, "visible_data_changed");
+ }
+}
+
+static void
+gail_menu_item_init_textutil (GailMenuItem *item,
+ GtkWidget *label)
+{
+ const gchar *label_text;
+
+ if (item->textutil == NULL)
+ {
+ item->textutil = gail_text_util_new ();
+ g_signal_connect (label,
+ "notify",
+ (GCallback) gail_menu_item_notify_label_gtk,
+ item);
+ }
+ label_text = gtk_label_get_text (GTK_LABEL (label));
+ gail_text_util_text_setup (item->textutil, label_text);
+}
+
+/* atktext.h */
+
+static void
+atk_text_interface_init (AtkTextIface *iface)
+{
+ iface->get_text = gail_menu_item_get_text;
+ iface->get_character_at_offset = gail_menu_item_get_character_at_offset;
+ iface->get_text_before_offset = gail_menu_item_get_text_before_offset;
+ iface->get_text_at_offset = gail_menu_item_get_text_at_offset;
+ iface->get_text_after_offset = gail_menu_item_get_text_after_offset;
+ iface->get_character_count = gail_menu_item_get_character_count;
+ iface->get_character_extents = gail_menu_item_get_character_extents;
+ iface->get_offset_at_point = gail_menu_item_get_offset_at_point;
+ iface->get_run_attributes = gail_menu_item_get_run_attributes;
+ iface->get_default_attributes = gail_menu_item_get_default_attributes;
+}
+
+static gchar*
+gail_menu_item_get_text (AtkText *text,
+ gint start_pos,
+ gint end_pos)
+{
+ GtkWidget *widget;
+ GtkWidget *label;
+ GailMenuItem *item;
+ const gchar *label_text;
+
+ widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (text));
+ if (widget == NULL)
+ /* State is defunct */
+ return NULL;
+
+ label = get_label_from_container (widget);
+
+ if (!GTK_IS_LABEL (label))
+ return NULL;
+
+ item = GAIL_MENU_ITEM (text);
+ if (!item->textutil)
+ gail_menu_item_init_textutil (item, label);
+
+ label_text = gtk_label_get_text (GTK_LABEL (label));
+
+ if (label_text == NULL)
+ return NULL;
+ else
+ {
+ return gail_text_util_get_substring (item->textutil,
+ start_pos, end_pos);
+ }
+}
+
+static gchar*
+gail_menu_item_get_text_before_offset (AtkText *text,
+ gint offset,
+ AtkTextBoundary boundary_type,
+ gint *start_offset,
+ gint *end_offset)
+{
+ GtkWidget *widget;
+ GtkWidget *label;
+ GailMenuItem *item;
+
+ widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (text));
+
+ if (widget == NULL)
+ /* State is defunct */
+ return NULL;
+
+ /* Get label */
+ label = get_label_from_container (widget);
+
+ if (!GTK_IS_LABEL(label))
+ return NULL;
+
+ item = GAIL_MENU_ITEM (text);
+ if (!item->textutil)
+ gail_menu_item_init_textutil (item, label);
+
+ return gail_text_util_get_text (item->textutil,
+ gtk_label_get_layout (GTK_LABEL (label)), GAIL_BEFORE_OFFSET,
+ boundary_type, offset, start_offset, end_offset);
+}
+
+static gchar*
+gail_menu_item_get_text_at_offset (AtkText *text,
+ gint offset,
+ AtkTextBoundary boundary_type,
+ gint *start_offset,
+ gint *end_offset)
+{
+ GtkWidget *widget;
+ GtkWidget *label;
+ GailMenuItem *item;
+
+ widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (text));
+
+ if (widget == NULL)
+ /* State is defunct */
+ return NULL;
+
+ /* Get label */
+ label = get_label_from_container (widget);
+
+ if (!GTK_IS_LABEL(label))
+ return NULL;
+
+ item = GAIL_MENU_ITEM (text);
+ if (!item->textutil)
+ gail_menu_item_init_textutil (item, label);
+
+ return gail_text_util_get_text (item->textutil,
+ gtk_label_get_layout (GTK_LABEL (label)), GAIL_AT_OFFSET,
+ boundary_type, offset, start_offset, end_offset);
+}
+
+static gchar*
+gail_menu_item_get_text_after_offset (AtkText *text,
+ gint offset,
+ AtkTextBoundary boundary_type,
+ gint *start_offset,
+ gint *end_offset)
+{
+ GtkWidget *widget;
+ GtkWidget *label;
+ GailMenuItem *item;
+
+ widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (text));
+
+ if (widget == NULL)
+ {
+ /* State is defunct */
+ return NULL;
+ }
+
+ /* Get label */
+ label = get_label_from_container (widget);
+
+ if (!GTK_IS_LABEL(label))
+ return NULL;
+
+ item = GAIL_MENU_ITEM (text);
+ if (!item->textutil)
+ gail_menu_item_init_textutil (item, label);
+
+ return gail_text_util_get_text (item->textutil,
+ gtk_label_get_layout (GTK_LABEL (label)), GAIL_AFTER_OFFSET,
+ boundary_type, offset, start_offset, end_offset);
+}
+
+static gint
+gail_menu_item_get_character_count (AtkText *text)
+{
+ GtkWidget *widget;
+ GtkWidget *label;
+
+ widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (text));
+ if (widget == NULL)
+ /* State is defunct */
+ return 0;
+
+ label = get_label_from_container (widget);
+
+ if (!GTK_IS_LABEL(label))
+ return 0;
+
+ return g_utf8_strlen (gtk_label_get_text (GTK_LABEL (label)), -1);
+}
+
+static void
+gail_menu_item_get_character_extents (AtkText *text,
+ gint offset,
+ gint *x,
+ gint *y,
+ gint *width,
+ gint *height,
+ AtkCoordType coords)
+{
+ GtkWidget *widget;
+ GtkWidget *label;
+ PangoRectangle char_rect;
+ gint index, x_layout, y_layout;
+ const gchar *label_text;
+
+ widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (text));
+
+ if (widget == NULL)
+ /* State is defunct */
+ return;
+
+ label = get_label_from_container (widget);
+
+ if (!GTK_IS_LABEL(label))
+ return;
+
+ gtk_label_get_layout_offsets (GTK_LABEL (label), &x_layout, &y_layout);
+ label_text = gtk_label_get_text (GTK_LABEL (label));
+ index = g_utf8_offset_to_pointer (label_text, offset) - label_text;
+ pango_layout_index_to_pos (gtk_label_get_layout (GTK_LABEL (label)), index, &char_rect);
+
+ gail_misc_get_extents_from_pango_rectangle (label, &char_rect,
+ x_layout, y_layout, x, y, width, height, coords);
+}
+
+static gint
+gail_menu_item_get_offset_at_point (AtkText *text,
+ gint x,
+ gint y,
+ AtkCoordType coords)
+{
+ GtkWidget *widget;
+ GtkWidget *label;
+ gint index, x_layout, y_layout;
+ const gchar *label_text;
+
+ widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (text));
+ if (widget == NULL)
+ /* State is defunct */
+ return -1;
+
+ label = get_label_from_container (widget);
+
+ if (!GTK_IS_LABEL(label))
+ return -1;
+
+ gtk_label_get_layout_offsets (GTK_LABEL (label), &x_layout, &y_layout);
+
+ index = gail_misc_get_index_at_point_in_layout (label,
+ gtk_label_get_layout (GTK_LABEL (label)),
+ x_layout, y_layout, x, y, coords);
+ label_text = gtk_label_get_text (GTK_LABEL (label));
+ if (index == -1)
+ {
+ if (coords == ATK_XY_WINDOW || coords == ATK_XY_SCREEN)
+ return g_utf8_strlen (label_text, -1);
+
+ return index;
+ }
+ else
+ return g_utf8_pointer_to_offset (label_text, label_text + index);
+}
+
+static AtkAttributeSet*
+gail_menu_item_get_run_attributes (AtkText *text,
+ gint offset,
+ gint *start_offset,
+ gint *end_offset)
+{
+ GtkWidget *widget;
+ GtkWidget *label;
+ AtkAttributeSet *at_set = NULL;
+ GtkJustification justify;
+ GtkTextDirection dir;
+
+ widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (text));
+ if (widget == NULL)
+ /* State is defunct */
+ return NULL;
+
+ label = get_label_from_container (widget);
+
+ if (!GTK_IS_LABEL(label))
+ return NULL;
+
+ /* Get values set for entire label, if any */
+ justify = gtk_label_get_justify (GTK_LABEL (label));
+ if (justify != GTK_JUSTIFY_CENTER)
+ {
+ at_set = gail_misc_add_attribute (at_set,
+ ATK_TEXT_ATTR_JUSTIFICATION,
+ g_strdup (atk_text_attribute_get_value (ATK_TEXT_ATTR_JUSTIFICATION, justify)));
+ }
+ dir = gtk_widget_get_direction (label);
+ if (dir == GTK_TEXT_DIR_RTL)
+ {
+ at_set = gail_misc_add_attribute (at_set,
+ ATK_TEXT_ATTR_DIRECTION,
+ g_strdup (atk_text_attribute_get_value (ATK_TEXT_ATTR_DIRECTION, dir)));
+ }
+
+ at_set = gail_misc_layout_get_run_attributes (at_set,
+ gtk_label_get_layout (GTK_LABEL (label)),
+ (gchar *) gtk_label_get_text (GTK_LABEL (label)),
+ offset,
+ start_offset,
+ end_offset);
+ return at_set;
+}
+
+static AtkAttributeSet*
+gail_menu_item_get_default_attributes (AtkText *text)
+{
+ GtkWidget *widget;
+ GtkWidget *label;
+ AtkAttributeSet *at_set = NULL;
+
+ widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (text));
+ if (widget == NULL)
+ /* State is defunct */
+ return NULL;
+
+ label = get_label_from_container (widget);
+
+ if (!GTK_IS_LABEL(label))
+ return NULL;
+
+ at_set = gail_misc_get_default_attributes (at_set,
+ gtk_label_get_layout (GTK_LABEL (label)),
+ widget);
+ return at_set;
+}
+
+static gunichar
+gail_menu_item_get_character_at_offset (AtkText *text,
+ gint offset)
+{
+ GtkWidget *widget;
+ GtkWidget *label;
+ const gchar *string;
+ gchar *index;
+
+ widget = gtk_accessible_get_widget (GTK_ACCESSIBLE (text));
+ if (widget == NULL)
+ /* State is defunct */
+ return '\0';
+
+ label = get_label_from_container (widget);
+
+ if (!GTK_IS_LABEL(label))
+ return '\0';
+ string = gtk_label_get_text (GTK_LABEL (label));
+ if (offset >= g_utf8_strlen (string, -1))
+ return '\0';
+ index = g_utf8_offset_to_pointer (string, offset);
+
+ return g_utf8_get_char (index);
+}
+
+static GtkWidget*
+get_label_from_container (GtkWidget *container)
+{
+ GtkWidget *label;
+ GList *children, *tmp_list;
+
+ if (!GTK_IS_CONTAINER (container))
+ return NULL;
+
+ children = gtk_container_get_children (GTK_CONTAINER (container));
+ label = NULL;
+
+ for (tmp_list = children; tmp_list != NULL; tmp_list = tmp_list->next)
+ {
+ if (GTK_IS_LABEL (tmp_list->data))
+ {
+ label = tmp_list->data;
+ break;
+ }
+ /*
+ * * Get label from menu item in desktop background preferences
+ * * option menu. See bug #144084.
+ * */
+ else if (GTK_IS_BOX (tmp_list->data))
+ {
+ label = get_label_from_container (GTK_WIDGET (tmp_list->data));
+ if (label)
+ break;
+ }
+ }
+ g_list_free (children);
+
+ return label;
+}
+
AtkObject*
gail_menu_item_new (GtkWidget *widget)
{
@@ -616,23 +1120,33 @@ gail_menu_item_finalize (GObject *object)
menu_item->action_idle_handler = 0;
}
+ if (menu_item->textutil)
+ {
+ g_object_unref (menu_item->textutil);
+ }
+ if (menu_item->text)
+ {
+ g_free (menu_item->text);
+ menu_item->text = NULL;
+ }
+
G_OBJECT_CLASS (gail_menu_item_parent_class)->finalize (object);
}
static void
-menu_item_select (GtkItem *item)
+menu_item_select (GtkMenuItem *item)
{
menu_item_selection (item, TRUE);
}
static void
-menu_item_deselect (GtkItem *item)
+menu_item_deselect (GtkMenuItem *item)
{
menu_item_selection (item, FALSE);
}
static void
-menu_item_selection (GtkItem *item,
+menu_item_selection (GtkMenuItem *item,
gboolean selected)
{
AtkObject *obj, *parent;
diff --git a/modules/other/gail/gailmenuitem.h b/modules/other/gail/gailmenuitem.h
index 5f83db7..298ead4 100644
--- a/modules/other/gail/gailmenuitem.h
+++ b/modules/other/gail/gailmenuitem.h
@@ -20,7 +20,8 @@
#ifndef __GAIL_MENU_ITEM_H__
#define __GAIL_MENU_ITEM_H__
-#include <gail/gailitem.h>
+#include <gail/gailcontainer.h>
+#include <libgail-util/gailtextutil.h>
G_BEGIN_DECLS
@@ -36,7 +37,11 @@ typedef struct _GailMenuItemClass GailMenuItemClass;
struct _GailMenuItem
{
- GailItem parent;
+ GailContainer parent;
+
+ GailTextUtil *textutil;
+
+ gchar *text;
gchar *click_keybinding;
gchar *click_description;
@@ -47,7 +52,7 @@ GType gail_menu_item_get_type (void);
struct _GailMenuItemClass
{
- GailItemClass parent_class;
+ GailContainerClass parent_class;
};
AtkObject* gail_menu_item_new (GtkWidget *widget);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]