[mutter/wip/carlosg/grabs-pt1: 50/59] clutter: Separate crossing event creation from emission
- From: Marge Bot <marge-bot src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [mutter/wip/carlosg/grabs-pt1: 50/59] clutter: Separate crossing event creation from emission
- Date: Tue, 11 Jan 2022 16:13:45 +0000 (UTC)
commit 4595da008c8ed44630c39e4b2c9ef58de18e7298
Author: Carlos Garnacho <carlosg gnome org>
Date: Tue Oct 26 16:51:01 2021 +0200
clutter: Separate crossing event creation from emission
We will want to be more specific about the portions of the actor
hierarchy that receive this event, separate creation and emission
so each place does what is relevant.
However, this commit brings no functional changes.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/2068>
clutter/clutter/clutter-stage.c | 44 ++++++++++++++++++++++-------------------
1 file changed, 24 insertions(+), 20 deletions(-)
---
diff --git a/clutter/clutter/clutter-stage.c b/clutter/clutter/clutter-stage.c
index e9354c4887..5b89080605 100644
--- a/clutter/clutter/clutter-stage.c
+++ b/clutter/clutter/clutter-stage.c
@@ -3460,7 +3460,7 @@ clutter_stage_set_device_coords (ClutterStage *stage,
entry->coords = coords;
}
-static void
+static ClutterEvent *
create_crossing_event (ClutterStage *stage,
ClutterInputDevice *device,
ClutterEventSequence *sequence,
@@ -3483,15 +3483,7 @@ create_crossing_event (ClutterStage *stage,
event->crossing.sequence = sequence;
clutter_event_set_device (event, device);
- /* we need to make sure that this event is processed
- * before any other event we might have queued up until
- * now, so we go on, and synthesize the event emission
- * ourselves
- */
- if (!_clutter_event_process_filters (event))
- _clutter_process_event (event);
-
- clutter_event_free (event);
+ return event;
}
void
@@ -3507,6 +3499,7 @@ clutter_stage_update_device (ClutterStage *stage,
ClutterInputDeviceType device_type;
ClutterActor *old_actor;
gboolean device_actor_changed;
+ ClutterEvent *event;
device_type = clutter_input_device_get_device_type (device);
@@ -3531,22 +3524,33 @@ clutter_stage_update_device (ClutterStage *stage,
point.y,
_clutter_actor_get_debug_name (new_actor));
+ /* we need to make sure that this event is processed
+ * before any other event we might have queued up until
+ * now, so we go on, and synthesize the event emission
+ * ourselves
+ */
if (old_actor && emit_crossing)
{
- create_crossing_event (stage,
- device, sequence,
- CLUTTER_LEAVE,
- old_actor, new_actor,
- point, time_ms);
+ event = create_crossing_event (stage,
+ device, sequence,
+ CLUTTER_LEAVE,
+ old_actor, new_actor,
+ point, time_ms);
+ if (!_clutter_event_process_filters (event))
+ _clutter_process_event (event);
+ clutter_event_free (event);
}
if (new_actor && emit_crossing)
{
- create_crossing_event (stage,
- device, sequence,
- CLUTTER_ENTER,
- new_actor, old_actor,
- point, time_ms);
+ event = create_crossing_event (stage,
+ device, sequence,
+ CLUTTER_ENTER,
+ new_actor, old_actor,
+ point, time_ms);
+ if (!_clutter_event_process_filters (event))
+ _clutter_process_event (event);
+ clutter_event_free (event);
}
}
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]