put a found-paths cache in Theme
This commit is contained in:
parent
fbde93c64f
commit
69a6558a00
20
theme.cpp
20
theme.cpp
@ -148,7 +148,7 @@ public:
|
|||||||
return cfg;
|
return cfg;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString findInTheme(const QString &image, const QString &theme) const;
|
QString findInTheme(const QString &image, const QString &theme, bool cache = true);
|
||||||
void compositingChanged();
|
void compositingChanged();
|
||||||
void discardCache(CacheTypes caches);
|
void discardCache(CacheTypes caches);
|
||||||
void scheduledCacheUpdate();
|
void scheduledCacheUpdate();
|
||||||
@ -188,6 +188,7 @@ public:
|
|||||||
QHash<QString, QString> idsToCache;
|
QHash<QString, QString> idsToCache;
|
||||||
QHash<QString, QString> animationMapping;
|
QHash<QString, QString> animationMapping;
|
||||||
QHash<styles, QString> cachedStyleSheets;
|
QHash<styles, QString> cachedStyleSheets;
|
||||||
|
QHash<QString, QString> discoveries;
|
||||||
QTimer *saveTimer;
|
QTimer *saveTimer;
|
||||||
|
|
||||||
#ifdef Q_WS_X11
|
#ifdef Q_WS_X11
|
||||||
@ -239,9 +240,12 @@ void ThemePrivate::onAppExitCleanup()
|
|||||||
cacheTheme = false;
|
cacheTheme = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString ThemePrivate::findInTheme(const QString &image, const QString &theme) const
|
QString ThemePrivate::findInTheme(const QString &image, const QString &theme, bool cache)
|
||||||
{
|
{
|
||||||
//TODO: this should be using Package
|
if (cache && discoveries.contains(image)) {
|
||||||
|
return discoveries[image];
|
||||||
|
}
|
||||||
|
|
||||||
QString search;
|
QString search;
|
||||||
|
|
||||||
if (locolor) {
|
if (locolor) {
|
||||||
@ -261,6 +265,10 @@ QString ThemePrivate::findInTheme(const QString &image, const QString &theme) co
|
|||||||
search = KStandardDirs::locate("data", search);
|
search = KStandardDirs::locate("data", search);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (cache && !search.isEmpty()) {
|
||||||
|
discoveries.insert(image, search);
|
||||||
|
}
|
||||||
|
|
||||||
return search;
|
return search;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -278,6 +286,8 @@ void ThemePrivate::compositingChanged()
|
|||||||
|
|
||||||
void ThemePrivate::discardCache(CacheTypes caches)
|
void ThemePrivate::discardCache(CacheTypes caches)
|
||||||
{
|
{
|
||||||
|
discoveries.clear();
|
||||||
|
|
||||||
if (caches & PixmapCache) {
|
if (caches & PixmapCache) {
|
||||||
pixmapsToCache.clear();
|
pixmapsToCache.clear();
|
||||||
saveTimer->stop();
|
saveTimer->stop();
|
||||||
@ -783,8 +793,8 @@ bool Theme::currentThemeHasImage(const QString &name) const
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return !(d->findInTheme(name % QLatin1Literal(".svgz"), d->themeName).isEmpty()) ||
|
return !(d->findInTheme(name % QLatin1Literal(".svgz"), d->themeName, false).isEmpty()) ||
|
||||||
!(d->findInTheme(name % QLatin1Literal(".svg"), d->themeName).isEmpty());
|
!(d->findInTheme(name % QLatin1Literal(".svg"), d->themeName, false).isEmpty());
|
||||||
}
|
}
|
||||||
|
|
||||||
KSharedConfigPtr Theme::colorScheme() const
|
KSharedConfigPtr Theme::colorScheme() const
|
||||||
|
Loading…
Reference in New Issue
Block a user