Move slide interface to the new approach
This commit is contained in:
parent
bfc174ea58
commit
2780d0557a
4 changed files with 85 additions and 139 deletions
|
@ -144,7 +144,7 @@ ecm_add_qtwayland_server_protocol(SERVER_LIB_SRCS
|
||||||
BASENAME relative-pointer-unstable-v1
|
BASENAME relative-pointer-unstable-v1
|
||||||
)
|
)
|
||||||
|
|
||||||
ecm_add_wayland_server_protocol(SERVER_LIB_SRCS
|
ecm_add_qtwayland_server_protocol(SERVER_LIB_SRCS
|
||||||
PROTOCOL ${PLASMA_WAYLAND_PROTOCOLS_DIR}/slide.xml
|
PROTOCOL ${PLASMA_WAYLAND_PROTOCOLS_DIR}/slide.xml
|
||||||
BASENAME slide
|
BASENAME slide
|
||||||
)
|
)
|
||||||
|
|
|
@ -101,8 +101,6 @@ void TestSlide::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_slideManagerInterface = m_display->createSlideManager(m_display);
|
m_slideManagerInterface = m_display->createSlideManager(m_display);
|
||||||
m_slideManagerInterface->create();
|
|
||||||
QVERIFY(m_slideManagerInterface->isValid());
|
|
||||||
|
|
||||||
QVERIFY(slideSpy.wait());
|
QVERIFY(slideSpy.wait());
|
||||||
m_slideManager = registry.createSlideManager(slideSpy.first().first().value<quint32>(), slideSpy.first().last().value<quint32>(), this);
|
m_slideManager = registry.createSlideManager(slideSpy.first().first().value<quint32>(), slideSpy.first().last().value<quint32>(), this);
|
||||||
|
@ -128,10 +126,12 @@ void TestSlide::cleanup()
|
||||||
delete m_thread;
|
delete m_thread;
|
||||||
m_thread = nullptr;
|
m_thread = nullptr;
|
||||||
}
|
}
|
||||||
CLEANUP(m_compositorInterface)
|
|
||||||
CLEANUP(m_slideManagerInterface)
|
|
||||||
CLEANUP(m_display)
|
CLEANUP(m_display)
|
||||||
#undef CLEANUP
|
#undef CLEANUP
|
||||||
|
// these are the children of the display
|
||||||
|
m_compositorInterface = nullptr;
|
||||||
|
m_slideManagerInterface = nullptr;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void TestSlide::testCreate()
|
void TestSlide::testCreate()
|
||||||
|
|
|
@ -5,196 +5,146 @@
|
||||||
*/
|
*/
|
||||||
#include "slide_interface.h"
|
#include "slide_interface.h"
|
||||||
#include "display.h"
|
#include "display.h"
|
||||||
#include "global_p.h"
|
|
||||||
#include "surface_interface.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-slide-server-protocol.h>
|
#include <qwayland-server-slide.h>
|
||||||
|
|
||||||
namespace KWaylandServer
|
namespace KWaylandServer
|
||||||
{
|
{
|
||||||
|
|
||||||
class SlideManagerInterface::Private : public Global::Private
|
static const quint32 s_version = 1;
|
||||||
|
|
||||||
|
class SlideManagerInterfacePrivate : public QtWaylandServer::org_kde_kwin_slide_manager
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
Private(SlideManagerInterface *q, Display *d);
|
SlideManagerInterfacePrivate(SlideManagerInterface *_q, Display *display);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void bind(wl_client *client, uint32_t version, uint32_t id) override;
|
|
||||||
void createSlide(wl_client *client, wl_resource *resource, uint32_t id, wl_resource *surface);
|
|
||||||
|
|
||||||
static void unbind(wl_resource *resource);
|
|
||||||
static Private *cast(wl_resource *r) {
|
|
||||||
return reinterpret_cast<Private*>(wl_resource_get_user_data(r));
|
|
||||||
}
|
|
||||||
|
|
||||||
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);
|
|
||||||
|
|
||||||
SlideManagerInterface *q;
|
SlideManagerInterface *q;
|
||||||
static const struct org_kde_kwin_slide_manager_interface s_interface;
|
|
||||||
//initializing here doesn't link
|
protected:
|
||||||
static const quint32 s_version;
|
void org_kde_kwin_slide_manager_create(Resource *resource, uint32_t id, wl_resource *surface) override;
|
||||||
|
void org_kde_kwin_slide_manager_unset(Resource *resource, wl_resource *surface) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
const quint32 SlideManagerInterface::Private::s_version = 1;
|
void SlideManagerInterfacePrivate::org_kde_kwin_slide_manager_create(Resource *resource, uint32_t id, wl_resource *surface)
|
||||||
|
|
||||||
#ifndef K_DOXYGEN
|
|
||||||
const struct org_kde_kwin_slide_manager_interface SlideManagerInterface::Private::s_interface = {
|
|
||||||
createCallback,
|
|
||||||
unsetCallback
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void SlideManagerInterface::Private::createCallback(wl_client *client, wl_resource *resource, uint32_t id, wl_resource * surface)
|
|
||||||
{
|
|
||||||
cast(resource)->createSlide(client, resource, id, surface);
|
|
||||||
}
|
|
||||||
|
|
||||||
void SlideManagerInterface::Private::createSlide(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;
|
||||||
}
|
}
|
||||||
|
|
||||||
SlideInterface *slide = new SlideInterface(q, resource);
|
wl_resource *slide_resource = wl_resource_create(resource->client(), &org_kde_kwin_slide_interface, resource->version(), id);
|
||||||
slide->create(display->getConnection(client), wl_resource_get_version(resource), id);
|
if (!slide_resource) {
|
||||||
if (!slide->resource()) {
|
wl_client_post_no_memory(resource->client());
|
||||||
wl_resource_post_no_memory(resource);
|
|
||||||
delete slide;
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
auto slide = new SlideInterface(q, slide_resource);
|
||||||
|
|
||||||
SurfaceInterfacePrivate *surfacePrivate = SurfaceInterfacePrivate::get(s);
|
SurfaceInterfacePrivate *surfacePrivate = SurfaceInterfacePrivate::get(s);
|
||||||
surfacePrivate->setSlide(QPointer<SlideInterface>(slide));
|
surfacePrivate->setSlide(QPointer<SlideInterface>(slide));
|
||||||
}
|
}
|
||||||
|
|
||||||
void SlideManagerInterface::Private::unsetCallback(wl_client *client, wl_resource *resource, wl_resource * surface)
|
void SlideManagerInterfacePrivate::org_kde_kwin_slide_manager_unset(Resource *resource, wl_resource *surface)
|
||||||
{
|
{
|
||||||
Q_UNUSED(client)
|
SurfaceInterface *s = SurfaceInterface::get(surface);
|
||||||
Q_UNUSED(resource)
|
if (!s) {
|
||||||
Q_UNUSED(surface)
|
wl_resource_post_error(resource->handle, 0, "Invalid surface");
|
||||||
// TODO: implement
|
|
||||||
}
|
|
||||||
|
|
||||||
SlideManagerInterface::Private::Private(SlideManagerInterface *q, Display *d)
|
|
||||||
: Global::Private(d, &org_kde_kwin_slide_manager_interface, s_version)
|
|
||||||
, q(q)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
void SlideManagerInterface::Private::bind(wl_client *client, uint32_t version, uint32_t id)
|
|
||||||
{
|
|
||||||
auto c = display->getConnection(client);
|
|
||||||
wl_resource *resource = c->createResource(&org_kde_kwin_slide_manager_interface, qMin(version, s_version), id);
|
|
||||||
if (!resource) {
|
|
||||||
wl_client_post_no_memory(client);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
wl_resource_set_implementation(resource, &s_interface, this, unbind);
|
SurfaceInterfacePrivate *surfacePrivate = SurfaceInterfacePrivate::get(s);
|
||||||
// TODO: should we track?
|
surfacePrivate->setSlide(QPointer<SlideInterface>());
|
||||||
}
|
}
|
||||||
|
|
||||||
void SlideManagerInterface::Private::unbind(wl_resource *resource)
|
SlideManagerInterfacePrivate::SlideManagerInterfacePrivate(SlideManagerInterface *_q, Display *display)
|
||||||
|
: QtWaylandServer::org_kde_kwin_slide_manager(*display, s_version)
|
||||||
|
, q(_q)
|
||||||
{
|
{
|
||||||
Q_UNUSED(resource)
|
|
||||||
// TODO: implement?
|
|
||||||
}
|
}
|
||||||
|
|
||||||
SlideManagerInterface::SlideManagerInterface(Display *display, QObject *parent)
|
SlideManagerInterface::SlideManagerInterface(Display *display, QObject *parent)
|
||||||
: Global(new Private(this, display), parent)
|
: QObject(parent)
|
||||||
|
, d(new SlideManagerInterfacePrivate(this, display))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
SlideManagerInterface::~SlideManagerInterface() = default;
|
SlideManagerInterface::~SlideManagerInterface() = default;
|
||||||
|
|
||||||
class SlideInterface::Private : public Resource::Private
|
class SlideInterfacePrivate : public QtWaylandServer::org_kde_kwin_slide
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
Private(SlideInterface *q, SlideManagerInterface *c, wl_resource *parentResource);
|
SlideInterfacePrivate(SlideInterface *_q, wl_resource *resource);
|
||||||
~Private();
|
|
||||||
|
|
||||||
SlideInterface::Location pendingLocation;
|
SlideInterface::Location pendingLocation;
|
||||||
SlideInterface::Location currentLocation;
|
SlideInterface::Location currentLocation;
|
||||||
uint32_t pendingOffset;
|
uint32_t pendingOffset;
|
||||||
uint32_t currentOffset;
|
uint32_t currentOffset;
|
||||||
|
SlideInterface *q;
|
||||||
|
|
||||||
private:
|
protected:
|
||||||
static void commitCallback(wl_client *client, wl_resource *resource);
|
void org_kde_kwin_slide_commit(Resource *resource) override;
|
||||||
static void setLocationCallback(wl_client *client, wl_resource *resource, uint32_t location);
|
void org_kde_kwin_slide_set_location(Resource *resource, uint32_t location) override;
|
||||||
static void setOffsetCallback(wl_client *client, wl_resource *resource, int32_t offset);
|
void org_kde_kwin_slide_set_offset(Resource *resource, int32_t offset) override;
|
||||||
|
void org_kde_kwin_slide_release(Resource *resource) override;
|
||||||
SlideInterface *q_func() {
|
void org_kde_kwin_slide_destroy_resource(Resource *resource) override;
|
||||||
return reinterpret_cast<SlideInterface *>(q);
|
|
||||||
}
|
|
||||||
|
|
||||||
static const struct org_kde_kwin_slide_interface s_interface;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifndef K_DOXYGEN
|
void SlideInterfacePrivate::org_kde_kwin_slide_commit(Resource *resource)
|
||||||
const struct org_kde_kwin_slide_interface SlideInterface::Private::s_interface = {
|
|
||||||
commitCallback,
|
|
||||||
setLocationCallback,
|
|
||||||
setOffsetCallback,
|
|
||||||
resourceDestroyedCallback
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void SlideInterface::Private::commitCallback(wl_client *client, wl_resource *resource)
|
|
||||||
{
|
{
|
||||||
Q_UNUSED(client)
|
Q_UNUSED(resource)
|
||||||
Private *p = cast<Private>(resource);
|
currentLocation = pendingLocation;
|
||||||
p->currentLocation = p->pendingLocation;
|
currentOffset = pendingOffset;
|
||||||
p->currentOffset = p->pendingOffset;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void SlideInterface::Private::setLocationCallback(wl_client *client, wl_resource *resource, uint32_t location)
|
void SlideInterfacePrivate::org_kde_kwin_slide_set_location(Resource *resource, uint32_t location)
|
||||||
{
|
{
|
||||||
Q_UNUSED(client)
|
Q_UNUSED(resource)
|
||||||
Private *p = cast<Private>(resource);
|
pendingLocation = (SlideInterface::Location)location;
|
||||||
p->pendingLocation = (SlideInterface::Location)location;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void SlideInterface::Private::setOffsetCallback(wl_client *client, wl_resource *resource, int32_t offset)
|
void SlideInterfacePrivate::org_kde_kwin_slide_set_offset(Resource *resource, int32_t offset)
|
||||||
{
|
{
|
||||||
Q_UNUSED(client)
|
Q_UNUSED(resource)
|
||||||
Private *p = cast<Private>(resource);
|
pendingOffset = offset;
|
||||||
p->pendingOffset = offset;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
SlideInterface::Private::Private(SlideInterface *q, SlideManagerInterface *c, wl_resource *parentResource)
|
void SlideInterfacePrivate::org_kde_kwin_slide_release(Resource *resource)
|
||||||
: Resource::Private(q, c, parentResource, &org_kde_kwin_slide_interface, &s_interface)
|
{
|
||||||
|
wl_resource_destroy(resource->handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
void SlideInterfacePrivate::org_kde_kwin_slide_destroy_resource(Resource *resource)
|
||||||
|
{
|
||||||
|
Q_UNUSED(resource)
|
||||||
|
delete q;
|
||||||
|
}
|
||||||
|
|
||||||
|
SlideInterfacePrivate::SlideInterfacePrivate(SlideInterface *_q, wl_resource *resource)
|
||||||
|
: QtWaylandServer::org_kde_kwin_slide(resource)
|
||||||
|
, q(_q)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
SlideInterface::Private::~Private() = default;
|
SlideInterface::SlideInterface(SlideManagerInterface *manager, wl_resource *resource)
|
||||||
|
: QObject(manager)
|
||||||
SlideInterface::SlideInterface(SlideManagerInterface *parent, wl_resource *parentResource)
|
, d(new SlideInterfacePrivate(this, resource))
|
||||||
: Resource(new Private(this, parent, parentResource))
|
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
SlideInterface::~SlideInterface() = default;
|
SlideInterface::~SlideInterface() = default;
|
||||||
|
|
||||||
|
|
||||||
SlideInterface::Location SlideInterface::location() const
|
SlideInterface::Location SlideInterface::location() const
|
||||||
{
|
{
|
||||||
Q_D();
|
|
||||||
return d->currentLocation;
|
return d->currentLocation;
|
||||||
}
|
}
|
||||||
|
|
||||||
qint32 SlideInterface::offset() const
|
qint32 SlideInterface::offset() const
|
||||||
{
|
{
|
||||||
Q_D();
|
|
||||||
return d->currentOffset;
|
return d->currentOffset;
|
||||||
}
|
}
|
||||||
|
|
||||||
SlideInterface::Private *SlideInterface::d_func() const
|
|
||||||
{
|
|
||||||
return reinterpret_cast<Private*>(d.data());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,46 +6,43 @@
|
||||||
#ifndef KWAYLAND_SERVER_SLIDE_INTERFACE_H
|
#ifndef KWAYLAND_SERVER_SLIDE_INTERFACE_H
|
||||||
#define KWAYLAND_SERVER_SLIDE_INTERFACE_H
|
#define KWAYLAND_SERVER_SLIDE_INTERFACE_H
|
||||||
|
|
||||||
#include "global.h"
|
#include <QObject>
|
||||||
#include "resource.h"
|
|
||||||
|
|
||||||
#include <KWaylandServer/kwaylandserver_export.h>
|
#include <KWaylandServer/kwaylandserver_export.h>
|
||||||
|
|
||||||
|
struct wl_resource;
|
||||||
|
|
||||||
namespace KWaylandServer
|
namespace KWaylandServer
|
||||||
{
|
{
|
||||||
|
|
||||||
class Display;
|
class Display;
|
||||||
|
class SlideManagerInterfacePrivate;
|
||||||
|
class SlideInterfacePrivate;
|
||||||
|
|
||||||
/**
|
class KWAYLANDSERVER_EXPORT SlideManagerInterface : public QObject
|
||||||
* TODO
|
|
||||||
*/
|
|
||||||
class KWAYLANDSERVER_EXPORT SlideManagerInterface : public Global
|
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
virtual ~SlideManagerInterface();
|
~SlideManagerInterface() override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
explicit SlideManagerInterface(Display *display, QObject *parent = nullptr);
|
explicit SlideManagerInterface(Display *display, QObject *parent = nullptr);
|
||||||
friend class Display;
|
friend class Display;
|
||||||
class Private;
|
QScopedPointer<SlideManagerInterfacePrivate> d;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
class KWAYLANDSERVER_EXPORT SlideInterface : public QObject
|
||||||
* TODO
|
|
||||||
*/
|
|
||||||
class KWAYLANDSERVER_EXPORT SlideInterface : public Resource
|
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
enum Location {
|
enum Location {
|
||||||
Left = 0, /**< Slide from the left edge of the screen */
|
Left = 0, /**< Slide from the left edge of the screen */
|
||||||
Top, /**< Slide from the top edge of the screen */
|
Top = 1, /**< Slide from the top edge of the screen */
|
||||||
Right, /**< Slide from the bottom edge of the screen */
|
Right = 2, /**< Slide from the bottom edge of the screen */
|
||||||
Bottom /**< Slide from the bottom edge of the screen */
|
Bottom = 3 /**< Slide from the bottom edge of the screen */
|
||||||
};
|
};
|
||||||
|
|
||||||
virtual ~SlideInterface();
|
~SlideInterface() override;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @returns the location the window will be slided from
|
* @returns the location the window will be slided from
|
||||||
|
@ -59,11 +56,10 @@ public:
|
||||||
qint32 offset() const;
|
qint32 offset() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
explicit SlideInterface(SlideManagerInterface *parent, wl_resource *parentResource);
|
explicit SlideInterface(SlideManagerInterface *manager, wl_resource *resource);
|
||||||
friend class SlideManagerInterface;
|
friend class SlideManagerInterfacePrivate;
|
||||||
|
|
||||||
class Private;
|
QScopedPointer<SlideInterfacePrivate> d;
|
||||||
Private *d_func() const;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue