Check for Control-Tab or Control-Shift-Tab, not any Control-key as a

Mon Mar 15 09:54:36 2004  Owen Taylor  <otaylor@redhat.com>

        * gtk/gtklabel.c (gtk_label_focus): Check for
        Control-Tab or Control-Shift-Tab, not any Control-key
        as a current event ... handles the case where a dialog
        is triggered from a control accelerator better.
This commit is contained in:
Owen Taylor 2004-03-15 14:57:54 +00:00 committed by Owen Taylor
parent 486fc4fe45
commit 4bbe84b508
6 changed files with 52 additions and 5 deletions

View File

@ -1,3 +1,10 @@
Mon Mar 15 09:54:36 2004 Owen Taylor <otaylor@redhat.com>
* gtk/gtklabel.c (gtk_label_focus): Check for
Control-Tab or Control-Shift-Tab, not any Control-key
as a current event ... handles the case where a dialog
is triggered from a control accelerator better.
Mon Mar 15 08:48:48 2004 Jonathan Blandford <jrb@gnome.org> Mon Mar 15 08:48:48 2004 Jonathan Blandford <jrb@gnome.org>
* gtk/gtkfilechooserentry.c (match_selected_callback): implement * gtk/gtkfilechooserentry.c (match_selected_callback): implement

View File

@ -1,3 +1,10 @@
Mon Mar 15 09:54:36 2004 Owen Taylor <otaylor@redhat.com>
* gtk/gtklabel.c (gtk_label_focus): Check for
Control-Tab or Control-Shift-Tab, not any Control-key
as a current event ... handles the case where a dialog
is triggered from a control accelerator better.
Mon Mar 15 08:48:48 2004 Jonathan Blandford <jrb@gnome.org> Mon Mar 15 08:48:48 2004 Jonathan Blandford <jrb@gnome.org>
* gtk/gtkfilechooserentry.c (match_selected_callback): implement * gtk/gtkfilechooserentry.c (match_selected_callback): implement

View File

@ -1,3 +1,10 @@
Mon Mar 15 09:54:36 2004 Owen Taylor <otaylor@redhat.com>
* gtk/gtklabel.c (gtk_label_focus): Check for
Control-Tab or Control-Shift-Tab, not any Control-key
as a current event ... handles the case where a dialog
is triggered from a control accelerator better.
Mon Mar 15 08:48:48 2004 Jonathan Blandford <jrb@gnome.org> Mon Mar 15 08:48:48 2004 Jonathan Blandford <jrb@gnome.org>
* gtk/gtkfilechooserentry.c (match_selected_callback): implement * gtk/gtkfilechooserentry.c (match_selected_callback): implement

View File

@ -1,3 +1,10 @@
Mon Mar 15 09:54:36 2004 Owen Taylor <otaylor@redhat.com>
* gtk/gtklabel.c (gtk_label_focus): Check for
Control-Tab or Control-Shift-Tab, not any Control-key
as a current event ... handles the case where a dialog
is triggered from a control accelerator better.
Mon Mar 15 08:48:48 2004 Jonathan Blandford <jrb@gnome.org> Mon Mar 15 08:48:48 2004 Jonathan Blandford <jrb@gnome.org>
* gtk/gtkfilechooserentry.c (match_selected_callback): implement * gtk/gtkfilechooserentry.c (match_selected_callback): implement

View File

@ -1,3 +1,10 @@
Mon Mar 15 09:54:36 2004 Owen Taylor <otaylor@redhat.com>
* gtk/gtklabel.c (gtk_label_focus): Check for
Control-Tab or Control-Shift-Tab, not any Control-key
as a current event ... handles the case where a dialog
is triggered from a control accelerator better.
Mon Mar 15 08:48:48 2004 Jonathan Blandford <jrb@gnome.org> Mon Mar 15 08:48:48 2004 Jonathan Blandford <jrb@gnome.org>
* gtk/gtkfilechooserentry.c (match_selected_callback): implement * gtk/gtkfilechooserentry.c (match_selected_callback): implement

View File

@ -2820,18 +2820,30 @@ gtk_label_focus (GtkWidget *widget,
GtkDirectionType direction) GtkDirectionType direction)
{ {
GtkLabel *label = GTK_LABEL (widget); GtkLabel *label = GTK_LABEL (widget);
GdkModifierType state; GdkEvent *current_event;
gboolean is_control_tab = FALSE;
/* We want to be in the tab chain only if we are selectable /* We want to be in the tab chain only if we are selectable
* and the Control key is pressed * and Control-[Shift]Tab is pressed
*/ */
if (label->select_info == NULL) if (label->select_info == NULL)
return FALSE; return FALSE;
if (!gtk_get_current_event_state (&state)) current_event = gtk_get_current_event ();
return FALSE;
if (state & GDK_CONTROL_MASK) if (current_event)
{
if (current_event->type == GDK_KEY_PRESS &&
(current_event->key.keyval == GDK_Tab ||
current_event->key.keyval == GDK_KP_Tab ||
current_event->key.keyval == GDK_ISO_Left_Tab) &&
(current_event->key.state & GDK_CONTROL_MASK) != 0)
is_control_tab = TRUE;
gdk_event_free (current_event);
}
if (is_control_tab)
return GTK_WIDGET_CLASS (parent_class)->focus (widget, direction); return GTK_WIDGET_CLASS (parent_class)->focus (widget, direction);
else else
return FALSE; return FALSE;