diff options
author | Matthias Clasen <mclasen@redhat.com> | 2005-10-24 20:01:57 +0000 |
---|---|---|
committer | Matthias Clasen <matthiasc@src.gnome.org> | 2005-10-24 20:01:57 +0000 |
commit | f2724a2515b384185cba4c16172ae4e28c7709af (patch) | |
tree | b5ed8be53db1dd1602f7b374eff21bd4754d75dc /gtk/gtkentry.c | |
parent | 3fe6e98689dc004935dfe94411b4927fd014ab28 (diff) | |
download | gtk+-f2724a2515b384185cba4c16172ae4e28c7709af.tar.gz |
Add settings to hide the input method and Unicode control character
2005-10-24 Matthias Clasen <mclasen@redhat.com>
Add settings to hide the input method and Unicode control character
submenus in the context menus of GtkEntry and GtkTextView.
* gdk/x11/gdkevents-x11.c: Map GTK+ settings to X settings.
* gtk/gtksettings.c (gtk_settings_class_init): Declare GTK+ settings here.
* gtk/gtktextview.c (popup_targets_received):
* gtk/gtkentry.c (popup_targets_received): Use the settings here.
Diffstat (limited to 'gtk/gtkentry.c')
-rw-r--r-- | gtk/gtkentry.c | 64 |
1 files changed, 40 insertions, 24 deletions
diff --git a/gtk/gtkentry.c b/gtk/gtkentry.c index de4d8139a5..83cc9f409c 100644 --- a/gtk/gtkentry.c +++ b/gtk/gtkentry.c @@ -4557,10 +4557,13 @@ popup_targets_received (GtkClipboard *clipboard, if (GTK_WIDGET_REALIZED (entry)) { - gboolean clipboard_contains_text = gtk_selection_data_targets_include_text (data); + gboolean clipboard_contains_text; GtkWidget *menuitem; GtkWidget *submenu; + gboolean show_input_method_menu; + gboolean show_unicode_menu; + clipboard_contains_text = gtk_selection_data_targets_include_text (data); if (entry->popup_menu) gtk_widget_destroy (entry->popup_menu); @@ -4594,33 +4597,46 @@ popup_targets_received (GtkClipboard *clipboard, gtk_widget_show (menuitem); gtk_menu_shell_append (GTK_MENU_SHELL (entry->popup_menu), menuitem); - menuitem = gtk_separator_menu_item_new (); - gtk_widget_show (menuitem); - gtk_menu_shell_append (GTK_MENU_SHELL (entry->popup_menu), menuitem); - - menuitem = gtk_menu_item_new_with_mnemonic (_("Input _Methods")); - gtk_widget_set_sensitive (menuitem, entry->editable); - gtk_widget_show (menuitem); - submenu = gtk_menu_new (); - gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), submenu); + g_object_get (gtk_widget_get_settings (GTK_WIDGET (entry)), + "gtk-show-input-method-menu", &show_input_method_menu, + "gtk-show-unicode-menu", &show_unicode_menu, + NULL); - gtk_menu_shell_append (GTK_MENU_SHELL (entry->popup_menu), menuitem); + if (show_input_method_menu || show_unicode_menu) + { + menuitem = gtk_separator_menu_item_new (); + gtk_widget_show (menuitem); + gtk_menu_shell_append (GTK_MENU_SHELL (entry->popup_menu), menuitem); + } - gtk_im_multicontext_append_menuitems (GTK_IM_MULTICONTEXT (entry->im_context), - GTK_MENU_SHELL (submenu)); + if (show_input_method_menu) + { + menuitem = gtk_menu_item_new_with_mnemonic (_("Input _Methods")); + gtk_widget_set_sensitive (menuitem, entry->editable); + gtk_widget_show (menuitem); + submenu = gtk_menu_new (); + gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), submenu); + + gtk_menu_shell_append (GTK_MENU_SHELL (entry->popup_menu), menuitem); - menuitem = gtk_menu_item_new_with_mnemonic (_("_Insert Unicode Control Character")); - gtk_widget_show (menuitem); + gtk_im_multicontext_append_menuitems (GTK_IM_MULTICONTEXT (entry->im_context), + GTK_MENU_SHELL (submenu)); + } - submenu = gtk_menu_new (); - gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), submenu); - gtk_menu_shell_append (GTK_MENU_SHELL (entry->popup_menu), menuitem); - - _gtk_text_util_append_special_char_menuitems (GTK_MENU_SHELL (submenu), - unichar_chosen_func, - entry); - if (!entry->editable) - gtk_widget_set_sensitive (menuitem, FALSE); + if (show_unicode_menu) + { + menuitem = gtk_menu_item_new_with_mnemonic (_("_Insert Unicode Control Character")); + gtk_widget_set_sensitive (menuitem, entry->editable); + gtk_widget_show (menuitem); + + submenu = gtk_menu_new (); + gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), submenu); + gtk_menu_shell_append (GTK_MENU_SHELL (entry->popup_menu), menuitem); + + _gtk_text_util_append_special_char_menuitems (GTK_MENU_SHELL (submenu), + unichar_chosen_func, + entry); + } g_signal_emit (entry, signals[POPULATE_POPUP], |