From e502246a364e77992aef609e030bc566addfb960 Mon Sep 17 00:00:00 2001 From: trialuser02 Date: Mon, 12 Oct 2009 12:25:53 +0000 Subject: fixed bug with calling XGrabKey with zero keycodes git-svn-id: http://svn.code.sf.net/p/qmmp-dev/code/trunk/qmmp@1306 90c681e8-e032-0410-971d-27865f9a5e38 --- src/plugins/General/hotkey/hotkeymanager.cpp | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/plugins/General/hotkey/hotkeymanager.cpp b/src/plugins/General/hotkey/hotkeymanager.cpp index ec1fb4350..7ddb83a4f 100644 --- a/src/plugins/General/hotkey/hotkeymanager.cpp +++ b/src/plugins/General/hotkey/hotkeymanager.cpp @@ -87,6 +87,8 @@ HotkeyManager::HotkeyManager(QObject *parent) : General(parent) hotkey->action = i; hotkey->key = key; hotkey->code = XKeysymToKeycode(QX11Info::display(), hotkey->key); + if(!hotkey->code) + continue; XGrabKey(QX11Info::display(), hotkey->code, mod | mask_mod, rootWindow, False, GrabModeAsync, GrabModeAsync); hotkey->mod = mod | mask_mod; @@ -102,7 +104,10 @@ HotkeyManager::HotkeyManager(QObject *parent) : General(parent) HotkeyManager::~HotkeyManager() { foreach(Hotkey *key, m_grabbedKeys) - XUngrabKey(QX11Info::display(), key->code, key->mod, QX11Info::appRootWindow()); + { + if(key->code) + XUngrabKey(QX11Info::display(), key->code, key->mod, QX11Info::appRootWindow()); + } while (!m_grabbedKeys.isEmpty()) delete m_grabbedKeys.takeFirst (); } -- cgit v1.2.3-13-gbd6f