kwin/src/wayland/idle_interface.h
Andreas Cord-Landwehr 9267f146fd KWayland: Convert license headers to SPDX
Summary:
Convert license headers to SPDX expressions and add license files as
required by REUSE specification.

Reviewers: zzag

Reviewed By: zzag

Subscribers: kde-frameworks-devel

Tags: #frameworks

Maniphest Tasks: T11550

Differential Revision: https://phabricator.kde.org/D28058
2020-03-16 19:57:44 +01:00

126 lines
3.6 KiB
C++

/*
SPDX-FileCopyrightText: 2015 Martin Gräßlin <mgraesslin@kde.org>
SPDX-License-Identifier: LGPL-2.1-only OR LGPL-3.0-only OR LicenseRef-KDE-Accepted-LGPL
*/
#ifndef KWAYLAND_SERVER_IDLE_INTERFACE_H
#define KWAYLAND_SERVER_IDLE_INTERFACE_H
#include <KWayland/Server/kwaylandserver_export.h>
#include "global.h"
#include "resource.h"
namespace KWayland
{
namespace Server
{
class Display;
class SeatInterface;
/**
* @brief Global representing the org_kde_kwin_idle interface.
*
* The IdleInterface allows to register callbacks which are invoked if there has
* not been any user activity (no input) for a specified time span on a seat.
*
* A client can bind an idle timeout for a SeatInterface and through that register
* an idle timeout. The complete interaction is handled internally, thus the API
* user only needs to create the IdleInterface in order to provide this feature.
*
* This interface is useful for clients as it allows them to perform power management,
* chat applications might want to set to away after no user input for some time, etc.
*
* Of course this exposes the global input usage to all clients. Normally clients don't
* know whether the input devices are used, only if their surfaces have focus. With this
* interface it is possible to notice that there are input events. A server should consider
* this to decide whether it wants to provide this feature!
*
* @since 5.4
**/
class KWAYLANDSERVER_EXPORT IdleInterface : public Global
{
Q_OBJECT
public:
virtual ~IdleInterface();
/**
* Inhibits the IdleInterface. While inhibited no IdleTimeoutInterface interface gets
* notified about an idle timeout.
*
* This can be used to inhibit power management, screen locking, etc. directly from
* Compositor side.
*
* To resume idle timeouts invoke @link{uninhibit}. It is possible to invoke inhibit several
* times, in that case uninhibit needs to called the same amount as inhibit has been called.
* @see uninhibit
* @see isInhibited
* @see inhibitedChanged
* @since 5.41
**/
void inhibit();
/**
* Inhibits the IdleInterface. The idle timeouts are only restarted if uninhibit has been
* called the same amount as inhibit.
*
* @see inhibit
* @see isInhibited
* @see inhibitedChanged
* @since 5.41
**/
void uninhibit();
/**
* @returns Whether idle timeouts are currently inhibited
* @see inhibit
* @see uninhibit
* @see inhibitedChanged
* @since 5.41
**/
bool isInhibited() const;
/**
* Calling this method allows the Compositor to simulate user activity.
* This means the same action is performed as if the user interacted with
* an input device on the SeatInterface.
* Idle timeouts are resumed and the idle time gets restarted.
* @since 5.42
**/
void simulateUserActivity();
Q_SIGNALS:
/**
* Emitted when the system gets inhibited or uninhibited.
* @see inhibit
* @see uninhibit
* @see isInhibited
* @since 5.41
**/
void inhibitedChanged();
private:
explicit IdleInterface(Display *display, QObject *parent = nullptr);
friend class Display;
class Private;
Private *d_func() const;
};
// TODO: KF6 make private class
class KWAYLANDSERVER_EXPORT IdleTimeoutInterface : public Resource
{
Q_OBJECT
public:
virtual ~IdleTimeoutInterface();
private:
explicit IdleTimeoutInterface(SeatInterface *seat, IdleInterface *parent, wl_resource *parentResource);
friend class IdleInterface;
class Private;
Private *d_func() const;
};
}
}
#endif