Version: (using KDE KDE 3.5.5) Installed from: Debian testing/unstable Packages Hi! When using a xorg configuration file without any special options and the setting in 'kcontrol > regional & accessibility > keyboard shortcuts > shortcut schemes' and in drop-down box chooses 'kde default for 4 modifier keys' win+tab does not switch thru all the virtual desktops. Adding Option "XkbOptions" "altwin:super_win" in xorg.conf gives right behaviour. I have tried reverting only commit 427993 and rebuilt kwin. http://websvn.kde.org/trunk/KDE/kdebase/kwin/tabbox.cpp?rev=427993&r1=427984&r2=427993 It works right when reverting this commit and without any special stuff in xorg.conf. (originally reported in debian as http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=406549 - where original submitter shows xorg.conf and other informations) /Sune
I don't think this is a bug in KWin. As the xmodmap output in the debian bugreport shows, in the first (non-working) case Mod4(=Win modifiers) includes only Super_L (left Win key) but not Super_R (right Win key), which is included only after explicitly using the option. So, in other words, the right Win key is not a Win modifier, so it doesn't work with Win+Tab. I suggest complaining to X.Org developers about the default modifier mapping.
On Monday 15 January 2007, Lubos Lunak wrote: > I don't think this is a bug in KWin. As the xmodmap output in the debian > bugreport shows, in the first (non-working) case Mod4(=Win modifiers) > includes only Super_L (left Win key) but not Super_R (right Win key), which > is included only after explicitly using the option. So, in other words, the > right Win key is not a Win modifier, so it doesn't work with Win+Tab. I > suggest complaining to X.Org developers about the default modifier mapping. Hi! I might not have been totally clear everywhere. with kde 3.4.3, it works without stuff in xorg.conf in kde 3.5.0 it don't. (Same xorg, same configuration) in kde3.5.5 with reverted the mentioned commit, it also works. so it is kwin that has changed, not xorg. I still think this is a valid bug report. (But I am not going to reopen, at least not yet) /Sune
Just to clarify a couple of points from the debian report: - It's broken with BOTH left and right Win keys - The scan code for Super_L reported in XModmap (Super_L (0x7f)) is different from what the key actually generates (0x73). The xkb rules file suggests this is some kind of virtual scan code. With the altwin:super_win option, XModmap lists both variants of Super_L (0x7f and 0x73) So it looks to me like newer Xorg releases generate different codes for Super and kwin should be handling these. Rob
I still don't see anything wrong with KWin. If left key is 0x73 and right key is 0x74 and the modifier list doesn't include either, then neither is a Win modifier, so KWin doesn't handle them. When they are included, KWin handles them.
Well, where did you get the fact that _both_ are not a Win modifier? As you said in comment #1, the right one is not a modifier. But the left one is. And the left one does _not_ work with kwin 3.5.5 while it worked with 3.4.3. This is exactly what I observed when trying to reproduce the Debian bug report. Left-win + tab did not work anymore once I upgraded from 3.4.3 to 3.5.5 (without changing anything else, especially Xorg). Brice
as it works with kwin 3.4.3 and doesn't with 3.5.x series, without any other changes than the kdebase changes I am reopening this bug.
*** Bug 123619 has been marked as a duplicate of this bug. ***
*** Bug 125246 has been marked as a duplicate of this bug. ***
SVN commit 626727 by lunakl: Revert r427993 (#106013) as it causes #140023. BUG: 140023 M +0 -4 events.cpp M +9 -51 tabbox.cpp M +0 -1 tabbox.h --- branches/KDE/3.5/kdebase/kwin/events.cpp #626726:626727 @@ -451,10 +451,6 @@ if( electricBorder( e )) return true; break; - case MappingNotify: - XRefreshKeyboardMapping( &e->xmapping ); - tab_box->updateKeyMapping(); - break; default: break; } --- branches/KDE/3.5/kdebase/kwin/tabbox.cpp #626726:626727 @@ -54,7 +54,6 @@ no_tasks = i18n("*** No Windows ***"); m = DesktopMode; // init variables - updateKeyMapping(); reconfigure(); reset(); connect(&delayedShowTimer, SIGNAL(timeout()), this, SLOT(show())); @@ -787,10 +786,6 @@ return bAll; } -static const int MAX_KEYSYMS = 4; -static uint alt_keysyms[ MAX_KEYSYMS ]; -static uint win_keysyms[ MAX_KEYSYMS ]; - static bool areModKeysDepressed( const KKeySequence& seq ) { uint rgKeySyms[10]; @@ -811,17 +806,18 @@ } if( mod & KKey::ALT ) { - for( int i = 0; - i < MAX_KEYSYMS && alt_keysyms[ i ] != NoSymbol; - ++i ) - rgKeySyms[nKeySyms++] = alt_keysyms[ i ]; + rgKeySyms[nKeySyms++] = XK_Alt_L; + rgKeySyms[nKeySyms++] = XK_Alt_R; } if( mod & KKey::WIN ) { - for( int i = 0; - i < MAX_KEYSYMS && win_keysyms[ i ] != NoSymbol; - ++i ) - rgKeySyms[nKeySyms++] = win_keysyms[ i ]; + // It would take some code to determine whether the Win key + // is associated with Super or Meta, so check for both. + // See bug #140023 for details. + rgKeySyms[nKeySyms++] = XK_Super_L; + rgKeySyms[nKeySyms++] = XK_Super_R; + rgKeySyms[nKeySyms++] = XK_Meta_L; + rgKeySyms[nKeySyms++] = XK_Meta_R; } return areKeySymXsDepressed( false, rgKeySyms, nKeySyms ); @@ -839,44 +835,6 @@ return false; } -void TabBox::updateKeyMapping() - { - const int size = 6; - uint keysyms[ size ] = { XK_Alt_L, XK_Alt_R, XK_Super_L, XK_Super_R, XK_Meta_L, XK_Meta_R }; - XModifierKeymap* map = XGetModifierMapping( qt_xdisplay() ); - int altpos = 0; - int winpos = 0; - int winmodpos = -1; - int winmod = KKeyNative::modX( KKey::WIN ); - while( winmod > 0 ) // get position of the set bit in winmod - { - winmod >>= 1; - ++winmodpos; - } - for( int i = 0; - i < MAX_KEYSYMS; - ++i ) - alt_keysyms[ i ] = win_keysyms[ i ] = NoSymbol; - for( int i = 0; - i < size; - ++i ) - { - KeyCode keycode = XKeysymToKeycode( qt_xdisplay(), keysyms[ i ] ); - for( int j = 0; - j < map->max_keypermod; - ++j ) - { - if( map->modifiermap[ 3 * map->max_keypermod + j ] == keycode ) // Alt - if( altpos < MAX_KEYSYMS ) - alt_keysyms[ altpos++ ] = keysyms[ i ]; - if( winmodpos >= 0 && map->modifiermap[ winmodpos * map->max_keypermod + j ] == keycode ) - if( winpos < MAX_KEYSYMS ) - win_keysyms[ winpos++ ] = keysyms[ i ]; - } - } - XFreeModifiermap( map ); - } - void Workspace::slotWalkThroughWindows() { if ( root != qt_xrootwin() ) --- branches/KDE/3.5/kdebase/kwin/tabbox.h #626726:626727 @@ -54,7 +54,6 @@ Workspace* workspace() const; void reconfigure(); - void updateKeyMapping(); protected: void showEvent( QShowEvent* );
*** Bug 108862 has been marked as a duplicate of this bug. ***
It works with kde3.5.7 but i have to press an additional key to actually swap to the marked window in the window list. So pressing WIN+TAB shows this list and I can cycle through it. Stopping pressing the buttons does not change the active window. This is not the case with any other combination i tried. After deactivating "Show window list while switching windows" it works. Do you want me to open a new bug report?
Yes, assuming there's not an open bugreport for this.
I had exactly the same problem as #11, but as noted in bug #108862 xmodmap -e "add mod4 = Super_L" fixed it for me.