8da9a184ed
Summary: This commit adds an interface bridge from KWin to KRfb. The purpose of this protocol is to pass a GBM fd of currently displayed buffer from KWin. The buffer is expected to be fully drawn once it is passed. Related to D1230 Test Plan: ********* Start testing of RemoteAccessTest ********* Config: Using QtTest library 5.6.0, Qt 5.6.0 (x86_64-little_endian-lp64 shared (dynamic) release build; by GCC 6.1.1 20160501) PASS : RemoteAccessTest::initTestCase() QDEBUG : RemoteAccessTest::testSendReleaseSingle() kwayland-client: Connected to Wayland server at: "kwayland-test-remote-access-0" QDEBUG : RemoteAccessTest::testSendReleaseSingle() kwayland-client: Wayland Interface: wl_shm / 1 / 1 QDEBUG : RemoteAccessTest::testSendReleaseSingle() kwayland-client: Wayland Interface: org_kde_kwin_remote_access_manager / 2 / 1 QDEBUG : RemoteAccessTest::testSendReleaseSingle() kwayland-server: Server buffer sent: fd 15 QDEBUG : RemoteAccessTest::testSendReleaseSingle() kwayland-client: Got buffer, server fd: 15 QDEBUG : RemoteAccessTest::testSendReleaseSingle() kwayland-server: Remote buffer returned, client 4 , id 0 , fd 15 QDEBUG : RemoteAccessTest::testSendReleaseSingle() kwayland-server: Buffer released, fd 15 QDEBUG : RemoteAccessTest::testSendReleaseSingle() kwayland-client: Buffer released PASS : RemoteAccessTest::testSendReleaseSingle() QDEBUG : RemoteAccessTest::testSendReleaseMultiple() kwayland-client: Connected to Wayland server at: "kwayland-test-remote-access-0" QDEBUG : RemoteAccessTest::testSendReleaseMultiple() kwayland-client: Wayland Interface: wl_shm / 1 / 1 QDEBUG : RemoteAccessTest::testSendReleaseMultiple() kwayland-client: Wayland Interface: org_kde_kwin_remote_access_manager / 2 / 1 QDEBUG : RemoteAccessTest::testSendReleaseMultiple() kwayland-server: Server buffer sent: fd 15 QDEBUG : RemoteAccessTest::testSendReleaseMultiple() kwayland-client: Got buffer, server fd: 15 QDEBUG : RemoteAccessTest::testSendReleaseMultiple() kwayland-client: Got buffer, server fd: 15 QDEBUG : RemoteAccessTest::testSendReleaseMultiple() kwayland-server: Remote buffer returned, client 4 , id 0 , fd 15 QDEBUG : RemoteAccessTest::testSendReleaseMultiple() kwayland-server: Remote buffer returned, client 5 , id 0 , fd 15 QDEBUG : RemoteAccessTest::testSendReleaseMultiple() kwayland-server: Buffer released, fd 15 QDEBUG : RemoteAccessTest::testSendReleaseMultiple() kwayland-client: Buffer released QDEBUG : RemoteAccessTest::testSendReleaseMultiple() kwayland-client: Buffer released PASS : RemoteAccessTest::testSendReleaseMultiple() QDEBUG : RemoteAccessTest::testSendClientGone() kwayland-client: Connected to Wayland server at: "kwayland-test-remote-access-0" QDEBUG : RemoteAccessTest::testSendClientGone() kwayland-client: Wayland Interface: wl_shm / 1 / 1 QDEBUG : RemoteAccessTest::testSendClientGone() kwayland-client: Wayland Interface: org_kde_kwin_remote_access_manager / 2 / 1 QDEBUG : RemoteAccessTest::testSendClientGone() kwayland-server: Server buffer sent: fd 15 QDEBUG : RemoteAccessTest::testSendClientGone() kwayland-server: Buffer released, fd 15 PASS : RemoteAccessTest::testSendClientGone() QDEBUG : RemoteAccessTest::testSendReceiveClientGone() kwayland-client: Connected to Wayland server at: "kwayland-test-remote-access-0" QDEBUG : RemoteAccessTest::testSendReceiveClientGone() kwayland-client: Wayland Interface: wl_shm / 1 / 1 QDEBUG : RemoteAccessTest::testSendReceiveClientGone() kwayland-client: Wayland Interface: org_kde_kwin_remote_access_manager / 2 / 1 QDEBUG : RemoteAccessTest::testSendReceiveClientGone() kwayland-server: Server buffer sent: fd 15 QDEBUG : RemoteAccessTest::testSendReceiveClientGone() kwayland-client: Got buffer, server fd: 15 QDEBUG : RemoteAccessTest::testSendReceiveClientGone() kwayland-client: Buffer released QDEBUG : RemoteAccessTest::testSendReceiveClientGone() kwayland-server: Buffer released, fd 15 PASS : RemoteAccessTest::testSendReceiveClientGone() PASS : RemoteAccessTest::cleanupTestCase() Totals: 6 passed, 0 failed, 0 skipped, 0 blacklisted ********* Finished testing of RemoteAccessTest ********* Reviewers: graesslin, davidedmundson, romangg Reviewed By: davidedmundson, romangg Subscribers: jtamate, jgrulich, romangg, ngraham, alexeymin, #frameworks, davidedmundson, plasma-devel Tags: #plasma_on_wayland, #frameworks Maniphest Tasks: T5653, T7785 Differential Revision: https://phabricator.kde.org/D1231
303 lines
11 KiB
C++
303 lines
11 KiB
C++
/********************************************************************
|
|
Copyright 2014 Martin Gräßlin <mgraesslin@kde.org>
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2.1 of the License, or (at your option) version 3, or any
|
|
later version accepted by the membership of KDE e.V. (or its
|
|
successor approved by the membership of KDE e.V.), which shall
|
|
act as a proxy defined in Section 6 of version 3 of the license.
|
|
|
|
This library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
*********************************************************************/
|
|
#ifndef WAYLAND_SERVER_DISPLAY_H
|
|
#define WAYLAND_SERVER_DISPLAY_H
|
|
|
|
#include <QList>
|
|
#include <QObject>
|
|
|
|
#include <KWayland/Server/kwaylandserver_export.h>
|
|
|
|
#include "clientconnection.h"
|
|
|
|
struct wl_client;
|
|
struct wl_display;
|
|
struct wl_event_loop;
|
|
|
|
namespace KWayland
|
|
{
|
|
/**
|
|
* @short KWayland Server.
|
|
*
|
|
* This namespace groups all classes related to the Server module.
|
|
*
|
|
* The main entry point into the KWayland::Server API is the Display class.
|
|
* It allows to create a Wayland server and create various global objects on it.
|
|
*
|
|
* KWayland::Server is an API to easily create a head-less Wayland server with a
|
|
* Qt style API.
|
|
*
|
|
* @see Display
|
|
**/
|
|
namespace Server
|
|
{
|
|
|
|
class CompositorInterface;
|
|
class DataDeviceManagerInterface;
|
|
class DpmsManagerInterface;
|
|
class IdleInterface;
|
|
enum class IdleInhibitManagerInterfaceVersion;
|
|
class RemoteAccessManagerInterface;
|
|
class IdleInhibitManagerInterface;
|
|
class FakeInputInterface;
|
|
class OutputInterface;
|
|
class OutputDeviceInterface;
|
|
class OutputConfigurationInterface;
|
|
class OutputManagementInterface;
|
|
class PlasmaShellInterface;
|
|
class PlasmaWindowManagementInterface;
|
|
class QtSurfaceExtensionInterface;
|
|
class SeatInterface;
|
|
class ShadowManagerInterface;
|
|
class BlurManagerInterface;
|
|
class ContrastManagerInterface;
|
|
class ServerSideDecorationManagerInterface;
|
|
class SlideManagerInterface;
|
|
class ShellInterface;
|
|
class SubCompositorInterface;
|
|
enum class TextInputInterfaceVersion;
|
|
class TextInputManagerInterface;
|
|
class XdgShellV5Interface;
|
|
enum class XdgShellInterfaceVersion;
|
|
class XdgShellInterface;
|
|
enum class RelativePointerInterfaceVersion;
|
|
class RelativePointerManagerInterface;
|
|
enum class PointerGesturesInterfaceVersion;
|
|
class PointerGesturesInterface;
|
|
enum class PointerConstraintsInterfaceVersion;
|
|
class PointerConstraintsInterface;
|
|
class XdgForeignInterface;
|
|
class AppMenuManagerInterface;
|
|
class ServerSideDecorationPaletteManagerInterface;
|
|
|
|
/**
|
|
* @brief Class holding the Wayland server display loop.
|
|
*
|
|
* @todo Improve documentation
|
|
**/
|
|
class KWAYLANDSERVER_EXPORT Display : public QObject
|
|
{
|
|
Q_OBJECT
|
|
Q_PROPERTY(QString socketName READ socketName WRITE setSocketName NOTIFY socketNameChanged)
|
|
Q_PROPERTY(bool running READ isRunning NOTIFY runningChanged)
|
|
public:
|
|
explicit Display(QObject *parent = nullptr);
|
|
virtual ~Display();
|
|
|
|
void setSocketName(const QString &name);
|
|
QString socketName() const;
|
|
|
|
quint32 serial();
|
|
quint32 nextSerial();
|
|
|
|
/**
|
|
* How to setup the server connection.
|
|
* @li ConnectToSocket: the server will open the socket identified by the socket name
|
|
* @li ConnectClientsOnly: only connections through createClient are possible
|
|
**/
|
|
enum class StartMode {
|
|
ConnectToSocket,
|
|
ConnectClientsOnly
|
|
};
|
|
void start(StartMode mode = StartMode::ConnectToSocket);
|
|
void terminate();
|
|
/**
|
|
* Starts the event loop for the server socket.
|
|
* This method should only be used if start() is used before creating the
|
|
* QCoreApplication. In that case start() cannot fully setup the event processing
|
|
* and the loop needs to be started after the QCoreApplication got created.
|
|
* @see start
|
|
* @see dispatchEvents
|
|
**/
|
|
void startLoop();
|
|
/**
|
|
* Dispatches pending events in a blocking way. May only be used if the Display is
|
|
* created and started before the QCoreApplication is created. Once the QCoreApplication
|
|
* is created and the event loop is started this method delegates to the normal dispatch
|
|
* handling.
|
|
* @see startLoop
|
|
**/
|
|
void dispatchEvents(int msecTimeout = -1);
|
|
|
|
/**
|
|
* Create a client for the given file descriptor.
|
|
*
|
|
* The client is created as if it connected through the normal server
|
|
* socket. This method can be used to create a connection bypassing the
|
|
* normal socket connection. It's recommended to use together with
|
|
* socketpair and pass the other side of the socket to the client.
|
|
*
|
|
* @param fd The file descriptor for the socket to the client
|
|
* @returns The new ClientConnection or @c null on failure.
|
|
**/
|
|
ClientConnection *createClient(int fd);
|
|
|
|
operator wl_display*();
|
|
operator wl_display*() const;
|
|
bool isRunning() const;
|
|
|
|
OutputInterface *createOutput(QObject *parent = nullptr);
|
|
void removeOutput(OutputInterface *output);
|
|
QList<OutputInterface*> outputs() const;
|
|
|
|
OutputDeviceInterface *createOutputDevice(QObject *parent = nullptr);
|
|
void removeOutputDevice(OutputDeviceInterface *output);
|
|
QList<OutputDeviceInterface*> outputDevices() const;
|
|
|
|
CompositorInterface *createCompositor(QObject *parent = nullptr);
|
|
void createShm();
|
|
ShellInterface *createShell(QObject *parent = nullptr);
|
|
SeatInterface *createSeat(QObject *parent = nullptr);
|
|
/**
|
|
* @returns All SeatInterface currently managed on the Display.
|
|
* @since 5.6
|
|
**/
|
|
QVector<SeatInterface*> seats() const;
|
|
SubCompositorInterface *createSubCompositor(QObject *parent = nullptr);
|
|
DataDeviceManagerInterface *createDataDeviceManager(QObject *parent = nullptr);
|
|
OutputManagementInterface *createOutputManagement(QObject *parent = nullptr);
|
|
PlasmaShellInterface *createPlasmaShell(QObject *parent = nullptr);
|
|
PlasmaWindowManagementInterface *createPlasmaWindowManagement(QObject *parent = nullptr);
|
|
QtSurfaceExtensionInterface *createQtSurfaceExtension(QObject *parent = nullptr);
|
|
IdleInterface *createIdle(QObject *parent = nullptr);
|
|
RemoteAccessManagerInterface *createRemoteAccessManager(QObject *parent = nullptr);
|
|
FakeInputInterface *createFakeInput(QObject *parent = nullptr);
|
|
ShadowManagerInterface *createShadowManager(QObject *parent = nullptr);
|
|
BlurManagerInterface *createBlurManager(QObject *parent = nullptr);
|
|
ContrastManagerInterface *createContrastManager(QObject *parent = nullptr);
|
|
SlideManagerInterface *createSlideManager(QObject *parent = nullptr);
|
|
DpmsManagerInterface *createDpmsManager(QObject *parent = nullptr);
|
|
/**
|
|
* @since 5.6
|
|
**/
|
|
ServerSideDecorationManagerInterface *createServerSideDecorationManager(QObject *parent = nullptr);
|
|
/**
|
|
* Create the text input manager in interface @p version.
|
|
* @returns The created manager object
|
|
* @since 5.23
|
|
**/
|
|
TextInputManagerInterface *createTextInputManager(const TextInputInterfaceVersion &version, QObject *parent = nullptr);
|
|
|
|
/**
|
|
* Creates the XdgShell in interface @p version.
|
|
*
|
|
* @since 5.25
|
|
**/
|
|
XdgShellInterface *createXdgShell(const XdgShellInterfaceVersion &version, QObject *parent = nullptr);
|
|
|
|
/**
|
|
* Creates the RelativePointerManagerInterface in interface @p version
|
|
*
|
|
* @returns The created manager object
|
|
* @since 5.28
|
|
**/
|
|
RelativePointerManagerInterface *createRelativePointerManager(const RelativePointerInterfaceVersion &version, QObject *parent = nullptr);
|
|
|
|
/**
|
|
* Creates the PointerGesturesInterface in interface @p version
|
|
*
|
|
* @returns The created manager object
|
|
* @since 5.29
|
|
**/
|
|
PointerGesturesInterface *createPointerGestures(const PointerGesturesInterfaceVersion &version, QObject *parent = nullptr);
|
|
|
|
/**
|
|
* Creates the PointerConstraintsInterface in interface @p version
|
|
*
|
|
* @returns The created manager object
|
|
* @since 5.29
|
|
**/
|
|
PointerConstraintsInterface *createPointerConstraints(const PointerConstraintsInterfaceVersion &version, QObject *parent = nullptr);
|
|
|
|
/**
|
|
* Creates the XdgForeignInterface in interface @p version
|
|
*
|
|
* @returns The created manager object
|
|
* @since 5.40
|
|
**/
|
|
XdgForeignInterface *createXdgForeignInterface(QObject *parent = nullptr);
|
|
|
|
/**
|
|
* Creates the IdleInhibitManagerInterface in interface @p version.
|
|
*
|
|
* @returns The created manager object
|
|
* @since 5.41
|
|
**/
|
|
IdleInhibitManagerInterface *createIdleInhibitManager(const IdleInhibitManagerInterfaceVersion &version, QObject *parent = nullptr);
|
|
|
|
/**
|
|
* Creates the AppMenuManagerInterface in interface @p version.
|
|
*
|
|
* @returns The created manager object
|
|
* @since 5.42
|
|
**/
|
|
AppMenuManagerInterface *createAppMenuManagerInterface(QObject *parent = nullptr);
|
|
|
|
/**
|
|
* Creates the ServerSideDecorationPaletteManagerInterface in interface @p version.
|
|
*
|
|
* @returns The created manager object
|
|
* @since 5.42
|
|
**/
|
|
ServerSideDecorationPaletteManagerInterface *createServerSideDecorationPaletteManager(QObject *parent = nullptr);
|
|
|
|
|
|
/**
|
|
* Gets the ClientConnection for the given @p client.
|
|
* If there is no ClientConnection yet for the given @p client, it will be created.
|
|
* @param client The native client for which the ClientConnection is retrieved
|
|
* @return The ClientConnection for the given native client
|
|
**/
|
|
ClientConnection *getConnection(wl_client *client);
|
|
QVector<ClientConnection*> connections() const;
|
|
|
|
/**
|
|
* Set the EGL @p display for this Wayland display.
|
|
* The EGLDisplay can only be set once and must be alive as long as the Wayland display
|
|
* is alive. The user should have set up the binding between the EGLDisplay and the
|
|
* Wayland display prior to calling this method.
|
|
*
|
|
* @see eglDisplay
|
|
* @since 5.3
|
|
**/
|
|
void setEglDisplay(void *display);
|
|
/**
|
|
* @returns the EGLDisplay used for this Wayland display or EGL_NO_DISPLAY if not set.
|
|
* @see setEglDisplay
|
|
* @since 5.3
|
|
**/
|
|
void *eglDisplay() const;
|
|
|
|
Q_SIGNALS:
|
|
void socketNameChanged(const QString&);
|
|
void runningChanged(bool);
|
|
void aboutToTerminate();
|
|
void clientConnected(KWayland::Server::ClientConnection*);
|
|
void clientDisconnected(KWayland::Server::ClientConnection*);
|
|
|
|
private:
|
|
class Private;
|
|
QScopedPointer<Private> d;
|
|
};
|
|
|
|
}
|
|
}
|
|
|
|
#endif
|