A hack to disable unredirect for login splashscreen, better solution would

be to add support for effects refcounting the window.
BUG: 172276


svn path=/trunk/KDE/kdebase/workspace/; revision=871255
This commit is contained in:
Luboš Luňák 2008-10-14 10:34:35 +00:00
parent 66f91caaf7
commit c12172d291
2 changed files with 5 additions and 1 deletions

View file

@ -899,6 +899,10 @@ bool Client::shouldUnredirect() const
bool Unmanaged::shouldUnredirect() const bool Unmanaged::shouldUnredirect() const
{ {
// the pixmap is needed for the login effect, a nicer solution would be the login effect increasing
// refcount for the window pixmap (which would prevent unredirect), avoiding this hack
if( resourceClass() == "ksplashx" || resourceClass() == "ksplashsimple" )
return false;
// it must cover whole display or one xinerama screen, and be the topmost there // it must cover whole display or one xinerama screen, and be the topmost there
if( geometry() == workspace()->clientArea( FullArea, geometry().center(), workspace()->currentDesktop()) if( geometry() == workspace()->clientArea( FullArea, geometry().center(), workspace()->currentDesktop())
|| geometry() == workspace()->clientArea( ScreenArea, geometry().center(), workspace()->currentDesktop())) || geometry() == workspace()->clientArea( ScreenArea, geometry().center(), workspace()->currentDesktop()))

View file

@ -98,7 +98,7 @@ void LoginEffect::windowClosed( EffectWindow* w )
bool LoginEffect::isLoginSplash( EffectWindow* w ) bool LoginEffect::isLoginSplash( EffectWindow* w )
{ // TODO there should be probably a better way (window type?) { // TODO there should be probably a better way (window type?)
// see also fade effect // see also fade effect and composite.cpp
if( w->windowClass() == "ksplashx ksplashx" if( w->windowClass() == "ksplashx ksplashx"
|| w->windowClass() == "ksplashsimple ksplashsimple" ) || w->windowClass() == "ksplashsimple ksplashsimple" )
{ {