summaryrefslogtreecommitdiffhomepage
path: root/qxt-mini/qxtglobalshortcut_x11.cpp
diff options
context:
space:
mode:
authorStanisław Halik <sthalik@misaki.pl>2017-05-16 05:08:11 +0200
committerGitHub <noreply@github.com>2017-05-16 05:08:11 +0200
commit7b66bd9506ff7ef1fce0ebe0a4d4825b3899fcf3 (patch)
tree9d98f81fa1d93c404b7b04fe23738e1c6bd83e3a /qxt-mini/qxtglobalshortcut_x11.cpp
parentdf567396803d3ea57de48fe090cbb9360abde703 (diff)
parentc2fdd8504ae99a408cc2630925cfb85295250d73 (diff)
Merge pull request #622 from miniskipper/unstable
Linux/X11: Fix hotkeys
Diffstat (limited to 'qxt-mini/qxtglobalshortcut_x11.cpp')
-rw-r--r--qxt-mini/qxtglobalshortcut_x11.cpp34
1 files changed, 29 insertions, 5 deletions
diff --git a/qxt-mini/qxtglobalshortcut_x11.cpp b/qxt-mini/qxtglobalshortcut_x11.cpp
index a2e47ade..0db1ece5 100644
--- a/qxt-mini/qxtglobalshortcut_x11.cpp
+++ b/qxt-mini/qxtglobalshortcut_x11.cpp
@@ -206,19 +206,45 @@ public:
return DefaultRootWindow(display());
}
- bool grabKey(quint32 keycode, Window window)
+ bool grabKey(quint32 keycode, quint32 modifiers, Window window)
{
+ //TODO: search keybinding by code and modifiers, so keys can be assigned multiple times using different modifiers
if (keybinding::incf(keycode))
{
QxtX11ErrorHandler errorHandler;
+ bool error = false;
- XGrabKey(display(), keycode, AnyModifier, window, True,
+ XGrabKey(display(), keycode, modifiers, window, True,
GrabModeAsync, GrabModeAsync);
+ if (errorHandler.error) {
+ error=true;
+ }
+ //Also grab key with num lock = on
+ XGrabKey(display(), keycode, modifiers | Mod2Mask, window, True,
+ GrabModeAsync, GrabModeAsync);
+ if (errorHandler.error) {
+ error=true;
+ }
+ //...and with scroll lock = on
+ XGrabKey(display(), keycode, modifiers | Mod5Mask, window, True,
+ GrabModeAsync, GrabModeAsync);
if (errorHandler.error) {
+ error=true;
+ }
+
+ //...and with bot = on
+ XGrabKey(display(), keycode, modifiers | Mod2Mask | Mod5Mask, window, True,
+ GrabModeAsync, GrabModeAsync);
+ if (errorHandler.error) {
+ error=true;
+ }
+
+ if(error){
ungrabKey(keycode, window);
return false;
}
+
}
return true;
@@ -262,8 +288,6 @@ bool QxtGlobalShortcutPrivate::nativeEventFilter(const QByteArray & eventType,
keystate |= Mod4Mask;
if(kev->state & XCB_MOD_MASK_SHIFT) //shift
keystate |= ShiftMask;
- if(kev->state & XCB_MOD_MASK_2) //numlock
- keystate |= Mod2Mask;
#if 0
if(key->state & XCB_MOD_MASK_3) // alt gr aka right-alt or ctrl+left-alt -- what mask is it?
keystate |= AltGrMask;
@@ -323,7 +347,7 @@ quint32 QxtGlobalShortcutPrivate::nativeKeycode(Qt::Key key)
bool QxtGlobalShortcutPrivate::registerShortcut(quint32 nativeKey, unused(quint32, nativeMods))
{
QxtX11Data x11;
- return x11.isValid() && x11.grabKey(nativeKey, x11.rootWindow());
+ return x11.isValid() && x11.grabKey(nativeKey, nativeMods, x11.rootWindow());
}
bool QxtGlobalShortcutPrivate::unregisterShortcut(quint32 nativeKey, unused(quint32, nativeMods))