Ensure FrameSvg uses lastModified timestamp when using cache
This, I suspect, is the true source of bug 426674. FrameSvg would request items from the cache without specifying any modification time stamp, so we end up always retrieving the cached version. Since lastModified is now a required parameter, we need to ensure this does not happen anymore. BUG: 426674
This commit is contained in:
parent
7b42e5b45d
commit
16f852ea4c
@ -61,7 +61,7 @@ void FrameSvg::setImagePath(const QString &path)
|
|||||||
setContainsMultipleImages(true);
|
setContainsMultipleImages(true);
|
||||||
Svg::d->setImagePath(path);
|
Svg::d->setImagePath(path);
|
||||||
if (!d->repaintBlocked) {
|
if (!d->repaintBlocked) {
|
||||||
d->updateFrameData();
|
d->updateFrameData(Svg::d->lastModified);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -74,7 +74,7 @@ void FrameSvg::setEnabledBorders(const EnabledBorders borders)
|
|||||||
d->enabledBorders = borders;
|
d->enabledBorders = borders;
|
||||||
|
|
||||||
if (!d->repaintBlocked) {
|
if (!d->repaintBlocked) {
|
||||||
d->updateFrameData();
|
d->updateFrameData(Svg::d->lastModified);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -121,7 +121,7 @@ void FrameSvg::setElementPrefix(const QString &prefix)
|
|||||||
d->location = Types::Floating;
|
d->location = Types::Floating;
|
||||||
|
|
||||||
if (!d->repaintBlocked) {
|
if (!d->repaintBlocked) {
|
||||||
d->updateFrameData();
|
d->updateFrameData(Svg::d->lastModified);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -437,6 +437,7 @@ QSharedPointer<FrameData> FrameSvgPrivate::lookupOrCreateMaskFrame(const QShared
|
|||||||
mask->enabledBorders = frame->enabledBorders;
|
mask->enabledBorders = frame->enabledBorders;
|
||||||
mask->frameSize = frameSize(frame).toSize();
|
mask->frameSize = frameSize(frame).toSize();
|
||||||
mask->cacheId = key;
|
mask->cacheId = key;
|
||||||
|
mask->lastModified = frame->lastModified;
|
||||||
s_sharedFrames[q->theme()->d].insert(key, mask);
|
s_sharedFrames[q->theme()->d].insert(key, mask);
|
||||||
|
|
||||||
return mask;
|
return mask;
|
||||||
@ -455,10 +456,10 @@ void FrameSvgPrivate::generateBackground(const QSharedPointer<FrameData> &frame)
|
|||||||
const bool overlayAvailable = !frame->prefix.startsWith(QLatin1String("mask-")) && q->hasElement(frame->prefix % QLatin1String("overlay"));
|
const bool overlayAvailable = !frame->prefix.startsWith(QLatin1String("mask-")) && q->hasElement(frame->prefix % QLatin1String("overlay"));
|
||||||
QPixmap overlay;
|
QPixmap overlay;
|
||||||
if (q->isUsingRenderingCache()) {
|
if (q->isUsingRenderingCache()) {
|
||||||
frameCached = q->theme()->findInCache(id, frame->cachedBackground) && !frame->cachedBackground.isNull();
|
frameCached = q->theme()->findInCache(id, frame->cachedBackground, frame->lastModified) && !frame->cachedBackground.isNull();
|
||||||
|
|
||||||
if (overlayAvailable) {
|
if (overlayAvailable) {
|
||||||
overlayCached = q->theme()->findInCache(QLatin1String("overlay_") % id, overlay) && !overlay.isNull();
|
overlayCached = q->theme()->findInCache(QLatin1String("overlay_") % id, overlay, frame->lastModified) && !overlay.isNull();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -579,7 +580,7 @@ QRect FrameSvgPrivate::contentGeometry(const QSharedPointer<FrameData> &frame, c
|
|||||||
return contentRect;
|
return contentRect;
|
||||||
}
|
}
|
||||||
|
|
||||||
void FrameSvgPrivate::updateFrameData(UpdateType updateType)
|
void FrameSvgPrivate::updateFrameData(uint lastModified, UpdateType updateType)
|
||||||
{
|
{
|
||||||
auto fd = frame;
|
auto fd = frame;
|
||||||
QString newKey;
|
QString newKey;
|
||||||
@ -629,6 +630,7 @@ void FrameSvgPrivate::updateFrameData(UpdateType updateType)
|
|||||||
fd->enabledBorders = enabledBorders;
|
fd->enabledBorders = enabledBorders;
|
||||||
fd->frameSize = pendingFrameSize;
|
fd->frameSize = pendingFrameSize;
|
||||||
fd->imagePath = q->imagePath();
|
fd->imagePath = q->imagePath();
|
||||||
|
fd->lastModified = lastModified;
|
||||||
//was fd just created empty now?
|
//was fd just created empty now?
|
||||||
if (newKey.isEmpty()) {
|
if (newKey.isEmpty()) {
|
||||||
newKey = cacheId(fd.data(), prefix);
|
newKey = cacheId(fd.data(), prefix);
|
||||||
@ -875,7 +877,7 @@ void FrameSvg::setRepaintBlocked(bool blocked)
|
|||||||
d->repaintBlocked = blocked;
|
d->repaintBlocked = blocked;
|
||||||
|
|
||||||
if (!blocked) {
|
if (!blocked) {
|
||||||
d->updateFrameData();
|
d->updateFrameData(Svg::d->lastModified);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -75,6 +75,7 @@ public:
|
|||||||
QPixmap cachedBackground;
|
QPixmap cachedBackground;
|
||||||
QCache<QString, QRegion> cachedMasks;
|
QCache<QString, QRegion> cachedMasks;
|
||||||
static const int MAX_CACHED_MASKS = 10;
|
static const int MAX_CACHED_MASKS = 10;
|
||||||
|
uint lastModified = 0;
|
||||||
|
|
||||||
QSize frameSize;
|
QSize frameSize;
|
||||||
QString cacheId;
|
QString cacheId;
|
||||||
@ -150,7 +151,7 @@ public:
|
|||||||
void paintCorner(QPainter& p, const QSharedPointer<FrameData> &frame, Plasma::FrameSvg::EnabledBorders border, const QRect& output) const;
|
void paintCorner(QPainter& p, const QSharedPointer<FrameData> &frame, Plasma::FrameSvg::EnabledBorders border, const QRect& output) const;
|
||||||
void paintCenter(QPainter& p, const QSharedPointer<FrameData> &frame, const QRect& contentRect, const QSize& fullSize);
|
void paintCenter(QPainter& p, const QSharedPointer<FrameData> &frame, const QRect& contentRect, const QSize& fullSize);
|
||||||
QRect contentGeometry(const QSharedPointer<FrameData> &frame, const QSize& size) const;
|
QRect contentGeometry(const QSharedPointer<FrameData> &frame, const QSize& size) const;
|
||||||
void updateFrameData(UpdateType updateType = UpdateFrameAndMargins);
|
void updateFrameData(uint lastModified, UpdateType updateType = UpdateFrameAndMargins);
|
||||||
QSharedPointer<FrameData> lookupOrCreateMaskFrame(const QSharedPointer<FrameData> &frame, const QString &maskPrefix, const QString &maskRequestedPrefix);
|
QSharedPointer<FrameData> lookupOrCreateMaskFrame(const QSharedPointer<FrameData> &frame, const QString &maskPrefix, const QString &maskRequestedPrefix);
|
||||||
|
|
||||||
Types::Location location = Types::Floating;
|
Types::Location location = Types::Floating;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user