migrate Contrast to new approach
This commit is contained in:
parent
efdc6e44ee
commit
095edbed4c
5 changed files with 82 additions and 149 deletions
|
@ -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
|
||||||
)
|
)
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue