Renamed gtk_button_new_stock() to gtk_button_new_from_stock() and removed
2001-03-21 Alexander Larsson <alexl@redhat.com> * gtk/gtkbutton.[ch]: * gtk/gtkdialog.c: Renamed gtk_button_new_stock() to gtk_button_new_from_stock() and removed accel_group argument. Renamed gtk_button_new_accel() to gtk_button_new_with_mnemonic() and removed accel_group argument. * gtk/gtkcheckbutton.[ch]: New function gtk_check_button_new_with_mnemonic(). * gtk/gtkentry.c: Override activate_mnemonic and just grab focus. * gtk/gtkitemfactory.c: Don't add menu uline accel group, instead use mnemonics support. * gtk/gtklabel.[ch]: New support for mnemonics. * gtk/gtkmarshal.list: Needed BOOLEAN:BOOLEAN for activate_mnemonic. * gtk/gtkmenu.[c]: * gtkmenushell.c: Use mnemonics instead of accel groups for uline support in menu items. Removed gtk_menu_get_uline_accel_group() and gtk_menu_ensure_uline_accel_group(). * gtk/gtkmenuitem.c: Override activate_mnemonic to handle switching between menu items if there are collisions. * gtk/gtknotebook.c: Connect to activate_mnemonic on the tab_label, so that activating it switches to that notebook page. * gtk/gtkwidget.[ch]: Add activate_mnemonic signal. New function gtk_widget_activate_mnemonic() to emit it. Default implementation does activate/grab_focus. * gtk/gtkwindow.[ch]: Add support for mnemonics in windows. New functions: gtk_window_add_mnemonic, gtk_window_remove_mnemonic, gtk_window_activate_mnemonic, gtk_window_set_mnemonic_modifier * gtk/testgtk.c: Update to function name changes.
This commit is contained in:
committed by
Alexander Larsson
parent
a24e9b1074
commit
de5eafede2
@ -116,7 +116,6 @@ static void gtk_menu_remove (GtkContainer *menu,
|
||||
|
||||
static GtkMenuShellClass *parent_class = NULL;
|
||||
static const gchar *attach_data_key = "gtk-menu-attach-data";
|
||||
static GQuark quark_uline_accel_group = 0;
|
||||
|
||||
GtkType
|
||||
gtk_menu_get_type (void)
|
||||
@ -248,6 +247,7 @@ gtk_menu_init (GtkMenu *menu)
|
||||
NULL);
|
||||
gtk_window_set_policy (GTK_WINDOW (menu->toplevel),
|
||||
FALSE, FALSE, TRUE);
|
||||
gtk_window_set_mnemonic_modifier (GTK_WINDOW (menu->toplevel), 0);
|
||||
|
||||
/* Refloat the menu, so that reference counting for the menu isn't
|
||||
* affected by it being a child of the toplevel
|
||||
@ -739,38 +739,6 @@ gtk_menu_get_accel_group (GtkMenu *menu)
|
||||
return menu->accel_group;
|
||||
}
|
||||
|
||||
GtkAccelGroup*
|
||||
gtk_menu_ensure_uline_accel_group (GtkMenu *menu)
|
||||
{
|
||||
GtkAccelGroup *accel_group;
|
||||
|
||||
g_return_val_if_fail (GTK_IS_MENU (menu), NULL);
|
||||
|
||||
if (!quark_uline_accel_group)
|
||||
quark_uline_accel_group = g_quark_from_static_string ("GtkMenu-uline-accel-group");
|
||||
|
||||
accel_group = gtk_object_get_data_by_id (GTK_OBJECT (menu), quark_uline_accel_group);
|
||||
if (!accel_group)
|
||||
{
|
||||
accel_group = gtk_accel_group_new ();
|
||||
gtk_accel_group_attach (accel_group, GTK_OBJECT (menu));
|
||||
gtk_object_set_data_by_id_full (GTK_OBJECT (menu),
|
||||
quark_uline_accel_group,
|
||||
accel_group,
|
||||
(GtkDestroyNotify) gtk_accel_group_unref);
|
||||
}
|
||||
|
||||
return accel_group;
|
||||
}
|
||||
|
||||
GtkAccelGroup*
|
||||
gtk_menu_get_uline_accel_group (GtkMenu *menu)
|
||||
{
|
||||
g_return_val_if_fail (GTK_IS_MENU (menu), NULL);
|
||||
|
||||
return gtk_object_get_data_by_id (GTK_OBJECT (menu), quark_uline_accel_group);
|
||||
}
|
||||
|
||||
void
|
||||
gtk_menu_reposition (GtkMenu *menu)
|
||||
{
|
||||
@ -844,6 +812,7 @@ gtk_menu_set_tearoff_state (GtkMenu *menu,
|
||||
NULL);
|
||||
gtk_window_set_type_hint (GTK_WINDOW (menu->tearoff_window),
|
||||
GDK_WINDOW_TYPE_HINT_MENU);
|
||||
gtk_window_set_mnemonic_modifier (GTK_WINDOW (menu->tearoff_window), 0);
|
||||
gtk_widget_set_app_paintable (menu->tearoff_window, TRUE);
|
||||
gtk_signal_connect (GTK_OBJECT (menu->tearoff_window),
|
||||
"event",
|
||||
@ -1420,7 +1389,6 @@ gtk_menu_key_press (GtkWidget *widget,
|
||||
(delete ||
|
||||
(gtk_accelerator_valid (event->keyval, event->state) &&
|
||||
(event->state ||
|
||||
!gtk_menu_get_uline_accel_group (GTK_MENU (menu_shell)) ||
|
||||
(event->keyval >= GDK_F1 && event->keyval <= GDK_F35)))))
|
||||
{
|
||||
GtkMenuItem *menu_item;
|
||||
|
||||
Reference in New Issue
Block a user