mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2025-03-01 10:33:28 +00:00
Move main non Thread Objects to Smart Pointers
This commit is contained in:
@@ -142,7 +142,7 @@ void JsonAPI::initialize()
|
||||
}
|
||||
|
||||
//notify eventhadler on suspend/resume/idle requests
|
||||
connect(this, &JsonAPI::signalEvent, EventHandler::getInstance(), &EventHandler::handleEvent);
|
||||
connect(this, &JsonAPI::signalEvent, EventHandler::getInstance().data(), &EventHandler::handleEvent);
|
||||
|
||||
connect(_ledStreamTimer, &QTimer::timeout, this, &JsonAPI::streamLedColorsUpdate, Qt::UniqueConnection);
|
||||
}
|
||||
|
@@ -165,7 +165,7 @@ bool CECHandler::enable()
|
||||
else
|
||||
{
|
||||
_isOpen=true;
|
||||
QObject::connect(this, &CECHandler::signalEvent, EventHandler::getInstance(), &EventHandler::handleEvent);
|
||||
QObject::connect(this, &CECHandler::signalEvent, EventHandler::getInstance().data(), &EventHandler::handleEvent);
|
||||
#ifdef VERBOSE_CEC
|
||||
std::cout << "Found Devices: " << scan().toStdString() << std::endl;
|
||||
#endif
|
||||
@@ -188,7 +188,7 @@ void CECHandler::disable()
|
||||
{
|
||||
if (_isInitialised)
|
||||
{
|
||||
QObject::disconnect(this, &CECHandler::signalEvent, EventHandler::getInstance(), &EventHandler::handleEvent);
|
||||
QObject::disconnect(this, &CECHandler::signalEvent, EventHandler::getInstance().data(), &EventHandler::handleEvent);
|
||||
_cecAdapter->Close();
|
||||
_isOpen=false;
|
||||
Info(_logger, "CEC handler disabled");
|
||||
|
@@ -7,6 +7,8 @@
|
||||
#include <utils/Process.h>
|
||||
#include <hyperion/HyperionIManager.h>
|
||||
|
||||
QScopedPointer<EventHandler> EventHandler::instance;
|
||||
|
||||
EventHandler::EventHandler()
|
||||
: _isSuspended(false)
|
||||
, _isIdle(false)
|
||||
@@ -22,10 +24,14 @@ EventHandler::~EventHandler()
|
||||
QObject::disconnect(this, &EventHandler::signalEvent, HyperionIManager::getInstance(), &HyperionIManager::handleEvent);
|
||||
}
|
||||
|
||||
EventHandler* EventHandler::getInstance()
|
||||
QScopedPointer<EventHandler>& EventHandler::getInstance()
|
||||
{
|
||||
static EventHandler instance;
|
||||
return &instance;
|
||||
if (!instance)
|
||||
{
|
||||
instance.reset(new EventHandler());
|
||||
}
|
||||
|
||||
return instance;
|
||||
}
|
||||
|
||||
void EventHandler::suspend()
|
||||
|
@@ -15,12 +15,12 @@ EventScheduler::EventScheduler()
|
||||
qRegisterMetaType<Event>("Event");
|
||||
_log = Logger::getInstance("EVENTS-SCHED");
|
||||
|
||||
QObject::connect(this, &EventScheduler::signalEvent, EventHandler::getInstance(), &EventHandler::handleEvent);
|
||||
QObject::connect(this, &EventScheduler::signalEvent, EventHandler::getInstance().data(), &EventHandler::handleEvent);
|
||||
}
|
||||
|
||||
EventScheduler::~EventScheduler()
|
||||
{
|
||||
QObject::disconnect(this, &EventScheduler::signalEvent, EventHandler::getInstance(), &EventHandler::handleEvent);
|
||||
QObject::disconnect(this, &EventScheduler::signalEvent, EventHandler::getInstance().data(), &EventHandler::handleEvent);
|
||||
clearTimers();
|
||||
Info(_log, "Event scheduler stopped");
|
||||
}
|
||||
|
@@ -39,12 +39,12 @@ OsEventHandlerBase::OsEventHandlerBase()
|
||||
{
|
||||
_isService = true;
|
||||
}
|
||||
QObject::connect(this, &OsEventHandlerBase::signalEvent, EventHandler::getInstance(), &EventHandler::handleEvent);
|
||||
QObject::connect(this, &OsEventHandlerBase::signalEvent, EventHandler::getInstance().data(), &EventHandler::handleEvent);
|
||||
}
|
||||
|
||||
OsEventHandlerBase::~OsEventHandlerBase()
|
||||
{
|
||||
QObject::disconnect(this, &OsEventHandlerBase::signalEvent, EventHandler::getInstance(), &EventHandler::handleEvent);
|
||||
QObject::disconnect(this, &OsEventHandlerBase::signalEvent, EventHandler::getInstance().data(), &EventHandler::handleEvent);
|
||||
|
||||
OsEventHandlerBase::unregisterLockHandler();
|
||||
OsEventHandlerBase::unregisterOsEventHandler();
|
||||
|
@@ -27,36 +27,43 @@ bool GrabberWrapper::GLOBAL_GRABBER_AUDIO_ENABLE = false;
|
||||
GrabberWrapper::GrabberWrapper(const QString& grabberName, Grabber * ggrabber, int updateRate_Hz)
|
||||
: _grabberName(grabberName)
|
||||
, _log(Logger::getInstance(grabberName.toUpper()))
|
||||
, _timer(new QTimer(this))
|
||||
, _timer(nullptr)
|
||||
, _updateInterval_ms(1000/updateRate_Hz)
|
||||
, _ggrabber(ggrabber)
|
||||
{
|
||||
GrabberWrapper::instance = this;
|
||||
|
||||
_timer.reset(new QTimer(this));
|
||||
|
||||
// Configure the timer to generate events every n milliseconds
|
||||
_timer->setTimerType(Qt::PreciseTimer);
|
||||
_timer->setInterval(_updateInterval_ms);
|
||||
|
||||
connect(_timer, &QTimer::timeout, this, &GrabberWrapper::action);
|
||||
connect(_timer.get(), &QTimer::timeout, this, &GrabberWrapper::action);
|
||||
|
||||
// connect the image forwarding
|
||||
if (_grabberName.startsWith("V4L"))
|
||||
{
|
||||
connect(this, &GrabberWrapper::systemImage, GlobalSignals::getInstance(), &GlobalSignals::setV4lImage);
|
||||
}
|
||||
else if (_grabberName.startsWith("Audio"))
|
||||
{
|
||||
connect(this, &GrabberWrapper::systemImage, GlobalSignals::getInstance(), &GlobalSignals::setAudioImage);
|
||||
}
|
||||
else
|
||||
{
|
||||
connect(this, &GrabberWrapper::systemImage, GlobalSignals::getInstance(), &GlobalSignals::setSystemImage);
|
||||
}
|
||||
|
||||
// listen for source requests
|
||||
connect(GlobalSignals::getInstance(), &GlobalSignals::requestSource, this, &GrabberWrapper::handleSourceRequest);
|
||||
|
||||
QObject::connect(EventHandler::getInstance(), &EventHandler::signalEvent, this, &GrabberWrapper::handleEvent);
|
||||
QObject::connect(EventHandler::getInstance().data(), &EventHandler::signalEvent, this, &GrabberWrapper::handleEvent);
|
||||
}
|
||||
|
||||
GrabberWrapper::~GrabberWrapper()
|
||||
{
|
||||
_timer->stop();
|
||||
delete _timer;
|
||||
GrabberWrapper::instance = nullptr;
|
||||
}
|
||||
|
||||
@@ -104,19 +111,25 @@ QStringList GrabberWrapper::getActive(int inst, GrabberTypeFilter type) const
|
||||
if (type == GrabberTypeFilter::SCREEN || type == GrabberTypeFilter::ALL)
|
||||
{
|
||||
if (GRABBER_SYS_CLIENTS.contains(inst))
|
||||
{
|
||||
result << GRABBER_SYS_CLIENTS.value(inst);
|
||||
}
|
||||
}
|
||||
|
||||
if (type == GrabberTypeFilter::VIDEO || type == GrabberTypeFilter::ALL)
|
||||
{
|
||||
if (GRABBER_V4L_CLIENTS.contains(inst))
|
||||
{
|
||||
result << GRABBER_V4L_CLIENTS.value(inst);
|
||||
}
|
||||
}
|
||||
|
||||
if (type == GrabberTypeFilter::AUDIO || type == GrabberTypeFilter::ALL)
|
||||
{
|
||||
if (GRABBER_AUDIO_CLIENTS.contains(inst))
|
||||
{
|
||||
result << GRABBER_AUDIO_CLIENTS.value(inst);
|
||||
}
|
||||
}
|
||||
|
||||
return result;
|
||||
@@ -208,7 +221,9 @@ void GrabberWrapper::updateTimer(int interval)
|
||||
_timer->setInterval(_updateInterval_ms);
|
||||
|
||||
if(timerWasActive)
|
||||
{
|
||||
_timer->start();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -269,40 +284,64 @@ void GrabberWrapper::handleSourceRequest(hyperion::Components component, int hyp
|
||||
!_grabberName.startsWith("Audio"))
|
||||
{
|
||||
if (listen)
|
||||
{
|
||||
GRABBER_SYS_CLIENTS.insert(hyperionInd, _grabberName);
|
||||
}
|
||||
else
|
||||
{
|
||||
GRABBER_SYS_CLIENTS.remove(hyperionInd);
|
||||
}
|
||||
|
||||
if (GRABBER_SYS_CLIENTS.empty() || !getSysGrabberState())
|
||||
{
|
||||
stop();
|
||||
}
|
||||
else
|
||||
{
|
||||
start();
|
||||
}
|
||||
}
|
||||
else if (component == hyperion::Components::COMP_V4L &&
|
||||
_grabberName.startsWith("V4L"))
|
||||
{
|
||||
if (listen)
|
||||
{
|
||||
GRABBER_V4L_CLIENTS.insert(hyperionInd, _grabberName);
|
||||
}
|
||||
else
|
||||
{
|
||||
GRABBER_V4L_CLIENTS.remove(hyperionInd);
|
||||
}
|
||||
|
||||
if (GRABBER_V4L_CLIENTS.empty() || !getV4lGrabberState())
|
||||
{
|
||||
stop();
|
||||
}
|
||||
else
|
||||
{
|
||||
start();
|
||||
}
|
||||
}
|
||||
else if (component == hyperion::Components::COMP_AUDIO &&
|
||||
_grabberName.startsWith("Audio"))
|
||||
{
|
||||
if (listen)
|
||||
{
|
||||
GRABBER_AUDIO_CLIENTS.insert(hyperionInd, _grabberName);
|
||||
}
|
||||
else
|
||||
{
|
||||
GRABBER_AUDIO_CLIENTS.remove(hyperionInd);
|
||||
}
|
||||
|
||||
if (GRABBER_AUDIO_CLIENTS.empty() || !getAudioGrabberState())
|
||||
{
|
||||
stop();
|
||||
}
|
||||
else
|
||||
{
|
||||
start();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user