From b002b279032145a6d4e3b93c30ea5b16d20a4973 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20Fl=C3=B6ser?= Date: Fri, 29 Dec 2017 18:29:19 +0100 Subject: [PATCH] Simulate user activity on fake input events Summary: This ensures that using KDE Connect to control input properly inhibits idle timeouts. Reviewers: #kwin, #plasma Subscribers: plasma-devel, kwin Tags: #plasma Differential Revision: https://phabricator.kde.org/D9555 --- input.cpp | 7 +++++++ wayland_server.cpp | 13 ++++++++++--- wayland_server.h | 4 ++++ 3 files changed, 21 insertions(+), 3 deletions(-) diff --git a/input.cpp b/input.cpp index cd105ecf1e..a08d03e6cd 100644 --- a/input.cpp +++ b/input.cpp @@ -1589,18 +1589,21 @@ void InputRedirection::setupWorkspace() [this] (const QSizeF &delta) { // TODO: Fix time m_pointer->processMotion(globalPointer() + QPointF(delta.width(), delta.height()), 0); + waylandServer()->simulateUserActivity(); } ); connect(device, &FakeInputDevice::pointerButtonPressRequested, this, [this] (quint32 button) { // TODO: Fix time m_pointer->processButton(button, InputRedirection::PointerButtonPressed, 0); + waylandServer()->simulateUserActivity(); } ); connect(device, &FakeInputDevice::pointerButtonReleaseRequested, this, [this] (quint32 button) { // TODO: Fix time m_pointer->processButton(button, InputRedirection::PointerButtonReleased, 0); + waylandServer()->simulateUserActivity(); } ); connect(device, &FakeInputDevice::pointerAxisRequested, this, @@ -1620,24 +1623,28 @@ void InputRedirection::setupWorkspace() } // TODO: Fix time m_pointer->processAxis(axis, delta, 0); + waylandServer()->simulateUserActivity(); } ); connect(device, &FakeInputDevice::touchDownRequested, this, [this] (quint32 id, const QPointF &pos) { // TODO: Fix time m_touch->processDown(id, pos, 0); + waylandServer()->simulateUserActivity(); } ); connect(device, &FakeInputDevice::touchMotionRequested, this, [this] (quint32 id, const QPointF &pos) { // TODO: Fix time m_touch->processMotion(id, pos, 0); + waylandServer()->simulateUserActivity(); } ); connect(device, &FakeInputDevice::touchUpRequested, this, [this] (quint32 id) { // TODO: Fix time m_touch->processUp(id, 0); + waylandServer()->simulateUserActivity(); } ); connect(device, &FakeInputDevice::touchCancelRequested, this, diff --git a/wayland_server.cpp b/wayland_server.cpp index d23fa4043c..11a142d18c 100644 --- a/wayland_server.cpp +++ b/wayland_server.cpp @@ -249,9 +249,9 @@ bool WaylandServer::init(const QByteArray &socketName, InitalizationFlags flags) } } ); - auto idle = m_display->createIdle(m_display); - idle->create(); - auto idleInhibition = new IdleInhibition(idle); + m_idle = m_display->createIdle(m_display); + m_idle->create(); + auto idleInhibition = new IdleInhibition(m_idle); connect(this, &WaylandServer::shellClientAdded, idleInhibition, &IdleInhibition::registerShellClient); m_display->createIdleInhibitManager(IdleInhibitManagerInterfaceVersion::UnstableV1, m_display)->create(); m_plasmaShell = m_display->createPlasmaShell(m_display); @@ -749,4 +749,11 @@ bool WaylandServer::hasScreenLockerIntegration() const return !m_initFlags.testFlag(InitalizationFlag::NoLockScreenIntegration); } +void WaylandServer::simulateUserActivity() +{ + if (m_idle) { + m_idle->simulateUserActivity(); + } +} + } diff --git a/wayland_server.h b/wayland_server.h index 868a7f0180..03ba8c8627 100644 --- a/wayland_server.h +++ b/wayland_server.h @@ -45,6 +45,7 @@ class ClientConnection; class CompositorInterface; class Display; class DataDeviceInterface; +class IdleInterface; class ShellInterface; class SeatInterface; class ServerSideDecorationManagerInterface; @@ -192,6 +193,8 @@ public: **/ SocketPairConnection createConnection(); + void simulateUserActivity(); + Q_SIGNALS: void shellClientAdded(KWin::ShellClient*); void shellClientRemoved(KWin::ShellClient*); @@ -223,6 +226,7 @@ private: KWayland::Server::OutputManagementInterface *m_outputManagement = nullptr; KWayland::Server::AppMenuManagerInterface *m_appMenuManager = nullptr; KWayland::Server::ServerSideDecorationPaletteManagerInterface *m_paletteManager = nullptr; + KWayland::Server::IdleInterface *m_idle = nullptr; struct { KWayland::Server::ClientConnection *client = nullptr; QMetaObject::Connection destroyConnection;