This enum describes how KWin is operating with the available windowing systems. By default KWin is using the OperationModeX11, but if the Wayland backend gets started KWin is using the OperationModeWaylandAndX11 This will be extended in future when XWayland and Wayland only become viable options.
118 lines
3.2 KiB
C++
118 lines
3.2 KiB
C++
/********************************************************************
|
|
KWin - the KDE window manager
|
|
This file is part of the KDE project.
|
|
|
|
Copyright (C) 1999, 2000 Matthias Ettrich <ettrich@kde.org>
|
|
Copyright (C) 2003 Lubos Lunak <l.lunak@kde.org>
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program 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 General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*********************************************************************/
|
|
|
|
#ifndef MAIN_H
|
|
#define MAIN_H
|
|
|
|
#include <KDE/KSelectionWatcher>
|
|
// Qt
|
|
#include <QApplication>
|
|
#include <QAbstractNativeEventFilter>
|
|
|
|
namespace KWin
|
|
{
|
|
|
|
class XcbEventFilter : public QAbstractNativeEventFilter
|
|
{
|
|
public:
|
|
virtual bool nativeEventFilter(const QByteArray &eventType, void *message, long int *result) override;
|
|
};
|
|
|
|
class KWinSelectionOwner
|
|
: public KSelectionOwner
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
explicit KWinSelectionOwner(int screen);
|
|
protected:
|
|
virtual bool genericReply(xcb_atom_t target, xcb_atom_t property, xcb_window_t requestor);
|
|
virtual void replyTargets(xcb_atom_t property, xcb_window_t requestor);
|
|
virtual void getAtoms();
|
|
private:
|
|
xcb_atom_t make_selection_atom(int screen);
|
|
static xcb_atom_t xa_version;
|
|
};
|
|
|
|
class Application : public QApplication
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
/**
|
|
* @brief This enum provides the various operation modes of KWin depending on the available
|
|
* Windowing Systems at startup. For example whether KWin only talks to X11 or also to a Wayland
|
|
* Compositor.
|
|
*
|
|
*/
|
|
enum OperationMode {
|
|
/**
|
|
* @brief KWin uses only X11 for managing windows and compositing
|
|
*/
|
|
OperationModeX11,
|
|
/**
|
|
* @brief KWin uses X11 for managing windows, but renders to a Wayland compositor.
|
|
* Input is received from the Wayland compositor.
|
|
*/
|
|
OperationModeWaylandAndX11
|
|
};
|
|
Application(int &argc, char **argv);
|
|
~Application();
|
|
|
|
void setReplace(bool replace);
|
|
void setConfigLock(bool lock);
|
|
|
|
void start();
|
|
/**
|
|
* @brief The operation mode used by KWin.
|
|
*
|
|
* @return OperationMode
|
|
*/
|
|
OperationMode operationMode() const;
|
|
void setOperationMode(OperationMode mode);
|
|
|
|
static void setCrashCount(int count);
|
|
static bool wasCrash();
|
|
|
|
protected:
|
|
bool notify(QObject* o, QEvent* e);
|
|
static void crashHandler(int signal);
|
|
|
|
private Q_SLOTS:
|
|
void lostSelection();
|
|
void resetCrashesCount();
|
|
|
|
private:
|
|
void crashChecking();
|
|
KWinSelectionOwner owner;
|
|
QScopedPointer<XcbEventFilter> m_eventFilter;
|
|
bool m_replace;
|
|
bool m_configLock;
|
|
OperationMode m_operationMode;
|
|
static int crashes;
|
|
};
|
|
|
|
inline static Application *kwinApp()
|
|
{
|
|
return static_cast<Application*>(QCoreApplication::instance());
|
|
}
|
|
|
|
} // namespace
|
|
|
|
#endif
|