summaryrefslogtreecommitdiff
path: root/gtk
diff options
context:
space:
mode:
authorMatthias Clasen <maclas@gmx.de>2003-08-24 23:11:14 +0000
committerMatthias Clasen <matthiasc@src.gnome.org>2003-08-24 23:11:14 +0000
commitbfa5c5aa4e8f3d72499b4dea946eb4c5dfaf1b45 (patch)
treee27c5a6765925b48db8da1396a0fd5a20cd273eb /gtk
parent32c6a944cfc5db7f59ee6232a8d76c04a27e908e (diff)
downloadgtk+-bfa5c5aa4e8f3d72499b4dea946eb4c5dfaf1b45.tar.gz
Hooks for translation of label and tooltip in GtkActionGroupEntries.
2003-08-25 Matthias Clasen <maclas@gmx.de> * gtk/gtkactiongroup.[hc] (gtk_action_group_set_translate_func, gtk_action_group_set_translation_domain): Hooks for translation of label and tooltip in GtkActionGroupEntries. (#120620)
Diffstat (limited to 'gtk')
-rw-r--r--gtk/gtkactiongroup.c100
-rw-r--r--gtk/gtkactiongroup.h9
2 files changed, 105 insertions, 4 deletions
diff --git a/gtk/gtkactiongroup.c b/gtk/gtkactiongroup.c
index 28ae218b32..69a2c1e355 100644
--- a/gtk/gtkactiongroup.c
+++ b/gtk/gtkactiongroup.c
@@ -40,8 +40,12 @@
struct _GtkActionGroupPrivate
{
- gchar *name;
- GHashTable *actions;
+ gchar *name;
+ GHashTable *actions;
+
+ GtkTranslateFunc translate_func;
+ gpointer translate_data;
+ GtkDestroyNotify translate_notify;
};
static void gtk_action_group_init (GtkActionGroup *self);
@@ -101,6 +105,9 @@ gtk_action_group_init (GtkActionGroup *self)
self->private_data->actions = g_hash_table_new_full (g_str_hash, g_str_equal,
(GDestroyNotify) g_free,
(GDestroyNotify) g_object_unref);
+ self->private_data->translate_func = NULL;
+ self->private_data->translate_data = NULL;
+ self->private_data->translate_notify = NULL;
}
/**
@@ -137,6 +144,9 @@ gtk_action_group_finalize (GObject *object)
g_hash_table_destroy (self->private_data->actions);
self->private_data->actions = NULL;
+ if (self->private_data->translate_notify)
+ self->private_data->translate_notify (self->private_data->translate_data);
+
if (parent_class->finalize)
(* parent_class->finalize) (object);
}
@@ -257,6 +267,7 @@ GList *
gtk_action_group_list_actions (GtkActionGroup *action_group)
{
GList *actions = NULL;
+ g_return_val_if_fail (GTK_IS_ACTION_GROUP (action_group), NULL);
g_hash_table_foreach (action_group->private_data->actions, add_single_action, &actions);
@@ -282,12 +293,17 @@ gtk_action_group_add_actions (GtkActionGroup *action_group,
guint n_entries)
{
guint i;
+ g_return_if_fail (GTK_IS_ACTION_GROUP (action_group));
+ GtkTranslateFunc translate_func = action_group->private_data->translate_func;
+ gpointer translate_data = action_group->private_data->translate_data;
for (i = 0; i < n_entries; i++)
{
GtkAction *action;
GType action_type;
gchar *accel_path;
+ gchar *label;
+ gchar *tooltip;
switch (entries[i].entry_type) {
case GTK_ACTION_NORMAL:
@@ -304,10 +320,21 @@ gtk_action_group_add_actions (GtkActionGroup *action_group,
action_type = GTK_TYPE_ACTION;
}
+ if (translate_func)
+ {
+ label = translate_func (entries[i].label, translate_data);
+ tooltip = translate_func (entries[i].tooltip, translate_data);
+ }
+ else
+ {
+ label = entries[i].label;
+ tooltip = entries[i].tooltip;
+ }
+
action = g_object_new (action_type,
"name", entries[i].name,
- "label", _(entries[i].label),
- "tooltip", _(entries[i].tooltip),
+ "label", label,
+ "tooltip", tooltip,
"stock_id", entries[i].stock_id,
NULL);
@@ -354,3 +381,68 @@ gtk_action_group_add_actions (GtkActionGroup *action_group,
g_object_unref (action);
}
}
+
+/**
+ * gtk_action_group_set_translate_func:
+ * @action_group: a #GtkActionGroup
+ * @func: a #GtkTranslateFunc
+ * @data: data to be passed to @func and @notify
+ * @notify: a #GtkDestroyNotify function to be called when @action_group is
+ * destroyed and when the translation function is changed again
+ *
+ * Sets a function to be used for translating the @label and @tooltip of
+ * #GtkActionGroupEntry<!-- -->s added by gtk_action_group_add_actions().
+ *
+ * If you're using gettext(), it is enough to set the translation domain
+ * with gtk_action_group_set_translation_domain().
+ *
+ * Since: 2.4
+ **/
+void
+gtk_action_group_set_translate_func (GtkActionGroup *action_group,
+ GtkTranslateFunc func,
+ gpointer data,
+ GtkDestroyNotify notify)
+{
+ g_return_if_fail (GTK_IS_ACTION_GROUP (action_group));
+
+ if (action_group->private_data->translate_notify)
+ action_group->private_data->translate_notify (action_group->private_data->translate_data);
+
+ action_group->private_data->translate_func = func;
+ action_group->private_data->translate_data = data;
+ action_group->private_data->translate_notify = notify;
+}
+
+static gchar *
+dgettext_swapped (const gchar *msgid,
+ const gchar *domainname)
+{
+ return dgettext (domainname, msgid);
+}
+
+/**
+ * gtk_action_group_set_translation_domain:
+ * @action_group: a #GtkActionGroup
+ * @domain: the translation domain to use for dgettext() calls
+ *
+ * Sets the translation domain and uses dgettext() for translating the
+ * @label and @tooltip of #GtkActionGroupEntry<!-- -->s added by
+ * gtk_action_group_add_actions().
+ *
+ * If you're not using gettext() for localization, see
+ * gtk_action_group_set_translate_func().
+ *
+ * Since: 2.4
+ **/
+void
+gtk_action_group_set_translation_domain (GtkActionGroup *action_group,
+ const gchar *domain)
+{
+ g_return_if_fail (GTK_IS_ACTION_GROUP (action_group));
+
+ gtk_action_group_set_translate_func (action_group,
+ dgettext_swapped,
+ g_strdup (domain),
+ g_free);
+}
diff --git a/gtk/gtkactiongroup.h b/gtk/gtkactiongroup.h
index 1489006d85..6036f2e0e7 100644
--- a/gtk/gtkactiongroup.h
+++ b/gtk/gtkactiongroup.h
@@ -31,6 +31,7 @@
#define __GTK_ACTION_GROUP_H__
#include <gtk/gtkaction.h>
+#include <gtk/gtkitemfactory.h> /* for GtkTranslateFunc */
#define GTK_TYPE_ACTION_GROUP (gtk_action_group_get_type ())
#define GTK_ACTION_GROUP(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_ACTION_GROUP, GtkActionGroup))
@@ -106,4 +107,12 @@ void gtk_action_group_add_actions (GtkActionGroup *action_grou
GtkActionGroupEntry *entries,
guint n_entries);
+void gtk_action_group_set_translate_func (GtkActionGroup *action_group,
+ GtkTranslateFunc func,
+ gpointer data,
+ GtkDestroyNotify notify);
+
+void gtk_action_group_set_translation_domain (GtkActionGroup *action_group,
+ const gchar *domain);
+
#endif /* __GTK_ACTION_GROUP_H__ */