2014-08-26 14:07:39 +00:00
|
|
|
/********************************************************************
|
2014-09-17 13:57:56 +00:00
|
|
|
Copyright 2014 Martin Gräßlin <mgraesslin@kde.org>
|
2014-08-26 14:07:39 +00:00
|
|
|
|
2014-09-17 13:57:56 +00:00
|
|
|
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.
|
2014-08-26 14:07:39 +00:00
|
|
|
|
2014-09-17 13:57:56 +00:00
|
|
|
This library is distributed in the hope that it will be useful,
|
2014-08-26 14:07:39 +00:00
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2014-09-17 13:57:56 +00:00
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
Lesser General Public License for more details.
|
2014-08-26 14:07:39 +00:00
|
|
|
|
2014-09-17 13:57:56 +00:00
|
|
|
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/>.
|
2014-08-26 14:07:39 +00:00
|
|
|
*********************************************************************/
|
2014-09-17 14:20:56 +00:00
|
|
|
#ifndef WAYLAND_SERVER_DISPLAY_H
|
|
|
|
#define WAYLAND_SERVER_DISPLAY_H
|
2014-08-26 14:07:39 +00:00
|
|
|
|
|
|
|
#include <QList>
|
|
|
|
#include <QObject>
|
|
|
|
|
2014-10-14 11:43:24 +00:00
|
|
|
#include <KWayland/Server/kwaylandserver_export.h>
|
2014-09-17 13:10:43 +00:00
|
|
|
|
2014-11-17 15:01:18 +00:00
|
|
|
#include "clientconnection.h"
|
|
|
|
|
|
|
|
struct wl_client;
|
2014-08-26 14:07:39 +00:00
|
|
|
struct wl_display;
|
|
|
|
struct wl_event_loop;
|
|
|
|
|
2014-09-17 14:10:38 +00:00
|
|
|
namespace KWayland
|
2014-08-26 14:07:39 +00:00
|
|
|
{
|
2014-09-17 14:10:38 +00:00
|
|
|
namespace Server
|
2014-08-26 14:07:39 +00:00
|
|
|
{
|
|
|
|
|
2014-08-28 07:52:35 +00:00
|
|
|
class CompositorInterface;
|
2014-11-04 14:10:22 +00:00
|
|
|
class DataDeviceManagerInterface;
|
2014-08-26 14:07:39 +00:00
|
|
|
class OutputInterface;
|
2015-06-09 00:48:56 +00:00
|
|
|
class PlasmaShellInterface;
|
2014-09-02 07:34:31 +00:00
|
|
|
class SeatInterface;
|
2014-08-29 09:42:57 +00:00
|
|
|
class ShellInterface;
|
2014-10-14 12:04:35 +00:00
|
|
|
class SubCompositorInterface;
|
2014-08-26 14:07:39 +00:00
|
|
|
|
2014-09-17 13:10:43 +00:00
|
|
|
class KWAYLANDSERVER_EXPORT Display : public QObject
|
2014-08-26 14:07:39 +00:00
|
|
|
{
|
|
|
|
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;
|
|
|
|
|
2014-08-29 09:42:57 +00:00
|
|
|
quint32 serial();
|
|
|
|
quint32 nextSerial();
|
|
|
|
|
2014-11-27 15:42:16 +00:00
|
|
|
/**
|
|
|
|
* 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);
|
2014-08-26 14:07:39 +00:00
|
|
|
void terminate();
|
2014-11-07 10:41:37 +00:00
|
|
|
/**
|
|
|
|
* 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
|
2015-05-18 08:27:44 +00:00
|
|
|
* is created and the event loop is started this method delegates to the normal dispatch
|
|
|
|
* handling.
|
2014-11-07 10:41:37 +00:00
|
|
|
* @see startLoop
|
|
|
|
**/
|
|
|
|
void dispatchEvents(int msecTimeout = -1);
|
2014-08-26 14:07:39 +00:00
|
|
|
|
2014-11-27 15:16:54 +00:00
|
|
|
/**
|
|
|
|
* 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);
|
|
|
|
|
2014-09-18 13:40:22 +00:00
|
|
|
operator wl_display*();
|
|
|
|
operator wl_display*() const;
|
|
|
|
bool isRunning() const;
|
2014-08-26 14:07:39 +00:00
|
|
|
|
|
|
|
OutputInterface *createOutput(QObject *parent = nullptr);
|
|
|
|
void removeOutput(OutputInterface *output);
|
2014-09-18 13:40:22 +00:00
|
|
|
QList<OutputInterface*> outputs() const;
|
2014-08-26 14:07:39 +00:00
|
|
|
|
2014-08-28 07:52:35 +00:00
|
|
|
CompositorInterface *createCompositor(QObject *parent = nullptr);
|
2014-08-28 12:22:53 +00:00
|
|
|
void createShm();
|
2014-08-29 09:42:57 +00:00
|
|
|
ShellInterface *createShell(QObject *parent = nullptr);
|
2014-09-02 07:34:31 +00:00
|
|
|
SeatInterface *createSeat(QObject *parent = nullptr);
|
2014-10-14 12:04:35 +00:00
|
|
|
SubCompositorInterface *createSubCompositor(QObject *parent = nullptr);
|
2014-11-04 14:10:22 +00:00
|
|
|
DataDeviceManagerInterface *createDataDeviceManager(QObject *parent = nullptr);
|
2015-06-09 00:48:56 +00:00
|
|
|
PlasmaShellInterface *createPlasmaShell(QObject *parent = nullptr);
|
2014-08-28 07:52:35 +00:00
|
|
|
|
2014-11-17 15:01:18 +00:00
|
|
|
/**
|
|
|
|
* 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);
|
2014-11-17 17:13:28 +00:00
|
|
|
QVector<ClientConnection*> connections() const;
|
2014-11-17 15:01:18 +00:00
|
|
|
|
2015-03-03 08:43:30 +00:00
|
|
|
/**
|
|
|
|
* 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;
|
|
|
|
|
2014-08-26 14:07:39 +00:00
|
|
|
Q_SIGNALS:
|
|
|
|
void socketNameChanged(const QString&);
|
|
|
|
void runningChanged(bool);
|
|
|
|
void aboutToTerminate();
|
2014-11-17 15:01:18 +00:00
|
|
|
void clientConnected(KWayland::Server::ClientConnection*);
|
|
|
|
void clientDisconnected(KWayland::Server::ClientConnection*);
|
2014-08-26 14:07:39 +00:00
|
|
|
|
|
|
|
private:
|
2014-09-18 13:40:22 +00:00
|
|
|
class Private;
|
|
|
|
QScopedPointer<Private> d;
|
2014-08-26 14:07:39 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|