From c2cb5ef708d15aa760b0adba0c8aed23775c7da6 Mon Sep 17 00:00:00 2001 From: Roman Gilg Date: Sun, 3 Mar 2024 23:35:06 +0100 Subject: [PATCH] refactor(client): handle subsurfaces without QPointer It is not needed. The objects keep their lifetimes according to the Wayland protocol. --- autotests/client/subsurface.cpp | 86 ++++++++++++++------------------- src/client/subcompositor.cpp | 6 +-- src/client/subcompositor.h | 5 +- src/client/subsurface.cpp | 61 +++++++++-------------- src/client/subsurface.h | 18 +++---- tests/subsurfacetest.cpp | 4 +- 6 files changed, 75 insertions(+), 105 deletions(-) diff --git a/autotests/client/subsurface.cpp b/autotests/client/subsurface.cpp index 1ec26400..2f74eee7 100644 --- a/autotests/client/subsurface.cpp +++ b/autotests/client/subsurface.cpp @@ -213,8 +213,7 @@ void TestSubsurface::testCreate() // create subsurface for surface of parent std::unique_ptr subsurface( - m_subCompositor->createSubSurface(QPointer(surface.get()), - QPointer(parent.get()))); + m_subCompositor->createSubSurface(*surface, *parent)); QVERIFY(subsurfaceCreatedSpy.wait()); @@ -267,8 +266,7 @@ void TestSubsurface::testMode() // create the Subsurface for surface of parent std::unique_ptr subsurface( - m_subCompositor->createSubSurface(QPointer(surface.get()), - QPointer(parent.get()))); + m_subCompositor->createSubSurface(*surface, *parent)); QVERIFY(subsurfaceCreatedSpy.wait()); auto serverSubsurface = subsurfaceCreatedSpy.first().first().value(); @@ -321,8 +319,7 @@ void TestSubsurface::testPosition() // create the Subsurface for surface of parent std::unique_ptr subsurface( - m_subCompositor->createSubSurface(QPointer(surface.get()), - QPointer(parent.get()))); + m_subCompositor->createSubSurface(*surface, *parent)); QVERIFY(subsurfaceCreatedSpy.wait()); auto serverSubsurface = subsurfaceCreatedSpy.first().first().value(); @@ -379,8 +376,7 @@ void TestSubsurface::testPlaceAbove() // Create the Subsurfaces for surface of parent. std::unique_ptr subsurface1( - m_subCompositor->createSubSurface(QPointer(surface1.get()), - QPointer(parent.get()))); + m_subCompositor->createSubSurface(*surface1, *parent)); QVERIFY(subsurfaceCreatedSpy.wait()); auto serverSubsurface1 @@ -389,8 +385,7 @@ void TestSubsurface::testPlaceAbove() subsurfaceCreatedSpy.clear(); std::unique_ptr subsurface2( - m_subCompositor->createSubSurface(QPointer(surface2.get()), - QPointer(parent.get()))); + m_subCompositor->createSubSurface(*surface2, *parent)); QVERIFY(subsurfaceCreatedSpy.wait()); auto serverSubsurface2 @@ -399,8 +394,7 @@ void TestSubsurface::testPlaceAbove() subsurfaceCreatedSpy.clear(); std::unique_ptr subsurface3( - m_subCompositor->createSubSurface(QPointer(surface3.get()), - QPointer(parent.get()))); + m_subCompositor->createSubSurface(*surface3, *parent)); QVERIFY(subsurfaceCreatedSpy.wait()); auto serverSubsurface3 @@ -443,7 +437,7 @@ void TestSubsurface::testPlaceAbove() QCOMPARE(serverSubsurface1->parentSurface()->state().children.at(2), serverSubsurface1); // Try placing 3 above 1, should result in 2, 1, 3. - subsurface3->placeAbove(QPointer(subsurface1.get())); + subsurface3->placeAbove(*subsurface1); parent->commit(Wrapland::Client::Surface::CommitFlag::None); wl_display_flush(m_connection->display()); QCoreApplication::processEvents(); @@ -453,7 +447,7 @@ void TestSubsurface::testPlaceAbove() QCOMPARE(serverSubsurface1->parentSurface()->state().children.at(2), serverSubsurface3); // try placing 3 above 2, should result in 2, 3, 1 - subsurface3->placeAbove(QPointer(subsurface2.get())); + subsurface3->placeAbove(*subsurface2); parent->commit(Wrapland::Client::Surface::CommitFlag::None); wl_display_flush(m_connection->display()); QCoreApplication::processEvents(); @@ -463,7 +457,7 @@ void TestSubsurface::testPlaceAbove() QCOMPARE(serverSubsurface1->parentSurface()->state().children.at(2), serverSubsurface1); // try placing 1 above 3 - shouldn't change - subsurface1->placeAbove(QPointer(subsurface3.get())); + subsurface1->placeAbove(*subsurface3); parent->commit(Wrapland::Client::Surface::CommitFlag::None); wl_display_flush(m_connection->display()); QCoreApplication::processEvents(); @@ -473,7 +467,7 @@ void TestSubsurface::testPlaceAbove() QCOMPARE(serverSubsurface1->parentSurface()->state().children.at(2), serverSubsurface1); // and 2 above 3 - > 3, 2, 1 - subsurface2->placeAbove(QPointer(subsurface3.get())); + subsurface2->placeAbove(*subsurface3); parent->commit(Wrapland::Client::Surface::CommitFlag::None); wl_display_flush(m_connection->display()); QCoreApplication::processEvents(); @@ -498,24 +492,21 @@ void TestSubsurface::testPlaceBelow() // create the Subsurfaces for surface of parent std::unique_ptr subsurface1( - m_subCompositor->createSubSurface(QPointer(surface1.get()), - QPointer(parent.get()))); + m_subCompositor->createSubSurface(*surface1, *parent)); QVERIFY(subsurfaceCreatedSpy.wait()); auto serverSubsurface1 = subsurfaceCreatedSpy.first().first().value(); QVERIFY(serverSubsurface1); subsurfaceCreatedSpy.clear(); std::unique_ptr subsurface2( - m_subCompositor->createSubSurface(QPointer(surface2.get()), - QPointer(parent.get()))); + m_subCompositor->createSubSurface(*surface2, *parent)); QVERIFY(subsurfaceCreatedSpy.wait()); auto serverSubsurface2 = subsurfaceCreatedSpy.first().first().value(); QVERIFY(serverSubsurface2); subsurfaceCreatedSpy.clear(); std::unique_ptr subsurface3( - m_subCompositor->createSubSurface(QPointer(surface3.get()), - QPointer(parent.get()))); + m_subCompositor->createSubSurface(*surface3, *parent)); QVERIFY(subsurfaceCreatedSpy.wait()); auto serverSubsurface3 = subsurfaceCreatedSpy.first().first().value(); @@ -552,7 +543,7 @@ void TestSubsurface::testPlaceBelow() QCOMPARE(serverSubsurface1->parentSurface()->state().children.at(2), serverSubsurface2); // place 1 below 3 -> 1, 3, 2 - subsurface1->placeBelow(QPointer(subsurface3.get())); + subsurface1->placeBelow(*subsurface3); parent->commit(Wrapland::Client::Surface::CommitFlag::None); wl_display_flush(m_connection->display()); QCoreApplication::processEvents(); @@ -562,7 +553,7 @@ void TestSubsurface::testPlaceBelow() QCOMPARE(serverSubsurface1->parentSurface()->state().children.at(2), serverSubsurface2); // 2 below 3 -> 1, 2, 3 - subsurface2->placeBelow(QPointer(subsurface3.get())); + subsurface2->placeBelow(*subsurface3); parent->commit(Wrapland::Client::Surface::CommitFlag::None); wl_display_flush(m_connection->display()); QCoreApplication::processEvents(); @@ -572,7 +563,7 @@ void TestSubsurface::testPlaceBelow() QCOMPARE(serverSubsurface1->parentSurface()->state().children.at(2), serverSubsurface3); // 1 below 2 -> shouldn't change - subsurface1->placeBelow(QPointer(subsurface2.get())); + subsurface1->placeBelow(*subsurface2); parent->commit(Wrapland::Client::Surface::CommitFlag::None); wl_display_flush(m_connection->display()); QCoreApplication::processEvents(); @@ -582,7 +573,7 @@ void TestSubsurface::testPlaceBelow() QCOMPARE(serverSubsurface1->parentSurface()->state().children.at(2), serverSubsurface3); // and 3 below 1 -> 3, 1, 2 - subsurface3->placeBelow(QPointer(subsurface1.get())); + subsurface3->placeBelow(*subsurface1); parent->commit(Wrapland::Client::Surface::CommitFlag::None); wl_display_flush(m_connection->display()); QCoreApplication::processEvents(); @@ -599,8 +590,7 @@ void TestSubsurface::testDestroy() std::unique_ptr parent(m_compositor->createSurface()); // create subsurface for surface of parent std::unique_ptr subsurface( - m_subCompositor->createSubSurface(QPointer(surface.get()), - QPointer(parent.get()))); + m_subCompositor->createSubSurface(*surface, *parent)); connect(m_connection, &Wrapland::Client::ConnectionThread::establishedChanged, @@ -650,8 +640,7 @@ void TestSubsurface::testCast() // Create subsurface for surface with parent. std::unique_ptr subsurface( - m_subCompositor->createSubSurface(QPointer(surface.get()), - QPointer(parent.get()))); + m_subCompositor->createSubSurface(*surface, *parent)); QCOMPARE(Wrapland::Client::SubSurface::get(*(subsurface.get())), QPointer(subsurface.get())); @@ -684,8 +673,7 @@ void TestSubsurface::testSyncMode() // create subsurface for surface of parent std::unique_ptr subsurface( - m_subCompositor->createSubSurface(QPointer(surface.get()), - QPointer(parent.get()))); + m_subCompositor->createSubSurface(*surface, *parent)); QVERIFY(!subsurfaceTreeChangedSpy.wait(100)); parent->commit(Wrapland::Client::Surface::CommitFlag::None); @@ -774,8 +762,7 @@ void TestSubsurface::testDeSyncMode() // create subsurface for surface of parent std::unique_ptr subsurface( - m_subCompositor->createSubSurface(QPointer(surface.get()), - QPointer(parent.get()))); + m_subCompositor->createSubSurface(*surface, *parent)); QVERIFY(!subsurfaceTreeChangedSpy.wait(100)); parent->commit(Wrapland::Client::Surface::CommitFlag::None); @@ -865,11 +852,9 @@ void TestSubsurface::testMainSurfaceFromTree() &Wrapland::Server::Surface::subsurfaceTreeChanged); QVERIFY(subsurfaceTreeChangedSpy.isValid()); - auto* sub1 = m_subCompositor->createSubSurface(childLevel1Surface.get(), parentSurface.get()); - auto* sub2 - = m_subCompositor->createSubSurface(childLevel2Surface.get(), childLevel1Surface.get()); - auto* sub3 - = m_subCompositor->createSubSurface(childLevel3Surface.get(), childLevel2Surface.get()); + auto* sub1 = m_subCompositor->createSubSurface(*childLevel1Surface, *parentSurface); + auto* sub2 = m_subCompositor->createSubSurface(*childLevel2Surface, *childLevel1Surface); + auto* sub3 = m_subCompositor->createSubSurface(*childLevel3Surface, *childLevel2Surface); childLevel2Surface->commit(Wrapland::Client::Surface::CommitFlag::None); childLevel1Surface->commit(Wrapland::Client::Surface::CommitFlag::None); @@ -927,7 +912,7 @@ void TestSubsurface::testRemoveSurface() QVERIFY(subsurfaceTreeChangedSpy.isValid()); std::unique_ptr sub( - m_subCompositor->createSubSurface(childSurface.get(), parentSurface.get())); + m_subCompositor->createSubSurface(*childSurface, *parentSurface)); parentSurface->commit(Wrapland::Client::Surface::CommitFlag::None); QVERIFY(parent_commit_spy.wait()); @@ -976,12 +961,11 @@ void TestSubsurface::testMappingOfSurfaceTree() &Wrapland::Server::Surface::subsurfaceTreeChanged); QVERIFY(subsurfaceTreeChangedSpy.isValid()); - auto subsurfaceLevel1 - = m_subCompositor->createSubSurface(childLevel1Surface.get(), parentSurface.get()); + auto subsurfaceLevel1 = m_subCompositor->createSubSurface(*childLevel1Surface, *parentSurface); auto subsurfaceLevel2 - = m_subCompositor->createSubSurface(childLevel2Surface.get(), childLevel1Surface.get()); + = m_subCompositor->createSubSurface(*childLevel2Surface, *childLevel1Surface); auto subsurfaceLevel3 - = m_subCompositor->createSubSurface(childLevel3Surface.get(), childLevel2Surface.get()); + = m_subCompositor->createSubSurface(*childLevel3Surface, *childLevel2Surface); childLevel3Surface->commit(Wrapland::Client::Surface::CommitFlag::None); childLevel2Surface->commit(Wrapland::Client::Surface::CommitFlag::None); @@ -1150,7 +1134,7 @@ void TestSubsurface::testSurfaceAt() // Create the subsurfaces for the children. std::unique_ptr child1Sub( - m_subCompositor->createSubSurface(child1.get(), parent.get())); + m_subCompositor->createSubSurface(*child1, *parent)); child1Sub->setMode(Wrapland::Client::SubSurface::Mode::Desynchronized); child1->attachBuffer(m_shm->createBuffer(childImage)); @@ -1159,7 +1143,7 @@ void TestSubsurface::testSurfaceAt() // Note: child2Sub is initially above child1Sub since it is added after. std::unique_ptr child2Sub( - m_subCompositor->createSubSurface(child2.get(), parent.get())); + m_subCompositor->createSubSurface(*child2, *parent)); child2Sub->setMode(Wrapland::Client::SubSurface::Mode::Desynchronized); child2Sub->setPosition(QPoint(50, 50)); @@ -1180,12 +1164,12 @@ void TestSubsurface::testSurfaceAt() // Create subsurfaces for the grandchildren. std::unique_ptr grandchild1Sub( - m_subCompositor->createSubSurface(grandchild1.get(), child1.get())); + m_subCompositor->createSubSurface(*grandchild1, *child1)); grandchild1Sub->setMode(Wrapland::Client::SubSurface::Mode::Desynchronized); grandchild1Sub->setPosition(QPoint(-25, -25)); std::unique_ptr grandchild2Sub( - m_subCompositor->createSubSurface(grandchild2.get(), child2.get())); + m_subCompositor->createSubSurface(*grandchild2, *child2)); grandchild2Sub->setMode(Wrapland::Client::SubSurface::Mode::Desynchronized); grandchild2Sub->setPosition(QPoint(25, 25)); @@ -1314,7 +1298,7 @@ void TestSubsurface::testDestroyAttachedBuffer() auto serverChildSurface = serverSurfaceCreated.last().first().value(); // create sub-surface - auto* sub = m_subCompositor->createSubSurface(child.get(), parent.get()); + auto sub = m_subCompositor->createSubSurface(*child, *parent); // let's damage this surface, will be in sub-surface pending state QImage image(QSize(100, 100), QImage::Format_ARGB32_Premultiplied); @@ -1358,9 +1342,9 @@ void TestSubsurface::testDestroyParentSurface() auto serverGrandChildSurface = serverSurfaceCreated.last().first().value(); // create sub-surface in desynchronized mode as Qt uses them - auto sub1 = m_subCompositor->createSubSurface(child.get(), parent.get()); + auto sub1 = m_subCompositor->createSubSurface(*child, *parent); sub1->setMode(Wrapland::Client::SubSurface::Mode::Desynchronized); - auto sub2 = m_subCompositor->createSubSurface(grandChild.get(), child.get()); + auto sub2 = m_subCompositor->createSubSurface(*grandChild, *child); sub2->setMode(Wrapland::Client::SubSurface::Mode::Desynchronized); // let's damage this surface diff --git a/src/client/subcompositor.cpp b/src/client/subcompositor.cpp index 5716d566..84afb203 100644 --- a/src/client/subcompositor.cpp +++ b/src/client/subcompositor.cpp @@ -60,13 +60,13 @@ void SubCompositor::setup(wl_subcompositor* subcompositor) d->subCompositor.setup(subcompositor); } -SubSurface* SubCompositor::createSubSurface(QPointer surface, - QPointer parentSurface, +SubSurface* SubCompositor::createSubSurface(Surface const& surface, + Surface const& parentSurface, QObject* parent) { Q_ASSERT(isValid()); SubSurface* s = new SubSurface(surface, parentSurface, parent); - auto w = wl_subcompositor_get_subsurface(d->subCompositor, *surface, *parentSurface); + auto w = wl_subcompositor_get_subsurface(d->subCompositor, surface, parentSurface); if (d->queue) { d->queue->addProxy(w); } diff --git a/src/client/subcompositor.h b/src/client/subcompositor.h index b6c6bf67..6f0fb61b 100644 --- a/src/client/subcompositor.h +++ b/src/client/subcompositor.h @@ -21,7 +21,6 @@ License along with this library. If not, see . #define WAYLAND_SUBCOMPOSITOR_H #include -#include // STD #include #include @@ -85,8 +84,8 @@ class WRAPLANDCLIENT_EXPORT SubCompositor : public QObject * @param parent The parent to pass to the Surface. * @returns The new created Surface **/ - SubSurface* createSubSurface(QPointer surface, - QPointer parentSurface, + SubSurface* createSubSurface(Surface const& surface, + Surface const& parentSurface, QObject* parent = nullptr); operator wl_subcompositor*(); diff --git a/src/client/subsurface.cpp b/src/client/subsurface.cpp index 125a9c3c..ef800f28 100644 --- a/src/client/subsurface.cpp +++ b/src/client/subsurface.cpp @@ -21,6 +21,7 @@ License along with this library. If not, see . #include "surface.h" #include "wayland_pointer_p.h" // Wayland +#include #include namespace Wrapland @@ -31,12 +32,12 @@ namespace Client class Q_DECL_HIDDEN SubSurface::Private { public: - Private(QPointer surface, QPointer parentSurface, SubSurface* q); + Private(Surface const& surface, Surface const& parentSurface, SubSurface* q); void setup(wl_subsurface* subsurface); WaylandPointer subSurface; - QPointer surface; - QPointer parentSurface; + gsl::not_null surface; + gsl::not_null parentSurface; Mode mode = Mode::Synchronized; QPoint pos = QPoint(0, 0); @@ -46,11 +47,9 @@ class Q_DECL_HIDDEN SubSurface::Private SubSurface* q; }; -SubSurface::Private::Private(QPointer surface, - QPointer parentSurface, - SubSurface* q) - : surface(surface) - , parentSurface(parentSurface) +SubSurface::Private::Private(Surface const& surface, Surface const& parentSurface, SubSurface* q) + : surface(&surface) + , parentSurface(&parentSurface) , q(q) { } @@ -68,7 +67,7 @@ SubSurface* SubSurface::Private::cast(wl_subsurface* native) return reinterpret_cast(wl_subsurface_get_user_data(native))->q; } -SubSurface::SubSurface(QPointer surface, QPointer parentSurface, QObject* parent) +SubSurface::SubSurface(Surface const& surface, Surface const& parentSurface, QObject* parent) : QObject(parent) , d(new Private(surface, parentSurface, this)) { @@ -94,14 +93,14 @@ bool SubSurface::isValid() const return d->subSurface.isValid(); } -QPointer SubSurface::surface() const +Surface const& SubSurface::surface() const { - return d->surface; + return *d->surface.get(); } -QPointer SubSurface::parentSurface() const +Surface const& SubSurface::parentSurface() const { - return d->parentSurface; + return *d->parentSurface.get(); } void SubSurface::setMode(SubSurface::Mode mode) @@ -141,49 +140,37 @@ QPoint SubSurface::position() const void SubSurface::raise() { - placeAbove(d->parentSurface); + placeAbove(*d->parentSurface.get()); } -void SubSurface::placeAbove(QPointer sibling) +void SubSurface::placeAbove(SubSurface const& sibling) { - if (sibling.isNull()) { - return; - } - placeAbove(sibling->surface()); + placeAbove(sibling.surface()); } -void SubSurface::placeAbove(QPointer sibling) +void SubSurface::placeAbove(Surface const& sibling) { - if (sibling.isNull()) { - return; - } - wl_subsurface_place_above(d->subSurface, *sibling); + wl_subsurface_place_above(d->subSurface, sibling); } void SubSurface::lower() { - placeBelow(d->parentSurface); + placeBelow(*d->parentSurface.get()); } -void SubSurface::placeBelow(QPointer sibling) +void SubSurface::placeBelow(Surface const& sibling) { - if (sibling.isNull()) { - return; - } - wl_subsurface_place_below(d->subSurface, *sibling); + wl_subsurface_place_below(d->subSurface, sibling); } -void SubSurface::placeBelow(QPointer sibling) +void SubSurface::placeBelow(SubSurface const& sibling) { - if (sibling.isNull()) { - return; - } - placeBelow(sibling->surface()); + placeBelow(sibling.surface()); } -QPointer SubSurface::get(wl_subsurface* native) +SubSurface const* SubSurface::get(wl_subsurface* native) { - return QPointer(Private::cast(native)); + return static_cast(Private::cast(native)); } SubSurface::operator wl_subsurface*() const diff --git a/src/client/subsurface.h b/src/client/subsurface.h index 660a2c33..3132c865 100644 --- a/src/client/subsurface.h +++ b/src/client/subsurface.h @@ -58,8 +58,8 @@ class WRAPLANDCLIENT_EXPORT SubSurface : public QObject { Q_OBJECT public: - explicit SubSurface(QPointer surface, - QPointer parentSurface, + explicit SubSurface(Surface const& surface, + Surface const& parentSurface, QObject* parent = nullptr); virtual ~SubSurface(); @@ -118,7 +118,7 @@ class WRAPLANDCLIENT_EXPORT SubSurface : public QObject * The change is only applied after the parent surface got committed. * @param sibling The SubSurface on top of which this SubSurface should be placed **/ - void placeAbove(QPointer sibling); + void placeAbove(SubSurface const& sibling); /** * Places the SubSurface above the @p referenceSurface. * @@ -129,7 +129,7 @@ class WRAPLANDCLIENT_EXPORT SubSurface : public QObject * The change is only applied after the parent surface got committed. * @param referenceSurface Either a sibling or parent Surface **/ - void placeAbove(QPointer referenceSurface); + void placeAbove(Surface const& referenceSurface); /** * Lowers this SubSurface below all siblings. @@ -146,7 +146,7 @@ class WRAPLANDCLIENT_EXPORT SubSurface : public QObject * The change is only applied after the parent surface got committed. * @param sibling The SubSurface under which the SubSurface should be put **/ - void placeBelow(QPointer sibling); + void placeBelow(SubSurface const& sibling); /** * Places the SubSurface below the @p referenceSurface. * @@ -157,18 +157,18 @@ class WRAPLANDCLIENT_EXPORT SubSurface : public QObject * The change is only applied after the parent surface got committed. * @param referenceSurface Either a sibling or parent Surface **/ - void placeBelow(QPointer referenceSurface); + void placeBelow(Surface const& referenceSurface); /** * @returns The Surface for which this SubSurface got created. **/ - QPointer surface() const; + Surface const& surface() const; /** * @returns The parent Surface of this SubSurface. **/ - QPointer parentSurface() const; + Surface const& parentSurface() const; - static QPointer get(wl_subsurface* native); + static SubSurface const* get(wl_subsurface* native); operator wl_subsurface*(); operator wl_subsurface*() const; diff --git a/tests/subsurfacetest.cpp b/tests/subsurfacetest.cpp index 1b2da871..75c4a26b 100644 --- a/tests/subsurfacetest.cpp +++ b/tests/subsurfacetest.cpp @@ -146,7 +146,7 @@ void SubSurfaceTest::setupRegistry(Registry* registry) // create the sub surface auto surface = m_compositor->createSurface(this); Q_ASSERT(surface); - auto subsurface = m_subCompositor->createSubSurface(surface, m_surface, this); + auto subsurface = m_subCompositor->createSubSurface(*surface, *m_surface, this); Q_ASSERT(subsurface); QImage image(QSize(100, 100), QImage::Format_ARGB32_Premultiplied); image.fill(Qt::red); @@ -156,7 +156,7 @@ void SubSurfaceTest::setupRegistry(Registry* registry) // and another sub-surface to the sub-surface auto surface2 = m_compositor->createSurface(this); Q_ASSERT(surface2); - auto subsurface2 = m_subCompositor->createSubSurface(surface2, surface, this); + auto subsurface2 = m_subCompositor->createSubSurface(*surface2, *surface, this); Q_ASSERT(subsurface2); QImage green(QSize(50, 50), QImage::Format_ARGB32_Premultiplied); green.fill(Qt::green);