From db602b8188296c612e5bb56fdb79441facec28f9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20Gr=C3=A4=C3=9Flin?= Date: Fri, 17 Jun 2016 15:54:00 +0200 Subject: [PATCH] [server] Ensure that Resource::Private::get returns nullptr if passed a nullptr Summary: A Resource might be unbound, but not yet destroyed. In that case this return a Resource instead of nullptr. This change adds an explicit nullptr check. Reviewers: #plasma_on_wayland Subscribers: plasma-devel Tags: #plasma_on_wayland Differential Revision: https://phabricator.kde.org/D1938 --- src/wayland/autotests/client/test_wayland_surface.cpp | 7 +++++++ src/wayland/server/resource_p.h | 3 +++ 2 files changed, 10 insertions(+) diff --git a/src/wayland/autotests/client/test_wayland_surface.cpp b/src/wayland/autotests/client/test_wayland_surface.cpp index 404501494f..669288274d 100644 --- a/src/wayland/autotests/client/test_wayland_surface.cpp +++ b/src/wayland/autotests/client/test_wayland_surface.cpp @@ -178,6 +178,8 @@ void TestWaylandSurface::testStaticAccessor() QSignalSpy serverSurfaceCreated(m_compositorInterface, SIGNAL(surfaceCreated(KWayland::Server::SurfaceInterface*))); QVERIFY(serverSurfaceCreated.isValid()); + QVERIFY(!KWayland::Server::SurfaceInterface::get(nullptr)); + QVERIFY(!KWayland::Server::SurfaceInterface::get(1, nullptr)); QVERIFY(KWayland::Client::Surface::all().isEmpty()); KWayland::Client::Surface *s1 = m_compositor->createSurface(); QVERIFY(s1->isValid()); @@ -226,6 +228,11 @@ void TestWaylandSurface::testStaticAccessor() delete s1; QVERIFY(KWayland::Client::Surface::all().isEmpty()); QVERIFY(!KWayland::Client::Surface::get(nullptr)); + QSignalSpy unboundSpy(serverSurface1, &KWayland::Server::Resource::unbound); + QVERIFY(unboundSpy.isValid()); + QVERIFY(unboundSpy.wait()); + QVERIFY(!KWayland::Server::SurfaceInterface::get(nullptr)); + QVERIFY(!KWayland::Server::SurfaceInterface::get(1, nullptr)); } void TestWaylandSurface::testDamage() diff --git a/src/wayland/server/resource_p.h b/src/wayland/server/resource_p.h index 4ecda0bdc2..34ca5c5b6e 100644 --- a/src/wayland/server/resource_p.h +++ b/src/wayland/server/resource_p.h @@ -44,6 +44,9 @@ public: static ResourceDerived *get(wl_resource *native) { static_assert(std::is_base_of::value, "ResourceDerived must be derived from Resource"); + if (!native) { + return nullptr; + } auto it = std::find_if(s_allResources.constBegin(), s_allResources.constEnd(), [native](Private *p) { return p->resource == native;