2019-09-29 18:06:18 +10:00
|
|
|
From 45b1aba399b89c20e93bc358dfba261e40fcf30b Mon Sep 17 00:00:00 2001
|
2019-08-22 14:33:10 +10:00
|
|
|
From: Derek Lesho <dereklesho52@Gmail.com>
|
|
|
|
Date: Tue, 25 Jun 2019 21:58:34 -0400
|
2019-09-25 14:06:49 +10:00
|
|
|
Subject: [PATCH 05/11] server: Don't emulate rawinput mouse events if native
|
2019-08-22 14:33:10 +10:00
|
|
|
exist.
|
|
|
|
|
|
|
|
Signed-off-by: Derek Lesho <dereklesho52@Gmail.com>
|
|
|
|
---
|
|
|
|
server/queue.c | 6 +++++-
|
|
|
|
1 file changed, 5 insertions(+), 1 deletion(-)
|
|
|
|
|
|
|
|
diff --git a/server/queue.c b/server/queue.c
|
2019-09-29 18:06:18 +10:00
|
|
|
index f9787933f2..060e73b819 100644
|
2019-08-22 14:33:10 +10:00
|
|
|
--- a/server/queue.c
|
|
|
|
+++ b/server/queue.c
|
2019-09-25 14:06:49 +10:00
|
|
|
@@ -1599,6 +1599,8 @@ static int send_hook_ll_message( struct desktop *desktop, struct message *hardwa
|
2019-08-22 14:33:10 +10:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
+static int emulate_raw_mouse = 1;
|
|
|
|
+
|
|
|
|
/* queue a hardware message for a mouse event */
|
|
|
|
static int queue_mouse_message( struct desktop *desktop, user_handle_t win, const hw_input_t *input,
|
|
|
|
unsigned int origin, struct msg_queue *sender )
|
2019-09-25 14:06:49 +10:00
|
|
|
@@ -1664,7 +1666,8 @@ static int queue_mouse_message( struct desktop *desktop, user_handle_t win, cons
|
2019-08-22 14:33:10 +10:00
|
|
|
y = desktop->cursor.y;
|
|
|
|
}
|
|
|
|
|
|
|
|
- if ((device = current->process->rawinput_mouse))
|
|
|
|
+ device = current->process->rawinput_mouse;
|
|
|
|
+ if (device && emulate_raw_mouse)
|
|
|
|
{
|
|
|
|
if (!(msg = alloc_hardware_message( input->mouse.info, source, time ))) return 0;
|
|
|
|
msg_data = msg->data;
|
2019-09-25 14:06:49 +10:00
|
|
|
@@ -2435,6 +2438,7 @@ DECL_HANDLER(send_rawinput_message)
|
2019-08-22 14:33:10 +10:00
|
|
|
switch (req->input.type)
|
|
|
|
{
|
|
|
|
case RIM_TYPEMOUSE:
|
|
|
|
+ emulate_raw_mouse = 0;
|
|
|
|
if ((device = current->process->rawinput_mouse))
|
|
|
|
{
|
|
|
|
struct thread *thread = device->target ? get_window_thread( device->target ) : NULL;
|
|
|
|
--
|
2019-09-25 14:06:49 +10:00
|
|
|
2.23.0
|
2019-08-22 14:33:10 +10:00
|
|
|
|