[gtk/wip/readonly-events] gtk: Port crossing event generation code to constructors
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/wip/readonly-events] gtk: Port crossing event generation code to constructors
- Date: Sat, 15 Feb 2020 00:30:59 +0000 (UTC)
commit 1f3b307c2f156ddece2667c81af92b4ff87ffb99
Author: Matthias Clasen <mclasen redhat com>
Date: Fri Feb 14 19:28:12 2020 -0500
gtk: Port crossing event generation code to constructors
Drop the focus handling from this code, since we now
have a separate function for it. And then use an event
constructor to create the events.
gtk/gtkmain.c | 76 ++++++++++-------------------------------------------------
1 file changed, 13 insertions(+), 63 deletions(-)
---
diff --git a/gtk/gtkmain.c b/gtk/gtkmain.c
index 533877f06b..31a3980fe8 100644
--- a/gtk/gtkmain.c
+++ b/gtk/gtkmain.c
@@ -1360,76 +1360,26 @@ synth_crossing (GtkWidget *widget,
GdkCrossingMode crossing_mode)
{
GdkEvent *event;
- GtkStateFlags flags;
-
- if (gdk_event_get_event_type (source) == GDK_FOCUS_CHANGE)
- {
- event = gdk_event_new (GDK_FOCUS_CHANGE);
- event->focus_change.in = enter;
- event->focus_change.mode = crossing_mode;
- event->focus_change.detail = notify_type;
-
- flags = GTK_STATE_FLAG_FOCUSED;
- if (!GTK_IS_WINDOW (toplevel) || gtk_window_get_focus_visible (GTK_WINDOW (toplevel)))
- flags |= GTK_STATE_FLAG_FOCUS_VISIBLE;
- }
- else
- {
- gdouble x, y;
- event = gdk_event_new (enter ? GDK_ENTER_NOTIFY : GDK_LEAVE_NOTIFY);
- if (related_target)
- {
- GdkSurface *surface;
-
- surface = gtk_native_get_surface (gtk_widget_get_native (related_target));
- event->crossing.child_surface = g_object_ref (surface);
- }
- gdk_event_get_coords (source, &x, &y);
- event->crossing.x = x;
- event->crossing.y = y;
- event->crossing.mode = crossing_mode;
- event->crossing.detail = notify_type;
-
- flags = GTK_STATE_FLAG_PRELIGHT;
- }
+ gdouble x, y;
+ gdk_event_get_coords (source, &x, &y);
+ event = gdk_event_crossing_new (enter ? GDK_ENTER_NOTIFY : GDK_LEAVE_NOTIFY,
+ gtk_native_get_surface (gtk_widget_get_native (toplevel)),
+ source->any.device,
+ source->any.source_device,
+ GDK_CURRENT_TIME,
+ 0,
+ x, y,
+ crossing_mode,
+ notify_type);
gdk_event_set_target (event, G_OBJECT (target));
gdk_event_set_related_target (event, G_OBJECT (related_target));
- gdk_event_set_device (event, gdk_event_get_device (source));
- gdk_event_set_source_device (event, gdk_event_get_source_device (source));
-
- event->any.surface = gtk_native_get_surface (gtk_widget_get_native (toplevel));
- if (event->any.surface)
- g_object_ref (event->any.surface);
if (is_or_contains (enter, notify_type))
- gtk_widget_set_state_flags (widget, flags, FALSE);
+ gtk_widget_set_state_flags (widget, GTK_STATE_FLAG_PRELIGHT, FALSE);
else
- gtk_widget_unset_state_flags (widget, flags);
-
- if (gdk_event_get_event_type (source) == GDK_FOCUS_CHANGE)
- {
- /* maintain focus chain */
- if (enter || notify_type == GDK_NOTIFY_INFERIOR)
- {
- GtkWidget *parent = gtk_widget_get_parent (widget);
- if (parent)
- gtk_widget_set_focus_child (parent, widget);
- }
- else if (!enter && notify_type != GDK_NOTIFY_INFERIOR)
- {
- GtkWidget *parent = gtk_widget_get_parent (widget);
- if (parent)
- gtk_widget_set_focus_child (parent, NULL);
- }
+ gtk_widget_unset_state_flags (widget, GTK_STATE_FLAG_PRELIGHT);
- /* maintain widget state */
- if (notify_type == GDK_NOTIFY_ANCESTOR ||
- notify_type == GDK_NOTIFY_INFERIOR ||
- notify_type == GDK_NOTIFY_NONLINEAR)
- gtk_widget_set_has_focus (widget, enter);
- }
-
gtk_widget_event (widget, event);
g_object_unref (event);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]