2022-03-12 14:09:57 +00:00
|
|
|
/*
|
|
|
|
KWin - the KDE window manager
|
|
|
|
This file is part of the KDE project.
|
|
|
|
|
|
|
|
SPDX-FileCopyrightText: 2019 Roman Gilg <subdiff@gmail.com>
|
|
|
|
SPDX-FileCopyrightText: 2020 Vlad Zahorodnii <vlad.zahorodnii@kde.org>
|
|
|
|
|
|
|
|
SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <QObject>
|
|
|
|
#include <QProcess>
|
2022-03-23 10:13:38 +00:00
|
|
|
#include <QScopedPointer>
|
2022-03-12 14:09:57 +00:00
|
|
|
#include <QSocketNotifier>
|
|
|
|
#include <QTemporaryFile>
|
2022-03-23 10:13:38 +00:00
|
|
|
#include <QVector>
|
2022-03-12 14:09:57 +00:00
|
|
|
|
|
|
|
#include <kwin_export.h>
|
|
|
|
|
|
|
|
class QTimer;
|
|
|
|
|
|
|
|
namespace KWin
|
|
|
|
{
|
|
|
|
class XwaylandSocket;
|
|
|
|
|
|
|
|
namespace Xwl
|
|
|
|
{
|
|
|
|
|
|
|
|
class KWIN_EXPORT XwaylandLauncher : public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
public:
|
|
|
|
explicit XwaylandLauncher(QObject *parent);
|
|
|
|
~XwaylandLauncher();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set file descriptors that xwayland should use for listening
|
|
|
|
* This is to be used in conjuction with kwin_wayland_wrapper which creates a socket externally
|
|
|
|
* That external process is responsible for setting up the DISPLAY env with a valid value.
|
|
|
|
* Ownership of the file descriptor is not transferrred.
|
|
|
|
*/
|
|
|
|
void setListenFDs(const QVector<int> &listenFds);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the display name used by XWayland (i.e ':0')
|
|
|
|
* This is to be used in conjuction with kwin_wayland_wrapper to provide the name of the socket
|
|
|
|
* created externally
|
|
|
|
*/
|
|
|
|
void setDisplayName(const QString &displayName);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the xauthority file to be used by XWayland
|
|
|
|
* This is to be used in conjuction with kwin_wayland_wrapper
|
|
|
|
*/
|
|
|
|
void setXauthority(const QString &xauthority);
|
|
|
|
|
|
|
|
void start();
|
|
|
|
void stop();
|
|
|
|
|
|
|
|
QString displayName() const;
|
|
|
|
QString xauthority() const;
|
|
|
|
int xcbConnectionFd() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
QProcess *process() const;
|
|
|
|
Q_SIGNALS:
|
|
|
|
/**
|
|
|
|
* This signal is emitted when the Xwayland server has been started successfully and it is
|
|
|
|
* ready to accept and manage X11 clients.
|
|
|
|
* For restarts it may be emitted multiple times
|
|
|
|
*/
|
|
|
|
void started();
|
|
|
|
/**
|
|
|
|
* This signal is emitted when the Xwayland server quits or crashes
|
|
|
|
*/
|
|
|
|
void finished();
|
|
|
|
/**
|
|
|
|
* This signal is emitted when an error occurs with the Xwayland server.
|
|
|
|
*/
|
|
|
|
void errorOccurred();
|
|
|
|
|
|
|
|
private Q_SLOTS:
|
|
|
|
void resetCrashCount();
|
|
|
|
void handleXwaylandFinished(int exitCode, QProcess::ExitStatus exitStatus);
|
|
|
|
void handleXwaylandCrashed();
|
|
|
|
void handleXwaylandError(QProcess::ProcessError error);
|
|
|
|
|
|
|
|
private:
|
|
|
|
void maybeDestroyReadyNotifier();
|
|
|
|
bool startInternal();
|
|
|
|
void stopInternal();
|
|
|
|
void restartInternal();
|
|
|
|
|
|
|
|
QProcess *m_xwaylandProcess = nullptr;
|
|
|
|
QSocketNotifier *m_readyNotifier = nullptr;
|
|
|
|
QTimer *m_resetCrashCountTimer = nullptr;
|
|
|
|
// this is only used when kwin is run without kwin_wayland_wrapper
|
|
|
|
QScopedPointer<XwaylandSocket> m_socket;
|
|
|
|
QVector<int> m_listenFds;
|
|
|
|
QString m_displayName;
|
|
|
|
QString m_xAuthority;
|
|
|
|
|
|
|
|
int m_crashCount = 0;
|
|
|
|
int m_xcbConnectionFd = -1;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|