mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-12 13:30:19 +00:00
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:
parent
486fc4fe45
commit
4bbe84b508
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user