Cancel menus when they are grab-shadowed by something thats not a submenu.
2005-06-27 Matthias Clasen <mclasen@redhat.com> * gtk/gtkmenu.c (gtk_menu_grab_notify): Cancel menus when they are grab-shadowed by something thats not a submenu. (#145416, Euan MacGregor)
This commit is contained in:
parent
3b1269f500
commit
ddd27f21a6
@ -1,3 +1,9 @@
|
|||||||
|
2005-06-27 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
|
* gtk/gtkmenu.c (gtk_menu_grab_notify): Cancel menus when
|
||||||
|
they are grab-shadowed by something thats not a
|
||||||
|
submenu. (#145416, Euan MacGregor)
|
||||||
|
|
||||||
2005-06-27 Owen Taylor <otaylor@redhat.com>
|
2005-06-27 Owen Taylor <otaylor@redhat.com>
|
||||||
|
|
||||||
* gtk/gtk[hv]ruler.c (gtk_[hv]ruler_draw_ticks):
|
* gtk/gtk[hv]ruler.c (gtk_[hv]ruler_draw_ticks):
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
2005-06-27 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
|
* gtk/gtkmenu.c (gtk_menu_grab_notify): Cancel menus when
|
||||||
|
they are grab-shadowed by something thats not a
|
||||||
|
submenu. (#145416, Euan MacGregor)
|
||||||
|
|
||||||
2005-06-27 Owen Taylor <otaylor@redhat.com>
|
2005-06-27 Owen Taylor <otaylor@redhat.com>
|
||||||
|
|
||||||
* gtk/gtk[hv]ruler.c (gtk_[hv]ruler_draw_ticks):
|
* gtk/gtk[hv]ruler.c (gtk_[hv]ruler_draw_ticks):
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
2005-06-27 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
|
* gtk/gtkmenu.c (gtk_menu_grab_notify): Cancel menus when
|
||||||
|
they are grab-shadowed by something thats not a
|
||||||
|
submenu. (#145416, Euan MacGregor)
|
||||||
|
|
||||||
2005-06-27 Owen Taylor <otaylor@redhat.com>
|
2005-06-27 Owen Taylor <otaylor@redhat.com>
|
||||||
|
|
||||||
* gtk/gtk[hv]ruler.c (gtk_[hv]ruler_draw_ticks):
|
* gtk/gtk[hv]ruler.c (gtk_[hv]ruler_draw_ticks):
|
||||||
|
@ -175,6 +175,8 @@ static gboolean gtk_menu_leave_notify (GtkWidget *widget,
|
|||||||
GdkEventCrossing *event);
|
GdkEventCrossing *event);
|
||||||
static void gtk_menu_scroll_to (GtkMenu *menu,
|
static void gtk_menu_scroll_to (GtkMenu *menu,
|
||||||
gint offset);
|
gint offset);
|
||||||
|
static void gtk_menu_grab_notify (GtkWidget *widget,
|
||||||
|
gboolean was_grabbed);
|
||||||
|
|
||||||
static void gtk_menu_stop_scrolling (GtkMenu *menu);
|
static void gtk_menu_stop_scrolling (GtkMenu *menu);
|
||||||
static void gtk_menu_remove_scroll_timeout (GtkMenu *menu);
|
static void gtk_menu_remove_scroll_timeout (GtkMenu *menu);
|
||||||
@ -501,6 +503,7 @@ gtk_menu_class_init (GtkMenuClass *class)
|
|||||||
widget_class->style_set = gtk_menu_style_set;
|
widget_class->style_set = gtk_menu_style_set;
|
||||||
widget_class->focus = gtk_menu_focus;
|
widget_class->focus = gtk_menu_focus;
|
||||||
widget_class->can_activate_accel = gtk_menu_real_can_activate_accel;
|
widget_class->can_activate_accel = gtk_menu_real_can_activate_accel;
|
||||||
|
widget_class->grab_notify = gtk_menu_grab_notify;
|
||||||
|
|
||||||
container_class->remove = gtk_menu_remove;
|
container_class->remove = gtk_menu_remove;
|
||||||
container_class->get_child_property = gtk_menu_get_child_property;
|
container_class->get_child_property = gtk_menu_get_child_property;
|
||||||
@ -4403,5 +4406,16 @@ gtk_menu_get_for_attach_widget (GtkWidget *widget)
|
|||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gtk_menu_grab_notify (GtkWidget *widget,
|
||||||
|
gboolean was_grabbed)
|
||||||
|
{
|
||||||
|
if (!was_grabbed)
|
||||||
|
{
|
||||||
|
if (!GTK_IS_MENU (gtk_grab_get_current ()))
|
||||||
|
gtk_menu_shell_cancel (GTK_MENU_SHELL (widget));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#define __GTK_MENU_C__
|
#define __GTK_MENU_C__
|
||||||
#include "gtkaliasdef.c"
|
#include "gtkaliasdef.c"
|
||||||
|
Loading…
Reference in New Issue
Block a user