]> Pileus Git - ~andy/gtk/commitdiff
R modules/other/gail/gailintl.h: Use the stock item's label as the name of
authorChristian Persch <chpe@gnome.org>
Thu, 20 Dec 2007 00:22:39 +0000 (00:22 +0000)
committerChristian Persch <chpe@src.gnome.org>
Thu, 20 Dec 2007 00:22:39 +0000 (00:22 +0000)
2007-12-20  Christian Persch  <chpe@gnome.org>

* modules/other/gail/Makefile.am:
* modules/other/gail/gailimage.c: (gail_image_class_init),
(gail_image_init), (elide_underscores), (gail_image_get_name),
(atk_image_interface_init), (gail_image_finalize):
* modules/other/gail/gailimage.h:
R modules/other/gail/gailintl.h:
* po/POTFILES.skip: Use the stock item's label as the name of the
accessible in gailimage.c. Bug #504246.

svn path=/trunk/; revision=19203

ChangeLog
modules/other/gail/Makefile.am
modules/other/gail/gailimage.c
modules/other/gail/gailimage.h
modules/other/gail/gailintl.h [deleted file]
po/POTFILES.skip

index 0c686d2b0296a60f7c88444699e096c5cc286f72..b69cc5b40ddb98ea0383342814ca6982d50240de 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,14 @@
+2007-12-20  Christian Persch  <chpe@gnome.org>
+
+       * modules/other/gail/Makefile.am:
+       * modules/other/gail/gailimage.c: (gail_image_class_init),
+       (gail_image_init), (elide_underscores), (gail_image_get_name),
+       (atk_image_interface_init), (gail_image_finalize):
+       * modules/other/gail/gailimage.h:
+       R modules/other/gail/gailintl.h:
+       * po/POTFILES.skip: Use the stock item's label as the name of the
+       accessible in gailimage.c. Bug #504246.
+
 2007-12-19  Mathias Hasselmann  <mathias@openismus.com>
 
        Avoid some compiler warnings and remove obsolete code. (#339540)
index 0825a41da977f5a819bbfc306761c4b6d35c371f..a8c8973984510bf043c14921d739c5d964e530ef 100644 (file)
@@ -6,7 +6,7 @@ if OS_WIN32
 no_undefined = -no-undefined
 endif
 
-moduledir = $(libdir)/gtk-2.0/$(GTK_BINARY_VERSION)/other
+moduledir = $(libdir)/gtk-2.0/modules
 module_LTLIBRARIES = libgail.la
 
 gail_c_sources =                       \
@@ -100,7 +100,6 @@ gail_private_h_sources =            \
        gailimage.h                     \
        gailimagecell.h                 \
        gailimagecellfactory.h          \
-       gailintl.h                      \
        gailitem.h                      \
        gaillabel.h                     \
        gaillist.h                      \
index e0bcc08df568e6d9354ef60d349ec8eff41a9ff0..557597e1eea03ac6daabffe4e7dae94936c735bf 100644 (file)
  * Boston, MA 02111-1307, USA.
  */
 
+#include <config.h>
+
+#include <string.h>
 #include <gtk/gtk.h>
 #include "gailimage.h"
-#include "gailintl.h"
 
 static void      gail_image_class_init         (GailImageClass *klass);
-static void      gail_image_object_init        (GailImage      *image);
+static void      gail_image_init               (GailImage      *image);
 static G_CONST_RETURN gchar* gail_image_get_name  (AtkObject     *accessible);
 
 
@@ -40,163 +42,9 @@ static void      gail_image_get_image_size     (AtkImage        *image,
 static gboolean  gail_image_set_image_description (AtkImage     *image,
                                                 const gchar     *description);
 static void      gail_image_finalize           (GObject         *object);
-                                                         
-typedef struct _GailImageItem GailImageItem;
-
-struct _GailImageItem
-{
-  GQuark id;
-  gchar *name;
-  gchar *stock_id;
-};
-
-static GailImageItem stock_items [] =
-{
-  { 0, N_("dialog authentication"), "gtk-dialog-authentication"},
-  { 0, N_("dialog information"), "gtk-dialog-info"},
-  { 0, N_("dialog warning"), "gtk-dialog-warning"},
-  { 0, N_("dialog error"), "gtk-dialog-error"},
-  { 0, N_("dialog question"), "gtk-dialog-question"},
-  { 0, N_("drag and drop"), "gtk-dnd"},
-  { 0, N_("multiple drag and drop"), "gtk-dnd-multiple"},
-  { 0, N_("add"), "gtk-add"},
-  { 0, N_("apply"), "gtk-apply"},
-  { 0, N_("bold"), "gtk-bold"},
-  { 0, N_("cancel"), "gtk_cancel"},
-  { 0, N_("cdrom"), "gtk-cdrom"},
-  { 0, N_("clear"), "gtk-clear"},
-  { 0, N_("close"), "gtk-close"},
-  { 0, N_("color picker"), "gtk-color-picker"},
-  { 0, N_("convert"), "gtk-convert"},
-  { 0, N_("copy"), "gtk-copy"},
-  { 0, N_("cut"), "gtk-cut"},
-  { 0, N_("delete"), "gtk-delete"},
-  { 0, N_("execute"), "gtk-execute"},
-  { 0, N_("find"), "gtk-find"},
-  { 0, N_("find and replace"), "gtk-find-and-replace"},
-  { 0, N_("floppy"), "gtk-floppy"},
-  { 0, N_("go to bottom"), "gtk-goto-bottom"},
-  { 0, N_("go to first"), "gtk-goto-first"},
-  { 0, N_("go to last"), "gtk-goto-last"},
-  { 0, N_("go to top"), "gtk-goto-top"},
-  { 0, N_("go back"), "gtk-go-back"},
-  { 0, N_("go down"), "gtk-go-down"},
-  { 0, N_("go forward"), "gtk-go-forward"},
-  { 0, N_("go up"), "gtk-go-up"},
-  { 0, N_("help"), "gtk-help"},
-  { 0, N_("home"), "gtk-home"},
-  { 0, N_("index"), "gtk-index"},
-  { 0, N_("italic"), "gtk-italic"},
-  { 0, N_("jump to"), "gtk-jump-to"},
-  { 0, N_("justify center"), "gtk-justify-center"},
-  { 0, N_("justify fill"), "gtk-justify-fill"},
-  { 0, N_("justify left"), "gtk-justify-left"},
-  { 0, N_("justify right"), "gtk-justify-right"},
-  { 0, N_("missing image"), "gtk-missing-image"},
-  { 0, N_("new"), "gtk-new"},
-  { 0, N_("no"), "gtk-no"},
-  { 0, N_("ok"), "gtk-ok"},
-  { 0, N_("open"), "gtk-open"},
-  { 0, N_("paste"), "gtk-paste"},
-  { 0, N_("preferences"), "gtk-preferences"},
-  { 0, N_("print"), "gtk-print"},
-  { 0, N_("print preview"), "gtk-print-preview"},
-  { 0, N_("properties"), "gtk-properties"},
-  { 0, N_("quit"), "gtk-quit"},
-  { 0, N_("redo"), "gtk-redo"},
-  { 0, N_("refresh"), "gtk-refresh"},
-  { 0, N_("remove"), "gtk-remove"},
-  { 0, N_("revert to saved"), "gtk-revert-to-saved"},
-  { 0, N_("save"), "gtk-save"},
-  { 0, N_("save as"), "gtk-save-as"},
-  { 0, N_("select color"), "gtk-select-color"},
-  { 0, N_("select font"), "gtk-select-font"},
-  { 0, N_("sort ascending"), "gtk-sort-ascending"},
-  { 0, N_("sort descending"), "gtk-sort-descending"},
-  { 0, N_("spell check"), "gtk-spell-check"},
-  { 0, N_("stop"), "gtk-stop"},
-  { 0, N_("strikethrough"), "gtk-strikethrough"},
-  { 0, N_("undelete"), "gtk-undelete"},
-  { 0, N_("underline"), "gtk-underline"},
-  { 0, N_("yes"), "gtk-yes"},
-  { 0, N_("zoom 100 percent"), "gtk-zoom-100"},
-  { 0, N_("zoom fit"), "gtk-zoom-fit"},
-  { 0, N_("zoom in"), "gtk-zoom-in"},
-  { 0, N_("zoom out"), "gtk-zoom-out"},
-
-  { 0, N_("timer"), "gnome-stock-timer"},
-  { 0, N_("timer stop"), "gnome-stock-timer-stop"},
-  { 0, N_("trash"), "gnome-stock-trash"},
-  { 0, N_("trash full"), "gnome-stock-trash-full"},
-  { 0, N_("scores"), "gnome-stock-scores"},
-  { 0, N_("about"), "gnome-stock-about"},
-  { 0, N_("blank"), "gnome-stock-blank"},
-  { 0, N_("volume"), "gnome-stock-volume"},
-  { 0, N_("midi"), "gnome-stock-midi"},
-  { 0, N_("microphone"), "gnome-stock-mic"},
-  { 0, N_("line in"), "gnome-stock-line-in"},
-  { 0, N_("mail"), "gnome-stock-mail"},
-  { 0, N_("mail receive"), "gnome-stock-mail-rcv"},
-  { 0, N_("mail send"), "gnome-stock-mail-snd"},
-  { 0, N_("mail reply"), "gnome-stock-mail-rpl"},
-  { 0, N_("mail forward"), "gnome-stock-mail-fwd"},
-  { 0, N_("mail new"), "gnome-stock-mail-new"},
-  { 0, N_("attach"), "gnome-stock-attach"},
-  { 0, N_("book red"), "gnome-stock-book-red"},
-  { 0, N_("book green"), "gnome-stock-book-green"},
-  { 0, N_("book blue"), "gnome-stock-book-blue"},
-  { 0, N_("book yellow"), "gnome-stock-book-yellow"},
-  { 0, N_("book open"), "gnome-stock-book-open"},
-  { 0, N_("multiple file"), "gnome-stock-multiple-file"},
-  { 0, N_("not"), "gnome-stock-not"},
-  { 0, N_("table borders"), "gnome-stock-table-borders"},
-  { 0, N_("table fill"), "gnome-stock-table-fill"},
-  { 0, N_("text indent"), "gnome-stock-text-indent"},
-  { 0, N_("text unindent"), "gnome-stock-text-unindent"},
-  { 0, N_("text bulleted list"), "gnome-stock-text-bulleted-list"},
-  { 0, N_("text numbered list"), "gnome-stock-text-numbered-list"},
-  { 0, N_("authentication"), "gnome-stock-authentication"}
-};
-
-static gpointer parent_class = NULL;
-
-GType
-gail_image_get_type (void)
-{
-  static GType type = 0;
-
-  if (!type)
-  {
-    static const GTypeInfo tinfo =
-    {
-      sizeof (GailImageClass),
-      (GBaseInitFunc) NULL, /* base init */
-      (GBaseFinalizeFunc) NULL, /* base finalize */
-      (GClassInitFunc) gail_image_class_init, /* class init */
-      (GClassFinalizeFunc) NULL, /* class finalize */
-      NULL, /* class data */
-      sizeof (GailImage), /* instance size */
-      0, /* nb preallocs */
-      (GInstanceInitFunc) gail_image_object_init, /* instance init */
-      NULL /* value table */
-    };
-
-    static const GInterfaceInfo atk_image_info =
-    {
-        (GInterfaceInitFunc) atk_image_interface_init,
-        (GInterfaceFinalizeFunc) NULL,
-        NULL
-    };
 
-    type = g_type_register_static (GAIL_TYPE_WIDGET,
-                                   "GailImage", &tinfo, 0);
-
-    g_type_add_interface_static (type, ATK_TYPE_IMAGE,
-                                 &atk_image_info);
-  }
-
-  return type;
-}
+G_DEFINE_TYPE_WITH_CODE (GailImage, gail_image, GAIL_TYPE_WIDGET,
+                         G_IMPLEMENT_INTERFACE (ATK_TYPE_IMAGE, atk_image_interface_init))
 
 static void
 gail_image_class_init (GailImageClass *klass)
@@ -204,14 +52,12 @@ gail_image_class_init (GailImageClass *klass)
   GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
   AtkObjectClass  *class = ATK_OBJECT_CLASS (klass);
 
-  parent_class = g_type_class_peek_parent (klass);
-
   gobject_class->finalize = gail_image_finalize;
   class->get_name = gail_image_get_name;
 }
 
 static void
-gail_image_object_init (GailImage *image)
+gail_image_init (GailImage *image)
 {
   image->image_description = NULL;
 }
@@ -234,81 +80,91 @@ gail_image_new (GtkWidget *widget)
   return accessible;
 }
 
-static void
-init_strings (void)
-{
-  gint i;
-
-  for (i = 0; i < G_N_ELEMENTS (stock_items); i++)
-    stock_items[i].id = g_quark_from_static_string (stock_items[i].stock_id);
-}
-
-static G_CONST_RETURN gchar*
-get_localized_name (const gchar *str)
+/* Copied from gtktoolbar.c, keep in sync */
+static gchar *
+elide_underscores (const gchar *original)
 {
-  GQuark str_q;
-  gint i;
-
-#if 0
-  static gboolean gettext_initialized = FALSE;
-
-  if (!gettext_initialized)
+  gchar *q, *result;
+  const gchar *p, *end;
+  gsize len;
+  gboolean last_underscore;
+  
+  if (!original)
+    return NULL;
+
+  len = strlen (original);
+  q = result = g_malloc (len + 1);
+  last_underscore = FALSE;
+  
+  end = original + len;
+  for (p = original; p < end; p++)
     {
-      init_strings ();
-      gettext_initialized = TRUE;
-#ifdef ENABLE_NLS
-      bindtextdomain (GETTEXT_PACKAGE, GAIL_LOCALEDIR);
-#ifdef HAVE_BIND_TEXTDOMAIN_CODESET
-      bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8");
-#endif
-#endif
+      if (!last_underscore && *p == '_')
+       last_underscore = TRUE;
+      else
+       {
+         last_underscore = FALSE;
+         if (original + 2 <= p && p + 1 <= end && 
+              p[-2] == '(' && p[-1] == '_' && p[0] != '_' && p[1] == ')')
+           {
+             q--;
+             *q = '\0';
+             p++;
+           }
+         else
+           *q++ = *p;
+       }
     }
-#endif
-
-  str_q = g_quark_try_string (str);
-  for (i = 0; i <  G_N_ELEMENTS (stock_items); i++)
-    {
-      if (str_q == stock_items[i].id)
-         return dgettext (GETTEXT_PACKAGE, stock_items[i].name);
-  }
 
-  return str;
+  if (last_underscore)
+    *q++ = '_';
+  
+  *q = '\0';
+  
+  return result;
 }
 
 static G_CONST_RETURN gchar*
 gail_image_get_name (AtkObject *accessible)
 {
-  G_CONST_RETURN gchar *name;
+  GtkWidget* widget;
+  GtkImage *image;
+  GailImage *image_accessible;
+  GtkStockItem stock_item;
+  const gchar *name;
 
-  name = ATK_OBJECT_CLASS (parent_class)->get_name (accessible); 
+  name = ATK_OBJECT_CLASS (gail_image_parent_class)->get_name (accessible); 
   if (name)
     return name;
-  else
-    {
-      GtkWidget* widget = GTK_ACCESSIBLE (accessible)->widget;
-      GtkImage *image;
-
-      if (widget == NULL)
-        /*
-         * State is defunct
-         */
-        return NULL;
-
-      g_return_val_if_fail (GTK_IS_IMAGE (widget), NULL);
-      image = GTK_IMAGE (widget);
-
-      if (image->storage_type == GTK_IMAGE_STOCK &&
-          image->data.stock.stock_id)
-        return get_localized_name (image->data.stock.stock_id); 
-      else return NULL;
-    }
+
+  widget = GTK_ACCESSIBLE (accessible)->widget;
+  /*
+   * State is defunct
+   */
+  if (widget == NULL)
+    return NULL;
+
+  g_return_val_if_fail (GTK_IS_IMAGE (widget), NULL);
+  image = GTK_IMAGE (widget);
+  image_accessible = GAIL_IMAGE (accessible);
+
+  g_free (image_accessible->stock_name);
+  image_accessible->stock_name = NULL;
+
+  if (image->storage_type != GTK_IMAGE_STOCK ||
+      image->data.stock.stock_id == NULL)
+    return NULL;
+
+  if (!gtk_stock_lookup (image->data.stock.stock_id, &stock_item))
+    return NULL;
+
+  image_accessible->stock_name = elide_underscores (stock_item.label);
+  return image_accessible->stock_name;
 }
 
 static void
 atk_image_interface_init (AtkImageIface *iface)
 {
-  g_return_if_fail (iface != NULL);
-
   iface->get_image_description = gail_image_get_image_description;
   iface->get_image_position = gail_image_get_image_position;
   iface->get_image_size = gail_image_get_image_size;
@@ -426,5 +282,7 @@ gail_image_finalize (GObject      *object)
   GailImage *aimage = GAIL_IMAGE (object);
 
   g_free (aimage->image_description);
-  G_OBJECT_CLASS (parent_class)->finalize (object);
+  g_free (aimage->stock_name);
+
+  G_OBJECT_CLASS (gail_image_parent_class)->finalize (object);
 }
index a30ff204d6e8cc600732e7a466ee507912dc8f09..f13b64d07445c08f37cdf366ab3f60b72cfc9f66 100644 (file)
@@ -42,6 +42,7 @@ struct _GailImage
   GailWidget parent;
 
   gchar*     image_description;
+  gchar*     stock_name;
 };
 
 GType gail_image_get_type (void);
diff --git a/modules/other/gail/gailintl.h b/modules/other/gail/gailintl.h
deleted file mode 100644 (file)
index 555de79..0000000
+++ /dev/null
@@ -1,24 +0,0 @@
-#ifndef __GAILINTL_H__
-#define __GAILINTL_H__
-
-#include "config.h"
-
-#ifdef ENABLE_NLS
-#include<libintl.h>
-#define _(String) dgettext(GETTEXT_PACKAGE,String)
-#ifdef gettext_noop
-#define N_(String) gettext_noop(String)
-#else
-#define N_(String) (String)
-#endif
-#else /* NLS is disabled */
-#define _(String) (String)
-#define N_(String) (String)
-#define textdomain(String) (String)
-#define gettext(String) (String)
-#define dgettext(Domain,String) (String)
-#define dcgettext(Domain,String,Type) (String)
-#define bindtextdomain(Domain,Directory) (Domain) 
-#endif
-
-#endif
index 736e9548a76f10a7de3222b6e9ae2a004c241773..e3b7a18284f6865ede221a49b90bf7081ae496ed 100644 (file)
@@ -1,4 +1,3 @@
 demos/gtk-demo/demo.ui
 gtk/paper_names.c
-modules/other/gail/gailimage.c