From 51c9a0bf5423406b685e0b6826d84e142a89ec0c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Thomas=20L=C3=BCbking?= Date: Mon, 27 Jul 2009 12:54:02 +0000 Subject: [PATCH] BUG: 201445 fix memleak on reconfigure and avoid heap allocation while not being in action svn path=/trunk/KDE/kdebase/workspace/; revision=1002976 --- effects/logout/logout.cpp | 55 +++++++++++++++++++++++++++------------ effects/logout/logout.h | 2 +- 2 files changed, 40 insertions(+), 17 deletions(-) diff --git a/effects/logout/logout.cpp b/effects/logout/logout.cpp index 3d8b55b13d..4d93a28ad7 100644 --- a/effects/logout/logout.cpp +++ b/effects/logout/logout.cpp @@ -45,7 +45,10 @@ LogoutEffect::LogoutEffect() Atom hack = XInternAtom( display(), "_KWIN_LOGOUT_EFFECT", False ); XChangeProperty( display(), sel, hack, hack, 8, PropModeReplace, (unsigned char*)&hack, 1 ); // the atom is not removed when effect is destroyed, this is temporary anyway - +#ifdef KWIN_HAVE_OPENGL_COMPOSITING + blurTexture = NULL; + blurTarget = NULL; +#endif reconfigure( ReconfigureAll ); } @@ -60,29 +63,49 @@ LogoutEffect::~LogoutEffect() void LogoutEffect::reconfigure( ReconfigureFlags ) { KConfigGroup conf = effects->effectConfig( "Logout" ); - bool useBlur = conf.readEntry( "UseBlur", true ); - + useBlur = conf.readEntry( "UseBlur", true ); #ifdef KWIN_HAVE_OPENGL_COMPOSITING - blurSupported = false; + delete blurTexture; blurTexture = NULL; + delete blurTarget; blurTarget = NULL; - if( effects->compositingType() == OpenGLCompositing && GLTexture::NPOTTextureSupported() && useBlur ) - { // TODO: It seems that it is not possible to create a GLRenderTarget that has - // a different size than the display right now. Most likely a KWin core bug. - // Create texture and render target - blurTexture = new GLTexture( displayWidth(), displayHeight() ); - blurTexture->setFilter( GL_LINEAR_MIPMAP_LINEAR ); - blurTexture->setWrapMode( GL_CLAMP_TO_EDGE ); - - blurTarget = new GLRenderTarget( blurTexture ); - if( blurTarget->valid() ) - blurSupported = true; - } + blurSupported = false; #endif } void LogoutEffect::prePaintScreen( ScreenPrePaintData& data, int time ) { +#ifdef KWIN_HAVE_OPENGL_COMPOSITING + if ( !logoutWindow ) + { + if (blurTexture) + { + delete blurTexture; + blurTexture = NULL; + delete blurTarget; + blurTarget = NULL; + blurSupported = false; + } + } + else if ( !blurTexture ) + { + blurSupported = false; + delete blurTarget; // catch as we just tested the texture ;-P + if( effects->compositingType() == OpenGLCompositing && GLTexture::NPOTTextureSupported() && useBlur ) + { // TODO: It seems that it is not possible to create a GLRenderTarget that has + // a different size than the display right now. Most likely a KWin core bug. + // Create texture and render target + blurTexture = new GLTexture( displayWidth(), displayHeight() ); + blurTexture->setFilter( GL_LINEAR_MIPMAP_LINEAR ); + blurTexture->setWrapMode( GL_CLAMP_TO_EDGE ); + + blurTarget = new GLRenderTarget( blurTexture ); + if( blurTarget->valid() ) + blurSupported = true; + } + } +#endif + if( logoutWindow != NULL && !logoutWindowClosed ) progress = qMin( 1.0, progress + time / animationTime( 2000.0 )); else if( progress > 0.0 ) diff --git a/effects/logout/logout.h b/effects/logout/logout.h index 2832f4d3cb..1b8ab0a5b9 100644 --- a/effects/logout/logout.h +++ b/effects/logout/logout.h @@ -54,7 +54,7 @@ class LogoutEffect bool logoutWindowPassed; #ifdef KWIN_HAVE_OPENGL_COMPOSITING - bool blurSupported; + bool blurSupported, useBlur; GLTexture* blurTexture; GLRenderTarget* blurTarget; double windowOpacity;