wayland/compositor: fixup buffer damage tracking for wl_shm buffers

remove qt hack, fixup conditions

fixes #6844
This commit is contained in:
Vaxry 2024-07-21 22:05:53 +02:00
parent cbaac6deaf
commit 341fb4497f

View file

@ -84,7 +84,7 @@ CWLSurfaceResource::CWLSurfaceResource(SP<CWlSurface> resource_) : resource(reso
Vector2D oldBufSize = current.buffer ? current.buffer->size : Vector2D{}; Vector2D oldBufSize = current.buffer ? current.buffer->size : Vector2D{};
Vector2D newBufSize = pending.buffer ? pending.buffer->size : Vector2D{}; Vector2D newBufSize = pending.buffer ? pending.buffer->size : Vector2D{};
if (oldBufSize != newBufSize) if (oldBufSize != newBufSize || current.buffer != pending.buffer)
pending.bufferDamage = CBox{{}, {INT32_MAX, INT32_MAX}}; pending.bufferDamage = CBox{{}, {INT32_MAX, INT32_MAX}};
bufferReleased = false; bufferReleased = false;
@ -407,10 +407,7 @@ void CWLSurfaceResource::commitPendingState() {
pending.bufferDamage.clear(); pending.bufferDamage.clear();
if (current.buffer && !bufferReleased) { if (current.buffer && !bufferReleased) {
// without previous dolphin et al are weird vvv current.buffer->update(accumulateCurrentBufferDamage());
//CRegion surfaceDamage =
// current.damage.copy().scale(current.scale).transform(current.transform, current.size.x, current.size.y).add(current.bufferDamage).add(previousBufferDamage);
current.buffer->update(CBox{{}, {INT32_MAX, INT32_MAX}}); // FIXME: figure this out to not use this hack. QT apps are wonky without this.
// release the buffer if it's synchronous as update() has done everything thats needed // release the buffer if it's synchronous as update() has done everything thats needed
// so we can let the app know we're done. // so we can let the app know we're done.