From d1fdb9a02fb823fe22faef0678bb69963d385d05 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20Gr=C3=A4=C3=9Flin?= Date: Mon, 26 Dec 2016 11:59:10 +0100 Subject: [PATCH] Use new xkbcommon API for consumed modifiers Summary: This change removes the workaround added with 421824b654a5301fe1c0ed97caded66936c91385. Xkbcommon 0.7 introduces the needed API to make this work without a workaround. Test Plan: Test case still passes Reviewers: #kwin, #plasma_on_wayland Subscribers: plasma-devel, kwin Tags: #plasma_on_wayland, #kwin Differential Revision: https://phabricator.kde.org/D3809 --- CMakeLists.txt | 2 +- keyboard_input.cpp | 25 ++++--------------------- 2 files changed, 5 insertions(+), 22 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 30ab234267..48ebff9b95 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -167,7 +167,7 @@ if(Wayland_Egl_FOUND) set(HAVE_WAYLAND_EGL TRUE) endif() -find_package(XKB 0.5.0) +find_package(XKB 0.7.0) set_package_properties(XKB PROPERTIES TYPE REQUIRED PURPOSE "Required for building KWin with Wayland support" diff --git a/keyboard_input.cpp b/keyboard_input.cpp index 4fc856cd6e..5a39c4cc22 100644 --- a/keyboard_input.cpp +++ b/keyboard_input.cpp @@ -401,16 +401,16 @@ void Xkb::updateModifiers() void Xkb::updateConsumedModifiers(uint32_t key) { Qt::KeyboardModifiers mods = Qt::NoModifier; - if (xkb_state_mod_index_is_consumed(m_state, key + 8, m_shiftModifier) == 1) { + if (xkb_state_mod_index_is_consumed2(m_state, key + 8, m_shiftModifier, XKB_CONSUMED_MODE_GTK) == 1) { mods |= Qt::ShiftModifier; } - if (xkb_state_mod_index_is_consumed(m_state, key + 8, m_altModifier) == 1) { + if (xkb_state_mod_index_is_consumed2(m_state, key + 8, m_altModifier, XKB_CONSUMED_MODE_GTK) == 1) { mods |= Qt::AltModifier; } - if (xkb_state_mod_index_is_consumed(m_state, key + 8, m_controlModifier) == 1) { + if (xkb_state_mod_index_is_consumed2(m_state, key + 8, m_controlModifier, XKB_CONSUMED_MODE_GTK) == 1) { mods |= Qt::ControlModifier; } - if (xkb_state_mod_index_is_consumed(m_state, key + 8, m_metaModifier) == 1) { + if (xkb_state_mod_index_is_consumed2(m_state, key + 8, m_metaModifier, XKB_CONSUMED_MODE_GTK) == 1) { mods |= Qt::MetaModifier; } m_consumedModifiers = mods; @@ -432,23 +432,6 @@ Qt::KeyboardModifiers Xkb::modifiersRelevantForGlobalShortcuts() const mods |= Qt::MetaModifier; } - // workaround xkbcommon limitation concerning consumed modifiers - // if a key could be turned into a keysym with a modifier xkbcommon - // considers the modifier as consumed even if not pressed - // e.g. alt+F3 considers alt as consumed as there is a keysym generated - // with ctrl+alt+F3 (vt switching) - // For more information see: - // https://bugs.freedesktop.org/show_bug.cgi?id=92818 - // https://github.com/xkbcommon/libxkbcommon/issues/17 - - // the workaround is to not consider the modifiers as consumed - // if they are not a currently - // this might have other side effects, though. The only proper way to - // handle this is through new API in xkbcommon which doesn't exist yet - if (m_consumedModifiers & ~m_modifiers) { - return mods; - } - Qt::KeyboardModifiers consumedMods = m_consumedModifiers; if ((mods & Qt::ShiftModifier) && (consumedMods == Qt::ShiftModifier)) { // test whether current keysym is a letter