some focus problem

svn path=/trunk/kdebase/kwin/; revision=55761
This commit is contained in:
Matthias Ettrich 2000-07-08 13:35:59 +00:00
parent ad1f6da5a2
commit b26fb71535

View file

@ -1032,25 +1032,23 @@ void Workspace::requestFocus( Client* c)
*/ */
void Workspace::clientHidden( Client* c ) void Workspace::clientHidden( Client* c )
{ {
if ( c == active_client || ( !active_client && c == should_get_focus ) ) if ( c != active_client && ( active_client || c != should_get_focus ) )
{ return;
active_client = 0;
should_get_focus = 0; active_client = 0;
if (!block_focus && should_get_focus = 0;
options->focusPolicyIsReasonable() && if (!block_focus &&
!focus_chain.isEmpty() options->focusPolicyIsReasonable() &&
) !focus_chain.isEmpty()
{ ) {
for (ClientList::ConstIterator it = focus_chain.fromLast(); for (ClientList::ConstIterator it = focus_chain.fromLast();
it != focus_chain.end(); it != focus_chain.end();
--it) --it) {
{ if ((*it)->isVisible()) {
if ((*it)->isVisible()) { requestFocus(*it);
requestFocus(*it); return;
return; }
} }
}
}
} }
if ( desktop_client ) if ( desktop_client )
requestFocus( desktop_client ); requestFocus( desktop_client );