1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
|
/*
SPDX-FileCopyrightText: 2021 Vlad Zahorodnii <vlad.zahorodnii@kde.org>
SPDX-License-Identifier: GPL-2.0-or-later
*/
#include "idledetector.h"
#include "input.h"
using namespace std::chrono_literals;
namespace KWin
{
IdleDetector::IdleDetector(std::chrono::milliseconds timeout, OperatingMode mode, QObject *parent)
: QObject(parent)
, m_timeout(timeout)
, m_mode(mode)
{
Q_ASSERT(timeout >= 0ms);
m_timer.start(timeout, this);
input()->addIdleDetector(this);
}
IdleDetector::~IdleDetector()
{
if (input()) {
input()->removeIdleDetector(this);
}
}
void IdleDetector::timerEvent(QTimerEvent *event)
{
if (event->timerId() == m_timer.timerId()) {
m_timer.stop();
markAsIdle();
}
}
IdleDetector::OperatingMode IdleDetector::mode() const
{
return m_mode;
}
bool IdleDetector::isInhibited() const
{
return m_isInhibited;
}
void IdleDetector::setInhibited(bool inhibited)
{
if (m_mode == OperatingMode::IgnoresInhibitors) {
return;
};
if (m_isInhibited == inhibited) {
return;
}
m_isInhibited = inhibited;
if (inhibited) {
m_timer.stop();
} else {
m_timer.start(m_timeout, this);
}
}
void IdleDetector::activity()
{
if (!m_isInhibited) {
m_timer.start(m_timeout, this);
markAsResumed();
}
}
void IdleDetector::markAsIdle()
{
if (!m_isIdle) {
m_isIdle = true;
Q_EMIT idle();
}
}
void IdleDetector::markAsResumed()
{
if (m_isIdle) {
m_isIdle = false;
Q_EMIT resumed();
}
}
} // namespace KWin
#include "moc_idledetector.cpp"
|