Commit ddd27f21 authored by Matthias Clasen's avatar Matthias Clasen Committed by Matthias Clasen

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)
parent 3b1269f5
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>
* gtk/gtk[hv]ruler.c (gtk_[hv]ruler_draw_ticks):
......
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>
* gtk/gtk[hv]ruler.c (gtk_[hv]ruler_draw_ticks):
......
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>
* gtk/gtk[hv]ruler.c (gtk_[hv]ruler_draw_ticks):
......
......@@ -175,6 +175,8 @@ static gboolean gtk_menu_leave_notify (GtkWidget *widget,
GdkEventCrossing *event);
static void gtk_menu_scroll_to (GtkMenu *menu,
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_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->focus = gtk_menu_focus;
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->get_child_property = gtk_menu_get_child_property;
......@@ -4403,5 +4406,16 @@ gtk_menu_get_for_attach_widget (GtkWidget *widget)
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__
#include "gtkaliasdef.c"
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment