summaryrefslogtreecommitdiff
path: root/quantum/mousekey.c
diff options
context:
space:
mode:
authorDrashna Jaelre <drashna@live.com>2022-06-28 15:28:44 -0700
committerGitHub <noreply@github.com>2022-06-28 15:28:44 -0700
commit43f8d365ba01b1e61b0c6cbbf6ef28eea9dee2b9 (patch)
tree2d9bab8c6ee6e64701fc61a946c4f5dac04c3628 /quantum/mousekey.c
parent1e402060a668d8edf72279c84c4083d9e3c0dacd (diff)
[Bug] Fix issue with mousekey movement getting stuck (#17493)
* [Bug] Fix issue with mousekey movement getting stuck * Lint
Diffstat (limited to 'quantum/mousekey.c')
-rw-r--r--quantum/mousekey.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/quantum/mousekey.c b/quantum/mousekey.c
index 64d0e66682..33d71af083 100644
--- a/quantum/mousekey.c
+++ b/quantum/mousekey.c
@@ -70,6 +70,10 @@ uint8_t mk_wheel_interval = MOUSEKEY_WHEEL_INTERVAL;
uint8_t mk_wheel_max_speed = MOUSEKEY_WHEEL_MAX_SPEED;
uint8_t mk_wheel_time_to_max = MOUSEKEY_WHEEL_TIME_TO_MAX;
+bool should_mousekey_report_send(report_mouse_t *mouse_report) {
+ return mouse_report->x || mouse_report->y || mouse_report->v || mouse_report->h;
+}
+
# ifndef MK_COMBINED
static uint8_t move_unit(void) {
@@ -252,7 +256,7 @@ void mousekey_task(void) {
}
}
- if (has_mouse_report_changed(&mouse_report, &tmpmr)) {
+ if (has_mouse_report_changed(&mouse_report, &tmpmr) || should_mousekey_report_send(&mouse_report)) {
mousekey_send();
}
memcpy(&mouse_report, &tmpmr, sizeof(tmpmr));
@@ -358,7 +362,7 @@ void mousekey_task(void) {
mouse_report.h = tmpmr.h;
}
- if (has_mouse_report_changed(&mouse_report, &tmpmr)) {
+ if (has_mouse_report_changed(&mouse_report, &tmpmr) || should_mousekey_report_send(&mouse_report)) {
mousekey_send();
}
memcpy(&mouse_report, &tmpmr, sizeof(tmpmr));