migrate Contrast to new approach

This commit is contained in:
Adrien Faveraux 2020-07-09 09:59:41 +02:00 committed by Vlad Zahorodnii
parent efdc6e44ee
commit 095edbed4c
5 changed files with 82 additions and 149 deletions

View file

@ -133,7 +133,7 @@ ecm_add_qtwayland_server_protocol(SERVER_LIB_SRCS
BASENAME blur BASENAME blur
) )
ecm_add_wayland_server_protocol(SERVER_LIB_SRCS ecm_add_qtwayland_server_protocol(SERVER_LIB_SRCS
PROTOCOL ${PLASMA_WAYLAND_PROTOCOLS_DIR}/contrast.xml PROTOCOL ${PLASMA_WAYLAND_PROTOCOLS_DIR}/contrast.xml
BASENAME contrast BASENAME contrast
) )

View file

@ -107,8 +107,6 @@ void TestContrast::init()
m_compositor = registry.createCompositor(compositorSpy.first().first().value<quint32>(), compositorSpy.first().last().value<quint32>(), this); m_compositor = registry.createCompositor(compositorSpy.first().first().value<quint32>(), compositorSpy.first().last().value<quint32>(), this);
m_contrastManagerInterface = m_display->createContrastManager(m_display); m_contrastManagerInterface = m_display->createContrastManager(m_display);
m_contrastManagerInterface->create();
QVERIFY(m_contrastManagerInterface->isValid());
QVERIFY(contrastSpy.wait()); QVERIFY(contrastSpy.wait());
m_contrastManager = registry.createContrastManager(contrastSpy.first().first().value<quint32>(), contrastSpy.first().last().value<quint32>(), this); m_contrastManager = registry.createContrastManager(contrastSpy.first().first().value<quint32>(), contrastSpy.first().last().value<quint32>(), this);

View file

@ -7,122 +7,76 @@
#include "contrast_interface.h" #include "contrast_interface.h"
#include "region_interface.h" #include "region_interface.h"
#include "display.h" #include "display.h"
#include "global_p.h"
#include "resource_p.h"
#include "surface_interface_p.h" #include "surface_interface_p.h"
#include <wayland-server.h> #include <wayland-server.h>
#include <wayland-contrast-server-protocol.h> #include <qwayland-server-contrast.h>
namespace KWaylandServer namespace KWaylandServer
{ {
class ContrastManagerInterface::Private : public Global::Private class ContrastManagerInterfacePrivate : public QtWaylandServer::org_kde_kwin_contrast_manager
{ {
public: public:
Private(ContrastManagerInterface *q, Display *d); ContrastManagerInterfacePrivate(ContrastManagerInterface *_q, Display *display);
~ContrastManagerInterfacePrivate() = default;
private: private:
void bind(wl_client *client, uint32_t version, uint32_t id) override;
void createContrast(wl_client *client, wl_resource *resource, uint32_t id, wl_resource *surface);
static void createCallback(wl_client *client, wl_resource *resource, uint32_t id, wl_resource *surface);
static void unsetCallback(wl_client *client, wl_resource *resource, wl_resource *surface);
static void unbind(wl_resource *resource);
static Private *cast(wl_resource *r) {
auto contrastManager = reinterpret_cast<QPointer<ContrastManagerInterface>*>(wl_resource_get_user_data(r))->data();
if (contrastManager) {
return static_cast<Private*>(contrastManager->d.data());
}
return nullptr;
}
ContrastManagerInterface *q; ContrastManagerInterface *q;
static const struct org_kde_kwin_contrast_manager_interface s_interface;
static const quint32 s_version; static const quint32 s_version;
protected:
void org_kde_kwin_contrast_manager_create(Resource *resource, uint32_t id, wl_resource *surface) override;
void org_kde_kwin_contrast_manager_unset(Resource *resource, wl_resource *surface) override;
}; };
const quint32 ContrastManagerInterface::Private::s_version = 1; const quint32 ContrastManagerInterfacePrivate::s_version = 1;
#ifndef K_DOXYGEN ContrastManagerInterfacePrivate::ContrastManagerInterfacePrivate(ContrastManagerInterface *_q, Display *display)
const struct org_kde_kwin_contrast_manager_interface ContrastManagerInterface::Private::s_interface = { : QtWaylandServer::org_kde_kwin_contrast_manager(*display, s_version)
createCallback, , q(_q)
unsetCallback
};
#endif
ContrastManagerInterface::Private::Private(ContrastManagerInterface *q, Display *d)
: Global::Private(d, &org_kde_kwin_contrast_manager_interface, s_version)
, q(q)
{ {
} }
void ContrastManagerInterface::Private::bind(wl_client *client, uint32_t version, uint32_t id) void ContrastManagerInterfacePrivate::org_kde_kwin_contrast_manager_create(Resource *resource, uint32_t id, wl_resource *surface)
{
auto c = display->getConnection(client);
wl_resource *resource = c->createResource(&org_kde_kwin_contrast_manager_interface, qMin(version, s_version), id);
if (!resource) {
wl_client_post_no_memory(client);
return;
}
auto ref = new QPointer<ContrastManagerInterface>(q);//deleted in unbind
wl_resource_set_implementation(resource, &s_interface, ref, unbind);
}
void ContrastManagerInterface::Private::unbind(wl_resource *resource)
{
delete reinterpret_cast<QPointer<ContrastManagerInterface>*>(wl_resource_get_user_data(resource));
}
void ContrastManagerInterface::Private::createCallback(wl_client *client, wl_resource *resource, uint32_t id, wl_resource *surface)
{
auto m = cast(resource);
if (!m) {
return;// will happen if global is deleted
}
m->createContrast(client, resource, id, surface);
}
void ContrastManagerInterface::Private::createContrast(wl_client *client, wl_resource *resource, uint32_t id, wl_resource *surface)
{ {
SurfaceInterface *s = SurfaceInterface::get(surface); SurfaceInterface *s = SurfaceInterface::get(surface);
if (!s) { if (!s) {
wl_resource_post_error(resource->handle, 0, "Invalid surface");
return; return;
} }
ContrastInterface *contrast = new ContrastInterface(q, resource); wl_resource *contrast_resource = wl_resource_create(resource->client(), &org_kde_kwin_contrast_interface, resource->version(), id);
contrast->create(display->getConnection(client), wl_resource_get_version(resource), id); if (!contrast_resource) {
if (!contrast->resource()) { wl_client_post_no_memory(resource->client());
wl_resource_post_no_memory(resource);
delete contrast;
return; return;
} }
s->d_func()->setContrast(QPointer<ContrastInterface>(contrast)); auto contrast = new ContrastInterface(contrast_resource);
s->d_func()->setContrast(contrast);
} }
void ContrastManagerInterface::Private::unsetCallback(wl_client *client, wl_resource *resource, wl_resource *surface) void ContrastManagerInterfacePrivate::org_kde_kwin_contrast_manager_unset(Resource *resource, wl_resource *surface)
{ {
Q_UNUSED(client)
Q_UNUSED(resource)
SurfaceInterface *s = SurfaceInterface::get(surface); SurfaceInterface *s = SurfaceInterface::get(surface);
if (!s) { if (!s) {
wl_resource_post_error(resource->handle, 0, "Invalid surface");
return; return;
} }
s->d_func()->setContrast(QPointer<ContrastInterface>()); s->d_func()->setContrast(QPointer<ContrastInterface>());
} }
ContrastManagerInterface::ContrastManagerInterface(Display *display, QObject *parent) ContrastManagerInterface::ContrastManagerInterface(Display *display, QObject *parent)
: Global(new Private(this, display), parent) : QObject(parent)
, d(new ContrastManagerInterfacePrivate(this, display))
{ {
} }
ContrastManagerInterface::~ContrastManagerInterface() = default; ContrastManagerInterface::~ContrastManagerInterface() = default;
class ContrastInterface::Private : public Resource::Private class ContrastInterfacePrivate : public QtWaylandServer::org_kde_kwin_contrast
{ {
public: public:
Private(ContrastInterface *q, ContrastManagerInterface *c, wl_resource *parentResource); ContrastInterfacePrivate(ContrastInterface *_q, wl_resource *resource);
~Private(); ~ContrastInterfacePrivate() = default;
QRegion pendingRegion; QRegion pendingRegion;
QRegion currentRegion; QRegion currentRegion;
@ -134,88 +88,78 @@ public:
qreal currentSaturation; qreal currentSaturation;
private: private:
void commit(); ContrastInterface *q;
//TODO
ContrastInterface *q_func() {
return reinterpret_cast<ContrastInterface *>(q);
}
static void commitCallback(wl_client *client, wl_resource *resource); protected:
static void setRegionCallback(wl_client *client, wl_resource *resource, wl_resource *region); void org_kde_kwin_contrast_commit(Resource *resource) override;
static void setContrastCallback(wl_client *client, wl_resource *resource, wl_fixed_t contrast); void org_kde_kwin_contrast_set_region(Resource *resource, wl_resource *region) override;
static void setIntensityCallback(wl_client *client, wl_resource *resource, wl_fixed_t intensity); void org_kde_kwin_contrast_set_contrast(Resource *resource, wl_fixed_t contrast) override;
static void setSaturationCallback(wl_client *client, wl_resource *resource, wl_fixed_t saturation); void org_kde_kwin_contrast_set_intensity(Resource *resource, wl_fixed_t intensity) override;
void org_kde_kwin_contrast_set_saturation(Resource *resource, wl_fixed_t saturation) override;
void org_kde_kwin_contrast_release(Resource *resource) override;
void org_kde_kwin_contrast_destroy_resource(Resource *resource) override;
static const struct org_kde_kwin_contrast_interface s_interface;
}; };
#ifndef K_DOXYGEN void ContrastInterfacePrivate::org_kde_kwin_contrast_commit(Resource *resource)
const struct org_kde_kwin_contrast_interface ContrastInterface::Private::s_interface = {
commitCallback,
setRegionCallback,
setContrastCallback,
setIntensityCallback,
setSaturationCallback,
resourceDestroyedCallback
};
#endif
void ContrastInterface::Private::commitCallback(wl_client *client, wl_resource *resource)
{
Q_UNUSED(client)
cast<Private>(resource)->commit();
}
void ContrastInterface::Private::commit()
{ {
Q_UNUSED(resource)
currentRegion = pendingRegion; currentRegion = pendingRegion;
currentContrast = pendingContrast; currentContrast = pendingContrast;
currentIntensity = pendingIntensity; currentIntensity = pendingIntensity;
currentSaturation = pendingSaturation; currentSaturation = pendingSaturation;
} }
void ContrastInterface::Private::setRegionCallback(wl_client *client, wl_resource *resource, wl_resource *region) void ContrastInterfacePrivate::org_kde_kwin_contrast_set_region(Resource *resource, wl_resource *region)
{ {
Q_UNUSED(client) Q_UNUSED(resource)
Private *p = cast<Private>(resource);
RegionInterface *r = RegionInterface::get(region); RegionInterface *r = RegionInterface::get(region);
if (r) { if (r) {
p->pendingRegion = r->region(); pendingRegion = r->region();
} else { } else {
p->pendingRegion = QRegion(); pendingRegion = QRegion();
} }
} }
void ContrastInterface::Private::setContrastCallback(wl_client *client, wl_resource *resource, wl_fixed_t contrast) void ContrastInterfacePrivate::org_kde_kwin_contrast_set_contrast(Resource *resource, wl_fixed_t contrast)
{ {
Q_UNUSED(client) Q_UNUSED(resource)
Private *p = cast<Private>(resource); pendingContrast = wl_fixed_to_double(contrast);
p->pendingContrast = wl_fixed_to_double(contrast);
} }
void ContrastInterface::Private::setIntensityCallback(wl_client *client, wl_resource *resource, wl_fixed_t intensity) void ContrastInterfacePrivate::org_kde_kwin_contrast_set_intensity(Resource *resource, wl_fixed_t intensity)
{ {
Q_UNUSED(client) Q_UNUSED(resource)
Private *p = cast<Private>(resource); pendingIntensity = wl_fixed_to_double(intensity);
p->pendingIntensity = wl_fixed_to_double(intensity);
} }
void ContrastInterface::Private::setSaturationCallback(wl_client *client, wl_resource *resource, wl_fixed_t saturation) void ContrastInterfacePrivate::org_kde_kwin_contrast_set_saturation(Resource *resource, wl_fixed_t saturation)
{ {
Q_UNUSED(client) Q_UNUSED(resource)
Private *p = cast<Private>(resource); pendingSaturation = wl_fixed_to_double(saturation);
p->pendingSaturation = wl_fixed_to_double(saturation);
} }
ContrastInterface::Private::Private(ContrastInterface *q, ContrastManagerInterface *c, wl_resource *parentResource) void ContrastInterfacePrivate::org_kde_kwin_contrast_release(Resource *resource)
: Resource::Private(q, c, parentResource, &org_kde_kwin_contrast_interface, &s_interface) {
wl_resource_destroy(resource->handle);
}
void ContrastInterfacePrivate::org_kde_kwin_contrast_destroy_resource(Resource *resource)
{
Q_UNUSED(resource)
delete q;
}
ContrastInterfacePrivate::ContrastInterfacePrivate(ContrastInterface *_q, wl_resource *resource)
: QtWaylandServer::org_kde_kwin_contrast(resource)
, q(_q)
{ {
} }
ContrastInterface::Private::~Private() = default; ContrastInterface::ContrastInterface(wl_resource *resource)
: QObject()
ContrastInterface::ContrastInterface(ContrastManagerInterface *parent, wl_resource *parentResource) , d(new ContrastInterfacePrivate(this, resource))
: Resource(new Private(this, parent, parentResource))
{ {
} }
@ -223,31 +167,22 @@ ContrastInterface::~ContrastInterface() = default;
QRegion ContrastInterface::region() const QRegion ContrastInterface::region() const
{ {
Q_D();
return d->currentRegion; return d->currentRegion;
} }
qreal ContrastInterface::contrast() const qreal ContrastInterface::contrast() const
{ {
Q_D();
return d->currentContrast; return d->currentContrast;
} }
qreal ContrastInterface::intensity() const qreal ContrastInterface::intensity() const
{ {
Q_D();
return d->currentIntensity; return d->currentIntensity;
} }
qreal ContrastInterface::saturation() const qreal ContrastInterface::saturation() const
{ {
Q_D();
return d->currentSaturation; return d->currentSaturation;
} }
ContrastInterface::Private *ContrastInterface::d_func() const
{
return reinterpret_cast<Private*>(d.data());
}
} }

View file

@ -7,17 +7,18 @@
#ifndef KWAYLAND_SERVER_CONTRAST_INTERFACE_H #ifndef KWAYLAND_SERVER_CONTRAST_INTERFACE_H
#define KWAYLAND_SERVER_CONTRAST_INTERFACE_H #define KWAYLAND_SERVER_CONTRAST_INTERFACE_H
#include "global.h"
#include "resource.h"
#include <QObject> #include <QObject>
#include <KWaylandServer/kwaylandserver_export.h> #include <KWaylandServer/kwaylandserver_export.h>
struct wl_resource;
namespace KWaylandServer namespace KWaylandServer
{ {
class Display; class Display;
class ContrastManagerInterfacePrivate;
class ContrastInterfacePrivate;
/** /**
* @brief Represents the Global for org_kde_kwin_contrast_manager interface. * @brief Represents the Global for org_kde_kwin_contrast_manager interface.
@ -28,16 +29,16 @@ class Display;
* @see SurfaceInterface * @see SurfaceInterface
* @since 5.5 * @since 5.5
**/ **/
class KWAYLANDSERVER_EXPORT ContrastManagerInterface : public Global class KWAYLANDSERVER_EXPORT ContrastManagerInterface : public QObject
{ {
Q_OBJECT Q_OBJECT
public: public:
virtual ~ContrastManagerInterface(); ~ContrastManagerInterface() override;
private: private:
explicit ContrastManagerInterface(Display *display, QObject *parent = nullptr); explicit ContrastManagerInterface(Display *display, QObject *parent = nullptr);
friend class Display; friend class Display;
class Private; QScopedPointer<ContrastManagerInterfacePrivate> d;
}; };
/** /**
@ -53,11 +54,11 @@ private:
* @see SurfaceInterface * @see SurfaceInterface
* @since 5.5 * @since 5.5
**/ **/
class KWAYLANDSERVER_EXPORT ContrastInterface : public Resource class KWAYLANDSERVER_EXPORT ContrastInterface : public QObject
{ {
Q_OBJECT Q_OBJECT
public: public:
virtual ~ContrastInterface(); ~ContrastInterface() override;
QRegion region() const; QRegion region() const;
qreal contrast() const; qreal contrast() const;
@ -65,11 +66,10 @@ public:
qreal saturation() const; qreal saturation() const;
private: private:
explicit ContrastInterface(ContrastManagerInterface *parent, wl_resource *parentResource); explicit ContrastInterface(wl_resource *resource);
friend class ContrastManagerInterface; friend class ContrastManagerInterfacePrivate;
class Private; QScopedPointer<ContrastInterfacePrivate> d;
Private *d_func() const;
}; };
} }

View file

@ -457,7 +457,7 @@ private:
friend class ShadowManagerInterface; friend class ShadowManagerInterface;
friend class BlurManagerInterfacePrivate; friend class BlurManagerInterfacePrivate;
friend class SlideManagerInterface; friend class SlideManagerInterface;
friend class ContrastManagerInterface; friend class ContrastManagerInterfacePrivate;
friend class IdleInhibitManagerUnstableV1Interface; friend class IdleInhibitManagerUnstableV1Interface;
friend class PointerConstraintsUnstableV1Interface; friend class PointerConstraintsUnstableV1Interface;
friend class SurfaceRole; friend class SurfaceRole;