2007-11-27 19:40:25 +00:00
|
|
|
/********************************************************************
|
2007-04-29 17:35:43 +00:00
|
|
|
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>
|
|
|
|
|
2007-11-27 19:40:25 +00:00
|
|
|
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/>.
|
|
|
|
*********************************************************************/
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
#ifndef MAIN_H
|
|
|
|
#define MAIN_H
|
|
|
|
|
2014-08-12 07:08:48 +00:00
|
|
|
#include <kwinglobals.h>
|
2014-08-15 12:03:52 +00:00
|
|
|
#include <config-kwin.h>
|
2014-08-12 07:08:48 +00:00
|
|
|
|
2014-03-17 15:24:10 +00:00
|
|
|
#include <KSelectionWatcher>
|
2014-03-18 13:37:01 +00:00
|
|
|
#include <KSelectionOwner>
|
2016-01-29 08:48:02 +00:00
|
|
|
#include <KSharedConfig>
|
2013-07-26 05:52:56 +00:00
|
|
|
// Qt
|
2013-08-28 12:10:51 +00:00
|
|
|
#include <QApplication>
|
2013-07-26 05:52:56 +00:00
|
|
|
#include <QAbstractNativeEventFilter>
|
2015-07-07 15:35:57 +00:00
|
|
|
#include <QProcessEnvironment>
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2016-04-06 15:30:00 +00:00
|
|
|
class KPluginMetaData;
|
2014-08-12 07:08:48 +00:00
|
|
|
class QCommandLineParser;
|
|
|
|
|
2007-04-29 17:35:43 +00:00
|
|
|
namespace KWin
|
|
|
|
{
|
|
|
|
|
2016-04-07 07:18:10 +00:00
|
|
|
class Platform;
|
2016-04-06 15:30:00 +00:00
|
|
|
|
2013-07-26 05:52:56 +00:00
|
|
|
class XcbEventFilter : public QAbstractNativeEventFilter
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual bool nativeEventFilter(const QByteArray &eventType, void *message, long int *result) override;
|
|
|
|
};
|
|
|
|
|
2014-08-12 07:08:48 +00:00
|
|
|
class KWIN_EXPORT Application : public QApplication
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
Q_OBJECT
|
2015-02-19 08:59:21 +00:00
|
|
|
Q_PROPERTY(quint32 x11Time READ x11Time WRITE setX11Time)
|
2015-02-18 07:31:53 +00:00
|
|
|
Q_PROPERTY(quint32 x11RootWindow READ x11RootWindow CONSTANT)
|
2015-02-18 10:19:04 +00:00
|
|
|
Q_PROPERTY(void *x11Connection READ x11Connection NOTIFY x11ConnectionChanged)
|
2015-02-18 10:52:51 +00:00
|
|
|
Q_PROPERTY(int x11ScreenNumber READ x11ScreenNumber CONSTANT)
|
2011-01-30 14:34:42 +00:00
|
|
|
public:
|
2013-06-25 06:52:08 +00:00
|
|
|
/**
|
|
|
|
* @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.
|
|
|
|
*/
|
2015-01-09 15:00:16 +00:00
|
|
|
OperationModeWaylandAndX11,
|
|
|
|
/**
|
|
|
|
* @brief KWin uses Wayland and controls a nested Xwayland server.
|
|
|
|
**/
|
|
|
|
OperationModeXwayland
|
2013-06-25 06:52:08 +00:00
|
|
|
};
|
2014-08-12 07:08:48 +00:00
|
|
|
virtual ~Application();
|
2011-01-30 14:34:42 +00:00
|
|
|
|
2013-08-28 12:10:51 +00:00
|
|
|
void setConfigLock(bool lock);
|
|
|
|
|
2016-01-29 08:48:02 +00:00
|
|
|
KSharedConfigPtr config() const {
|
|
|
|
return m_config;
|
|
|
|
}
|
|
|
|
void setConfig(KSharedConfigPtr config) {
|
|
|
|
m_config = config;
|
|
|
|
}
|
|
|
|
|
2013-08-28 12:10:51 +00:00
|
|
|
void start();
|
2013-06-25 06:52:08 +00:00
|
|
|
/**
|
|
|
|
* @brief The operation mode used by KWin.
|
|
|
|
*
|
|
|
|
* @return OperationMode
|
|
|
|
*/
|
|
|
|
OperationMode operationMode() const;
|
|
|
|
void setOperationMode(OperationMode mode);
|
2013-06-25 07:53:45 +00:00
|
|
|
bool shouldUseWaylandForCompositing() const;
|
2013-08-28 12:10:51 +00:00
|
|
|
|
2014-08-12 07:08:48 +00:00
|
|
|
void setupTranslator();
|
|
|
|
void setupCommandLine(QCommandLineParser *parser);
|
|
|
|
void processCommandLine(QCommandLineParser *parser);
|
|
|
|
|
2015-02-19 08:59:21 +00:00
|
|
|
xcb_timestamp_t x11Time() const {
|
|
|
|
return m_x11Time;
|
|
|
|
}
|
2017-05-03 19:17:25 +00:00
|
|
|
enum class TimestampUpdate {
|
|
|
|
OnlyIfLarger,
|
|
|
|
Always
|
|
|
|
};
|
|
|
|
void setX11Time(xcb_timestamp_t timestamp, TimestampUpdate force = TimestampUpdate::OnlyIfLarger) {
|
2017-05-06 17:52:41 +00:00
|
|
|
if ((timestamp > m_x11Time || force == TimestampUpdate::Always) && timestamp != 0) {
|
2015-02-19 08:59:21 +00:00
|
|
|
m_x11Time = timestamp;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
void updateX11Time(xcb_generic_event_t *event);
|
2015-02-20 13:53:03 +00:00
|
|
|
void createScreens();
|
2015-02-19 08:59:21 +00:00
|
|
|
|
2013-08-28 12:10:51 +00:00
|
|
|
static void setCrashCount(int count);
|
|
|
|
static bool wasCrash();
|
|
|
|
|
2014-08-12 07:08:48 +00:00
|
|
|
/**
|
|
|
|
* Creates the KAboutData object for the KWin instance and registers it as
|
|
|
|
* KAboutData::setApplicationData.
|
|
|
|
**/
|
|
|
|
static void createAboutData();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @returns the X11 Screen number. If not applicable it's set to @c -1.
|
|
|
|
**/
|
|
|
|
static int x11ScreenNumber();
|
|
|
|
/**
|
|
|
|
* Sets the X11 screen number of this KWin instance to @p screenNumber.
|
|
|
|
**/
|
|
|
|
static void setX11ScreenNumber(int screenNumber);
|
|
|
|
/**
|
|
|
|
* @returns whether this is a multi head setup on X11.
|
|
|
|
**/
|
|
|
|
static bool isX11MultiHead();
|
|
|
|
/**
|
|
|
|
* Sets whether this is a multi head setup on X11.
|
|
|
|
*/
|
|
|
|
static void setX11MultiHead(bool multiHead);
|
|
|
|
|
2015-02-18 07:31:53 +00:00
|
|
|
/**
|
|
|
|
* @returns the X11 root window.
|
|
|
|
**/
|
|
|
|
xcb_window_t x11RootWindow() const {
|
|
|
|
return m_rootWindow;
|
|
|
|
}
|
|
|
|
|
2015-02-18 10:19:04 +00:00
|
|
|
/**
|
|
|
|
* @returns the X11 xcb connection
|
|
|
|
**/
|
|
|
|
xcb_connection_t *x11Connection() const {
|
|
|
|
return m_connection;
|
|
|
|
}
|
|
|
|
|
2015-11-24 08:01:46 +00:00
|
|
|
#ifdef KWIN_BUILD_ACTIVITIES
|
|
|
|
bool usesKActivities() const {
|
|
|
|
return m_useKActivities;
|
|
|
|
}
|
|
|
|
void setUseKActivities(bool use) {
|
|
|
|
m_useKActivities = use;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2015-07-07 15:35:57 +00:00
|
|
|
virtual QProcessEnvironment processStartupEnvironment() const;
|
|
|
|
|
2016-04-06 15:30:00 +00:00
|
|
|
void initPlatform(const KPluginMetaData &plugin);
|
2016-04-07 07:18:10 +00:00
|
|
|
Platform *platform() const {
|
2016-04-06 15:30:00 +00:00
|
|
|
return m_platform;
|
|
|
|
}
|
|
|
|
|
2014-08-12 07:08:48 +00:00
|
|
|
static void setupMalloc();
|
|
|
|
static void setupLocalizedString();
|
|
|
|
|
2014-08-15 12:03:52 +00:00
|
|
|
static bool usesLibinput();
|
|
|
|
static void setUseLibinput(bool use);
|
|
|
|
|
2015-02-18 10:19:04 +00:00
|
|
|
Q_SIGNALS:
|
|
|
|
void x11ConnectionChanged();
|
2015-11-12 14:13:42 +00:00
|
|
|
void x11ConnectionAboutToBeDestroyed();
|
2015-02-23 14:53:24 +00:00
|
|
|
void workspaceCreated();
|
2015-03-27 14:14:23 +00:00
|
|
|
void screensCreated();
|
2015-04-15 15:47:56 +00:00
|
|
|
void virtualTerminalCreated();
|
2015-02-18 10:19:04 +00:00
|
|
|
|
2011-01-30 14:34:42 +00:00
|
|
|
protected:
|
2014-08-12 07:08:48 +00:00
|
|
|
Application(OperationMode mode, int &argc, char **argv);
|
|
|
|
virtual void performStartup() = 0;
|
|
|
|
|
|
|
|
void notifyKSplash();
|
2015-02-20 13:53:03 +00:00
|
|
|
void createInput();
|
2014-08-12 07:08:48 +00:00
|
|
|
void createWorkspace();
|
|
|
|
void createAtoms();
|
|
|
|
void createOptions();
|
2015-02-23 14:57:00 +00:00
|
|
|
void createCompositor();
|
2014-08-12 07:08:48 +00:00
|
|
|
void setupEventFilters();
|
|
|
|
void destroyWorkspace();
|
2015-05-27 07:09:05 +00:00
|
|
|
void destroyCompositor();
|
2015-02-18 07:31:53 +00:00
|
|
|
/**
|
|
|
|
* Inheriting classes should use this method to set the X11 root window
|
|
|
|
* before accessing any X11 specific code pathes.
|
|
|
|
**/
|
|
|
|
void setX11RootWindow(xcb_window_t root) {
|
|
|
|
m_rootWindow = root;
|
|
|
|
}
|
2015-02-18 10:19:04 +00:00
|
|
|
/**
|
|
|
|
* Inheriting classes should use this method to set the xcb connection
|
|
|
|
* before accessing any X11 specific code pathes.
|
|
|
|
**/
|
|
|
|
void setX11Connection(xcb_connection_t *c) {
|
|
|
|
m_connection = c;
|
|
|
|
emit x11ConnectionChanged();
|
|
|
|
}
|
2015-05-26 12:26:56 +00:00
|
|
|
void destroyAtoms();
|
2014-08-12 07:08:48 +00:00
|
|
|
|
2015-05-01 14:55:15 +00:00
|
|
|
protected:
|
|
|
|
QString m_originalSessionKey;
|
2016-05-06 14:28:29 +00:00
|
|
|
static int crashes;
|
2015-05-01 14:55:15 +00:00
|
|
|
|
2013-07-22 14:07:39 +00:00
|
|
|
private Q_SLOTS:
|
2011-01-30 14:34:42 +00:00
|
|
|
void resetCrashesCount();
|
|
|
|
|
|
|
|
private:
|
2013-07-26 05:52:56 +00:00
|
|
|
QScopedPointer<XcbEventFilter> m_eventFilter;
|
2013-08-28 12:10:51 +00:00
|
|
|
bool m_configLock;
|
2016-01-29 08:48:02 +00:00
|
|
|
KSharedConfigPtr m_config;
|
2013-06-25 06:52:08 +00:00
|
|
|
OperationMode m_operationMode;
|
2015-02-19 08:59:21 +00:00
|
|
|
xcb_timestamp_t m_x11Time = XCB_TIME_CURRENT_TIME;
|
2015-02-18 07:31:53 +00:00
|
|
|
xcb_window_t m_rootWindow = XCB_WINDOW_NONE;
|
2015-02-18 10:19:04 +00:00
|
|
|
xcb_connection_t *m_connection = nullptr;
|
2015-11-24 08:01:46 +00:00
|
|
|
#ifdef KWIN_BUILD_ACTIVITIES
|
|
|
|
bool m_useKActivities = true;
|
|
|
|
#endif
|
2016-04-07 07:18:10 +00:00
|
|
|
Platform *m_platform = nullptr;
|
2011-01-30 14:34:42 +00:00
|
|
|
};
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2014-01-09 13:47:57 +00:00
|
|
|
inline static Application *kwinApp()
|
|
|
|
{
|
|
|
|
return static_cast<Application*>(QCoreApplication::instance());
|
|
|
|
}
|
|
|
|
|
2007-04-29 17:35:43 +00:00
|
|
|
} // namespace
|
|
|
|
|
|
|
|
#endif
|