kwin/src/wayland/server_decoration_interface.h
Vlad Zahorodnii 47897e249f Add ServerDecorationInterface::preferredMode()
This change adds the preferred decoration mode similar to what
XdgToplevelDecorationV1Interface has. It's needed to clean up some kwin
code.
2021-12-08 21:31:17 +02:00

131 lines
3.7 KiB
C++

/*
SPDX-FileCopyrightText: 2015 Martin Gräßlin <mgraesslin@kde.org>
SPDX-License-Identifier: LGPL-2.1-only OR LGPL-3.0-only OR LicenseRef-KDE-Accepted-LGPL
*/
#pragma once
#include <QObject>
#include <KWaylandServer/kwaylandserver_export.h>
struct wl_resource;
namespace KWaylandServer
{
class Display;
class ServerSideDecorationInterface;
class SurfaceInterface;
class ServerSideDecorationManagerInterfacePrivate;
class ServerSideDecorationInterfacePrivate;
/**
* @brief Manager to create ServerSideDecorationInterface.
*/
class KWAYLANDSERVER_EXPORT ServerSideDecorationManagerInterface : public QObject
{
Q_OBJECT
public:
explicit ServerSideDecorationManagerInterface(Display *display, QObject *parent = nullptr);
~ServerSideDecorationManagerInterface() override;
/**
* Decoration mode used for SurfaceInterfaces.
*/
enum class Mode {
/**
* Undecorated: neither client, nor server provide decoration. Example: popups.
*/
None,
/**
* The decoration is part of the surface.
*/
Client,
/**
* The surface gets embedded into a decoration frame provided by the Server.
*/
Server,
};
/**
* Sets the default @p mode which is pushed to the Clients on creating a ServerSideDecorationInterface.
* @param mode The new default mode.
* @see defaultMode
*/
void setDefaultMode(Mode mode);
/**
* @returns the current default mode.
* @see setDefaultMode
*/
Mode defaultMode() const;
Q_SIGNALS:
/**
* Emitted whenever a new ServerSideDecorationInterface is created.
*/
void decorationCreated(KWaylandServer::ServerSideDecorationInterface *);
private:
QScopedPointer<ServerSideDecorationManagerInterfacePrivate> d;
};
/**
* @brief Representing how a SurfaceInterface should be decorated.
*
* Created by ServerSideDecorationManagerInterface and emitted with decorationCreated signal.
*/
class KWAYLANDSERVER_EXPORT ServerSideDecorationInterface : public QObject
{
Q_OBJECT
public:
~ServerSideDecorationInterface() override;
/**
* Sets the @p mode on the SurfaceInterface. A client might refuse the provided @p mode,
* in that case modeRequested will be emitted.
* @see mode
* @see modeRequested
*/
void setMode(ServerSideDecorationManagerInterface::Mode mode);
/**
* @returns the currently set mode, not the requested mode.
* @see setMode
* @see modeRequested
*/
ServerSideDecorationManagerInterface::Mode mode() const;
/**
* Returns the preferred decoration mode as specified by the client.
*/
ServerSideDecorationManagerInterface::Mode preferredMode() const;
/**
* @returns The SurfaceInterface this ServerSideDecorationInterface references.
*/
SurfaceInterface *surface() const;
/**
* @returns The ServerSideDecorationInterface for the given @p surface, @c nullptr if there is none.
*/
static ServerSideDecorationInterface *get(SurfaceInterface *surface);
Q_SIGNALS:
/**
* The client requested the provided mode.
* The server needs to acknowledge the requested mode by setting it through setMode.
* @see setMode
* @see mode
*/
void preferredModeChanged();
private:
explicit ServerSideDecorationInterface(ServerSideDecorationManagerInterface *manager, SurfaceInterface *surface, wl_resource *resource);
friend class ServerSideDecorationManagerInterfacePrivate;
QScopedPointer<ServerSideDecorationInterfacePrivate> d;
};
}
Q_DECLARE_METATYPE(KWaylandServer::ServerSideDecorationInterface *)
Q_DECLARE_METATYPE(KWaylandServer::ServerSideDecorationManagerInterface::Mode)