gtk+ r21548 - in trunk: . gtk
- From: matthiasc svn gnome org
- To: svn-commits-list gnome org
- Subject: gtk+ r21548 - in trunk: . gtk
- Date: Tue, 30 Sep 2008 00:58:39 +0000 (UTC)
Author: matthiasc
Date: Tue Sep 30 00:58:39 2008
New Revision: 21548
URL: http://svn.gnome.org/viewvc/gtk+?rev=21548&view=rev
Log:
2008-09-29 Matthias Clasen <mclasen redhat com>
Bug 553086 â hard to see current immodule
* gtk/gtkimmulticontext.c (gtk_im_multicontext_append_menuitems):
Display the actually selected context in the system menuitem.
Complaint by Akira Tagoh.
Modified:
trunk/ChangeLog
trunk/gtk/gtkimmulticontext.c
Modified: trunk/gtk/gtkimmulticontext.c
==============================================================================
--- trunk/gtk/gtkimmulticontext.c (original)
+++ trunk/gtk/gtkimmulticontext.c Tue Sep 30 00:58:39 2008
@@ -538,9 +538,11 @@
const GtkIMContextInfo **contexts;
guint n_contexts, i;
GSList *group = NULL;
- GtkWidget *menuitem;
+ GtkWidget *menuitem, *system_menuitem;
+ const char *system_context_id;
- menuitem = gtk_radio_menu_item_new_with_label (group, Q_("input method menu|System"));
+ system_context_id = _gtk_im_module_get_default_context_id (context->priv->client_window);
+ system_menuitem = menuitem = gtk_radio_menu_item_new_with_label (group, Q_("input method menu|System"));
if (!user_context_id)
gtk_check_menu_item_set_active (GTK_CHECK_MENU_ITEM (menuitem), TRUE);
group = gtk_radio_menu_item_get_group (GTK_RADIO_MENU_ITEM (menuitem));
@@ -550,6 +552,10 @@
gtk_widget_show (menuitem);
gtk_menu_shell_append (menushell, menuitem);
+ menuitem = gtk_separator_menu_item_new ();
+ gtk_widget_show (menuitem);
+ gtk_menu_shell_append (menushell, menuitem);
+
_gtk_im_module_list (&contexts, &n_contexts);
for (i = 0; i < n_contexts; i++)
@@ -613,7 +619,18 @@
if ((user_context_id &&
strcmp (contexts[i]->context_id, user_context_id) == 0))
gtk_check_menu_item_set_active (GTK_CHECK_MENU_ITEM (menuitem), TRUE);
-
+
+ if (strcmp (contexts[i]->context_id, system_context_id) == 0)
+ {
+ GtkWidget *label;
+ char *text;
+
+ label = gtk_bin_get_child (GTK_BIN (system_menuitem));
+ text = g_strdup_printf (Q_("input method menu|System (%s)"), translated_name);
+ gtk_label_set_text (GTK_LABEL (label), text);
+ g_free (text);
+ }
+
group = gtk_radio_menu_item_get_group (GTK_RADIO_MENU_ITEM (menuitem));
g_object_set_data (G_OBJECT (menuitem), I_("gtk-context-id"),
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]