Signed-off-by: Peter Hutterer <peter.hutte...@who-t.net>
---
 src/filter-private.h |  5 +++++
 src/filter.c         | 43 +++++++++++++++++++++++++++++--------------
 2 files changed, 34 insertions(+), 14 deletions(-)

diff --git a/src/filter-private.h b/src/filter-private.h
index ec87a849..10be823b 100644
--- a/src/filter-private.h
+++ b/src/filter-private.h
@@ -73,6 +73,11 @@ struct pointer_trackers {
 
 void init_trackers(struct pointer_trackers *trackers,
                   size_t ntrackers);
+void free_trackers(struct pointer_trackers *trackers);
+
+void
+reset_trackers(struct pointer_trackers *trackers,
+              uint64_t time);
 void
 feed_trackers(struct pointer_trackers *trackers,
              const struct device_float_coords *delta,
diff --git a/src/filter.c b/src/filter.c
index 3670c38f..d2106868 100644
--- a/src/filter.c
+++ b/src/filter.c
@@ -188,6 +188,33 @@ init_trackers(struct pointer_trackers *trackers,
        trackers->smoothener = NULL;
 }
 
+void
+free_trackers(struct pointer_trackers *trackers)
+{
+       free(trackers->trackers);
+       free(trackers->smoothener);
+}
+
+void
+reset_trackers(struct pointer_trackers *trackers,
+              uint64_t time)
+{
+       unsigned int offset;
+       struct pointer_tracker *tracker;
+
+       for (offset = 1; offset < trackers->ntrackers; offset++) {
+               tracker = tracker_by_offset(trackers, offset);
+               tracker->time = 0;
+               tracker->dir = 0;
+               tracker->delta.x = 0;
+               tracker->delta.y = 0;
+       }
+
+       tracker = tracker_by_offset(trackers, 0);
+       tracker->time = time;
+       tracker->dir = UNDEFINED_DIRECTION;
+}
+
 void
 feed_trackers(struct pointer_trackers *trackers,
              const struct device_float_coords *delta,
@@ -622,20 +649,8 @@ accelerator_restart(struct motion_filter *filter,
 {
        struct pointer_accelerator *accel =
                (struct pointer_accelerator *) filter;
-       unsigned int offset;
-       struct pointer_tracker *tracker;
 
-       for (offset = 1; offset < accel->trackers.ntrackers; offset++) {
-               tracker = tracker_by_offset(&accel->trackers, offset);
-               tracker->time = 0;
-               tracker->dir = 0;
-               tracker->delta.x = 0;
-               tracker->delta.y = 0;
-       }
-
-       tracker = tracker_by_offset(&accel->trackers, 0);
-       tracker->time = time;
-       tracker->dir = UNDEFINED_DIRECTION;
+       reset_trackers(&accel->trackers, time);
 }
 
 static void
@@ -644,7 +659,7 @@ accelerator_destroy(struct motion_filter *filter)
        struct pointer_accelerator *accel =
                (struct pointer_accelerator *) filter;
 
-       free(accel->trackers.trackers);
+       free_trackers(&accel->trackers);
        free(accel);
 }
 
-- 
2.14.3

_______________________________________________
wayland-devel mailing list
wayland-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/wayland-devel

Reply via email to