xcb: update connection time when possible

At least we try to do it with all events triggered by user.

Pick-to: 5.15 6.1 6.2
Change-Id: I28b399a2517600f7da2c91a50fecdf58b9d81fb6
Reviewed-by: JiDe Zhang <zhangjide@uniontech.com>
Reviewed-by: Shawn Rutledge <shawn.rutledge@qt.io>
This commit is contained in:
Liang Qi 2021-07-08 11:53:42 +02:00
parent 63c1e7c4a1
commit 25feb2fe3e
2 changed files with 19 additions and 3 deletions

View File

@ -579,6 +579,7 @@ void QXcbConnection::handleXcbEvent(xcb_generic_event_t *event)
HANDLE_PLATFORM_WINDOW_EVENT(xcb_expose_event_t, window, handleExposeEvent); HANDLE_PLATFORM_WINDOW_EVENT(xcb_expose_event_t, window, handleExposeEvent);
case XCB_BUTTON_PRESS: { case XCB_BUTTON_PRESS: {
auto ev = reinterpret_cast<xcb_button_press_event_t *>(event); auto ev = reinterpret_cast<xcb_button_press_event_t *>(event);
setTime(ev->time);
m_keyboard->updateXKBStateFromCore(ev->state); m_keyboard->updateXKBStateFromCore(ev->state);
// the event explicitly contains the state of the three first buttons, // the event explicitly contains the state of the three first buttons,
// the rest we need to manage ourselves // the rest we need to manage ourselves
@ -591,6 +592,7 @@ void QXcbConnection::handleXcbEvent(xcb_generic_event_t *event)
} }
case XCB_BUTTON_RELEASE: { case XCB_BUTTON_RELEASE: {
auto ev = reinterpret_cast<xcb_button_release_event_t *>(event); auto ev = reinterpret_cast<xcb_button_release_event_t *>(event);
setTime(ev->time);
if (m_duringSystemMoveResize && ev->root != XCB_NONE) if (m_duringSystemMoveResize && ev->root != XCB_NONE)
abortSystemMoveResize(ev->root); abortSystemMoveResize(ev->root);
m_keyboard->updateXKBStateFromCore(ev->state); m_keyboard->updateXKBStateFromCore(ev->state);
@ -603,6 +605,7 @@ void QXcbConnection::handleXcbEvent(xcb_generic_event_t *event)
} }
case XCB_MOTION_NOTIFY: { case XCB_MOTION_NOTIFY: {
auto ev = reinterpret_cast<xcb_motion_notify_event_t *>(event); auto ev = reinterpret_cast<xcb_motion_notify_event_t *>(event);
setTime(ev->time);
m_keyboard->updateXKBStateFromCore(ev->state); m_keyboard->updateXKBStateFromCore(ev->state);
m_buttonState = (m_buttonState & ~0x7) | translateMouseButtons(ev->state); m_buttonState = (m_buttonState & ~0x7) | translateMouseButtons(ev->state);
if (Q_UNLIKELY(lcQpaXInputEvents().isDebugEnabled())) if (Q_UNLIKELY(lcQpaXInputEvents().isDebugEnabled()))
@ -643,14 +646,19 @@ void QXcbConnection::handleXcbEvent(xcb_generic_event_t *event)
// Prefer XI2 enter (XCB_INPUT_ENTER) events over core events. // Prefer XI2 enter (XCB_INPUT_ENTER) events over core events.
break; break;
} }
setTime(reinterpret_cast<xcb_enter_notify_event_t *>(event)->time);
HANDLE_PLATFORM_WINDOW_EVENT(xcb_enter_notify_event_t, event, handleEnterNotifyEvent); HANDLE_PLATFORM_WINDOW_EVENT(xcb_enter_notify_event_t, event, handleEnterNotifyEvent);
case XCB_LEAVE_NOTIFY: case XCB_LEAVE_NOTIFY:
{
if (hasXInput2()) { if (hasXInput2()) {
// Prefer XI2 leave (XCB_INPUT_LEAVE) events over core events. // Prefer XI2 leave (XCB_INPUT_LEAVE) events over core events.
break; break;
} }
m_keyboard->updateXKBStateFromCore(reinterpret_cast<xcb_leave_notify_event_t *>(event)->state); auto ev = reinterpret_cast<xcb_leave_notify_event_t *>(event);
setTime(ev->time);
m_keyboard->updateXKBStateFromCore(ev->state);
HANDLE_PLATFORM_WINDOW_EVENT(xcb_leave_notify_event_t, event, handleLeaveNotifyEvent); HANDLE_PLATFORM_WINDOW_EVENT(xcb_leave_notify_event_t, event, handleLeaveNotifyEvent);
}
case XCB_FOCUS_IN: case XCB_FOCUS_IN:
HANDLE_PLATFORM_WINDOW_EVENT(xcb_focus_in_event_t, event, handleFocusInEvent); HANDLE_PLATFORM_WINDOW_EVENT(xcb_focus_in_event_t, event, handleFocusInEvent);
case XCB_FOCUS_OUT: case XCB_FOCUS_OUT:
@ -658,13 +666,18 @@ void QXcbConnection::handleXcbEvent(xcb_generic_event_t *event)
case XCB_KEY_PRESS: case XCB_KEY_PRESS:
{ {
auto keyPress = reinterpret_cast<xcb_key_press_event_t *>(event); auto keyPress = reinterpret_cast<xcb_key_press_event_t *>(event);
setTime(keyPress->time);
m_keyboard->updateXKBStateFromCore(keyPress->state); m_keyboard->updateXKBStateFromCore(keyPress->state);
setTime(keyPress->time); setTime(keyPress->time);
HANDLE_KEYBOARD_EVENT(xcb_key_press_event_t, handleKeyPressEvent); HANDLE_KEYBOARD_EVENT(xcb_key_press_event_t, handleKeyPressEvent);
} }
case XCB_KEY_RELEASE: case XCB_KEY_RELEASE:
m_keyboard->updateXKBStateFromCore(reinterpret_cast<xcb_key_release_event_t *>(event)->state); {
auto keyRelease = reinterpret_cast<xcb_key_release_event_t *>(event);
setTime(keyRelease->time);
m_keyboard->updateXKBStateFromCore(keyRelease->state);
HANDLE_KEYBOARD_EVENT(xcb_key_release_event_t, handleKeyReleaseEvent); HANDLE_KEYBOARD_EVENT(xcb_key_release_event_t, handleKeyReleaseEvent);
}
case XCB_MAPPING_NOTIFY: case XCB_MAPPING_NOTIFY:
m_keyboard->updateKeymap(reinterpret_cast<xcb_mapping_notify_event_t *>(event)); m_keyboard->updateKeymap(reinterpret_cast<xcb_mapping_notify_event_t *>(event));
break; break;
@ -672,6 +685,7 @@ void QXcbConnection::handleXcbEvent(xcb_generic_event_t *event)
{ {
#if QT_CONFIG(draganddrop) || QT_CONFIG(clipboard) #if QT_CONFIG(draganddrop) || QT_CONFIG(clipboard)
auto selectionRequest = reinterpret_cast<xcb_selection_request_event_t *>(event); auto selectionRequest = reinterpret_cast<xcb_selection_request_event_t *>(event);
setTime(selectionRequest->time);
#endif #endif
#if QT_CONFIG(draganddrop) #if QT_CONFIG(draganddrop)
if (selectionRequest->selection == atom(QXcbAtom::XdndSelection)) if (selectionRequest->selection == atom(QXcbAtom::XdndSelection))
@ -696,11 +710,12 @@ void QXcbConnection::handleXcbEvent(xcb_generic_event_t *event)
break; break;
case XCB_PROPERTY_NOTIFY: case XCB_PROPERTY_NOTIFY:
{ {
auto propertyNotify = reinterpret_cast<xcb_property_notify_event_t *>(event);
setTime(propertyNotify->time);
#ifndef QT_NO_CLIPBOARD #ifndef QT_NO_CLIPBOARD
if (m_clipboard->handlePropertyNotify(event)) if (m_clipboard->handlePropertyNotify(event))
break; break;
#endif #endif
auto propertyNotify = reinterpret_cast<xcb_property_notify_event_t *>(event);
if (propertyNotify->atom == atom(QXcbAtom::_NET_WORKAREA)) { if (propertyNotify->atom == atom(QXcbAtom::_NET_WORKAREA)) {
QXcbVirtualDesktop *virtualDesktop = virtualDesktopForRootWindow(propertyNotify->window); QXcbVirtualDesktop *virtualDesktop = virtualDesktopForRootWindow(propertyNotify->window);
if (virtualDesktop) if (virtualDesktop)

View File

@ -639,6 +639,7 @@ static inline qreal fixed1616ToReal(xcb_input_fp1616_t val)
void QXcbConnection::xi2HandleEvent(xcb_ge_event_t *event) void QXcbConnection::xi2HandleEvent(xcb_ge_event_t *event)
{ {
auto *xiEvent = reinterpret_cast<qt_xcb_input_device_event_t *>(event); auto *xiEvent = reinterpret_cast<qt_xcb_input_device_event_t *>(event);
setTime(xiEvent->time);
if (m_xiSlavePointerIds.contains(xiEvent->deviceid)) { if (m_xiSlavePointerIds.contains(xiEvent->deviceid)) {
if (!m_duringSystemMoveResize) if (!m_duringSystemMoveResize)
return; return;