simplify the discardCache call; makes sanitizing this code easier (e.g. never having a null pointer!)

svn path=/trunk/KDE/kdelibs/; revision=1015481
This commit is contained in:
Aaron J. Seigo 2009-08-25 16:13:27 +00:00
parent e2ab114d6d
commit c4079787fa

View File

@ -125,7 +125,7 @@ public:
QString findInTheme(const QString &image, const QString &theme) const; QString findInTheme(const QString &image, const QString &theme) const;
void compositingChanged(); void compositingChanged();
void discardCache(bool recreateElementsCache); void discardCache();
void scheduledCacheUpdate(); void scheduledCacheUpdate();
void colorsChanged(); void colorsChanged();
bool useCache(); bool useCache();
@ -212,13 +212,13 @@ void ThemePrivate::compositingChanged()
if (compositingActive != nowCompositingActive) { if (compositingActive != nowCompositingActive) {
compositingActive = nowCompositingActive; compositingActive = nowCompositingActive;
discardCache(true); discardCache();
emit q->themeChanged(); emit q->themeChanged();
} }
#endif #endif
} }
void ThemePrivate::discardCache(bool recreateElementsCache) void ThemePrivate::discardCache()
{ {
KPixmapCache::deleteCache("plasma_theme_" + themeName); KPixmapCache::deleteCache("plasma_theme_" + themeName);
delete pixmapCache; delete pixmapCache;
@ -227,16 +227,13 @@ void ThemePrivate::discardCache(bool recreateElementsCache)
pixmapsToCache.clear(); pixmapsToCache.clear();
saveTimer->stop(); saveTimer->stop();
svgElementsCache = 0;
const QString svgElementsFile = KStandardDirs::locateLocal("cache", "plasma-svgelements-" + themeName); const QString svgElementsFile = KStandardDirs::locateLocal("cache", "plasma-svgelements-" + themeName);
if (!svgElementsFile.isEmpty()) { if (!svgElementsFile.isEmpty()) {
QFile f(svgElementsFile); QFile f(svgElementsFile);
f.remove(); f.remove();
} }
if (recreateElementsCache) { svgElementsCache = KSharedConfig::openConfig(svgElementsFile);
svgElementsCache = KSharedConfig::openConfig(svgElementsFile);
}
} }
void ThemePrivate::scheduledCacheUpdate() void ThemePrivate::scheduledCacheUpdate()
@ -254,7 +251,7 @@ void ThemePrivate::scheduledCacheUpdate()
void ThemePrivate::colorsChanged() void ThemePrivate::colorsChanged()
{ {
discardCache(true); discardCache();
colorScheme = KColorScheme(QPalette::Active, KColorScheme::Window, colors); colorScheme = KColorScheme(QPalette::Active, KColorScheme::Window, colors);
buttonColorScheme = KColorScheme(QPalette::Active, KColorScheme::Button, colors); buttonColorScheme = KColorScheme(QPalette::Active, KColorScheme::Button, colors);
viewColorScheme = KColorScheme(QPalette::Active, KColorScheme::View, colors); viewColorScheme = KColorScheme(QPalette::Active, KColorScheme::View, colors);
@ -379,7 +376,7 @@ void ThemePrivate::setThemeName(const QString &tempThemeName, bool writeSettings
//discard the old theme cache //discard the old theme cache
if (!themeName.isEmpty() && pixmapCache) { if (!themeName.isEmpty() && pixmapCache) {
discardCache(false); discardCache();
} }
themeName = theme; themeName = theme;
@ -462,14 +459,15 @@ void ThemePrivate::setThemeName(const QString &tempThemeName, bool writeSettings
QFile f(metadataPath); QFile f(metadataPath);
QFileInfo info(f); QFileInfo info(f);
if (useCache() && info.lastModified().toTime_t() > pixmapCache->timestamp()) { if (useCache() && info.lastModified().toTime_t() > pixmapCache->timestamp()) {
discardCache(false); discardCache();
} else {
QString svgElementsFile = KStandardDirs::locateLocal("cache", "plasma-svgelements-" + themeName);
svgElementsCache = KSharedConfig::openConfig(svgElementsFile);
} }
invalidElements.clear(); invalidElements.clear();
QString svgElementsFile = KStandardDirs::locateLocal("cache", "plasma-svgelements-" + themeName);
svgElementsCache = KSharedConfig::openConfig(svgElementsFile);
emit q->themeChanged(); emit q->themeChanged();
} }