diff options
author | Owen Taylor <otaylor@redhat.com> | 2002-05-20 15:51:46 +0000 |
---|---|---|
committer | Owen Taylor <otaylor@src.gnome.org> | 2002-05-20 15:51:46 +0000 |
commit | 0b12fe101b25bab06f175d0c060891014271e224 (patch) | |
tree | 28f8738bc362ecf7a042a2502dc6879ff6f5a0cc /gtk/gtkplug.c | |
parent | 6c708e69aeb85a9ebe1aff8d6bb7079672b1c5e4 (diff) | |
download | gtk+-0b12fe101b25bab06f175d0c060891014271e224.tar.gz |
Undo an accidental revert of fixes of May 16. (Caught by Padraig O'Briain)
Mon May 20 11:47:59 2002 Owen Taylor <otaylor@redhat.com>
* gtk/gtkplug.c: Undo an accidental revert of
fixes of May 16. (Caught by Padraig O'Briain)
* gtk/gtkctree.c (cell_size_request): Fix bug where
size request for text cells was being overwritten.
(#82264, Graham Swallow.)
Diffstat (limited to 'gtk/gtkplug.c')
-rw-r--r-- | gtk/gtkplug.c | 32 |
1 files changed, 28 insertions, 4 deletions
diff --git a/gtk/gtkplug.c b/gtk/gtkplug.c index 5d076a4acb..c74c7c4714 100644 --- a/gtk/gtkplug.c +++ b/gtk/gtkplug.c @@ -48,6 +48,8 @@ static void gtk_plug_size_allocate (GtkWidget *widget, GtkAllocation *allocation); static gboolean gtk_plug_key_press_event (GtkWidget *widget, GdkEventKey *event); +static gboolean gtk_plug_focus_event (GtkWidget *widget, + GdkEventFocus *event); static void gtk_plug_set_focus (GtkWindow *window, GtkWidget *focus); static gboolean gtk_plug_focus (GtkWidget *widget, @@ -123,6 +125,8 @@ gtk_plug_class_init (GtkPlugClass *class) widget_class->realize = gtk_plug_realize; widget_class->unrealize = gtk_plug_unrealize; widget_class->key_press_event = gtk_plug_key_press_event; + widget_class->focus_in_event = gtk_plug_focus_event; + widget_class->focus_out_event = gtk_plug_focus_event; widget_class->show = gtk_plug_show; widget_class->hide = gtk_plug_hide; @@ -655,6 +659,17 @@ gtk_plug_key_press_event (GtkWidget *widget, return FALSE; } +static gboolean +gtk_plug_focus_event (GtkWidget *widget, + GdkEventFocus *event) +{ + /* We eat focus-in events and focus-out events, since they + * can be generated by something like a keyboard grab on + * a child of the plug. + */ + return FALSE; +} + static void gtk_plug_set_focus (GtkWindow *window, GtkWidget *focus) @@ -1000,15 +1015,24 @@ handle_xembed_message (GtkPlug *plug, case XEMBED_FOCUS_OUT: { + GtkWidget *widget = GTK_WIDGET (plug); GdkEvent event; event.focus_change.type = GDK_FOCUS_CHANGE; - event.focus_change.window = GTK_WIDGET (plug)->window; + event.focus_change.window = widget->window; event.focus_change.send_event = TRUE; - event.focus_change.in = (message == XEMBED_FOCUS_IN); - - gtk_widget_event (GTK_WIDGET (plug), &event); + if (message == XEMBED_FOCUS_IN) + { + event.focus_change.in = TRUE; + GTK_WIDGET_CLASS (parent_class)->focus_in_event (widget, (GdkEventFocus *)&event); + } + else + { + event.focus_change.in = FALSE; + GTK_WIDGET_CLASS (parent_class)->focus_out_event (widget, (GdkEventFocus *)&event); + } + break; } |