Files
deskflow/src/lib/base/SimpleEventQueueBuffer.cpp

86 lines
1.8 KiB
C++

/*
* Deskflow -- mouse and keyboard sharing utility
* SPDX-FileCopyrightText: (C) 2012 - 2016 Symless Ltd.
* SPDX-FileCopyrightText: (C) 2004 Chris Schoeneman
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
*/
#include "base/SimpleEventQueueBuffer.h"
#include "arch/Arch.h"
#include "base/Stopwatch.h"
class EventQueueTimer
{
};
//
// SimpleEventQueueBuffer
//
SimpleEventQueueBuffer::SimpleEventQueueBuffer()
{
m_queueMutex = ARCH->newMutex();
m_queueReadyCond = ARCH->newCondVar();
}
SimpleEventQueueBuffer::~SimpleEventQueueBuffer()
{
ARCH->closeCondVar(m_queueReadyCond);
ARCH->closeMutex(m_queueMutex);
}
void SimpleEventQueueBuffer::waitForEvent(double timeout)
{
ArchMutexLock lock(m_queueMutex);
Stopwatch timer(true);
while (!m_queueReady) {
double timeLeft = timeout;
if (timeLeft >= 0.0) {
timeLeft -= timer.getTime();
if (timeLeft < 0.0) {
return;
}
}
ARCH->waitCondVar(m_queueReadyCond, m_queueMutex, timeLeft);
}
}
IEventQueueBuffer::Type SimpleEventQueueBuffer::getEvent(Event &, uint32_t &dataID)
{
ArchMutexLock lock(m_queueMutex);
if (!m_queueReady) {
return IEventQueueBuffer::Type::Unknown;
}
dataID = m_queue.back();
m_queue.pop_back();
m_queueReady = !m_queue.empty();
return IEventQueueBuffer::Type::User;
}
bool SimpleEventQueueBuffer::addEvent(uint32_t dataID)
{
ArchMutexLock lock(m_queueMutex);
m_queue.push_front(dataID);
if (!m_queueReady) {
m_queueReady = true;
ARCH->broadcastCondVar(m_queueReadyCond);
}
return true;
}
bool SimpleEventQueueBuffer::isEmpty() const
{
ArchMutexLock lock(m_queueMutex);
return !m_queueReady;
}
EventQueueTimer *SimpleEventQueueBuffer::newTimer(double, bool) const
{
return new EventQueueTimer;
}
void SimpleEventQueueBuffer::deleteTimer(EventQueueTimer *timer) const
{
delete timer;
}