mirror of
https://github.com/arcan1s/awesome-widgets.git
synced 2025-04-25 07:57:19 +00:00
I've added 'optimize' option (by default true). If it options is set then sources will be checked if they are required (with dependencies if any). And if they are not required they will be dropped by using common mechanism. Please note that if this option enabled the following features (at the moment) will be unavailable: * key request from context menu (from configuration interface it still works) * notifications event if sources on which notification is not connected I suppose this commit will increase performance in about 4-5 times.
102 lines
3.7 KiB
C++
102 lines
3.7 KiB
C++
/***************************************************************************
|
|
* This file is part of awesome-widgets *
|
|
* *
|
|
* awesome-widgets is free software: you can redistribute it and/or *
|
|
* modify it under the terms of the GNU General Public License as *
|
|
* published by the Free Software Foundation, either version 3 of the *
|
|
* License, or (at your option) any later version. *
|
|
* *
|
|
* awesome-widgets is distributed in the hope that it will be useful, *
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
|
* GNU General Public License for more details. *
|
|
* *
|
|
* You should have received a copy of the GNU General Public License *
|
|
* along with awesome-widgets. If not, see http://www.gnu.org/licenses/ *
|
|
***************************************************************************/
|
|
|
|
#include "awdataengineaggregator.h"
|
|
|
|
#include "awdebug.h"
|
|
#include "awkeys.h"
|
|
|
|
|
|
AWDataEngineAggregator::AWDataEngineAggregator(QObject *parent)
|
|
: QObject(parent)
|
|
{
|
|
qCDebug(LOG_AW) << __PRETTY_FUNCTION__;
|
|
}
|
|
|
|
|
|
AWDataEngineAggregator::~AWDataEngineAggregator()
|
|
{
|
|
qCDebug(LOG_AW) << __PRETTY_FUNCTION__;
|
|
|
|
clear();
|
|
}
|
|
|
|
|
|
void AWDataEngineAggregator::clear()
|
|
{
|
|
// disconnect sources first
|
|
disconnectSources();
|
|
m_dataEngines.clear();
|
|
delete m_consumer;
|
|
m_consumer = nullptr;
|
|
}
|
|
|
|
|
|
void AWDataEngineAggregator::disconnectSources()
|
|
{
|
|
for (auto dataengine : m_dataEngines.values())
|
|
for (auto source : dataengine->sources())
|
|
dataengine->disconnectSource(source, parent());
|
|
}
|
|
|
|
|
|
void AWDataEngineAggregator::initDataEngines(const int interval)
|
|
{
|
|
qCDebug(LOG_AW) << "Init dataengines with interval" << interval;
|
|
|
|
m_consumer = new Plasma::DataEngineConsumer();
|
|
m_dataEngines[QString("systemmonitor")]
|
|
= m_consumer->dataEngine(QString("systemmonitor"));
|
|
m_dataEngines[QString("extsysmon")]
|
|
= m_consumer->dataEngine(QString("extsysmon"));
|
|
m_dataEngines[QString("time")] = m_consumer->dataEngine(QString("time"));
|
|
|
|
// additional method required by systemmonitor structure
|
|
connect(m_dataEngines[QString("systemmonitor")],
|
|
&Plasma::DataEngine::sourceAdded,
|
|
[this, interval](const QString source) {
|
|
emit(deviceAdded(source));
|
|
m_dataEngines[QString("systemmonitor")]->connectSource(
|
|
source, parent(), interval);
|
|
});
|
|
|
|
return reconnectSources(interval);
|
|
}
|
|
|
|
|
|
void AWDataEngineAggregator::dropSource(const QString source)
|
|
{
|
|
qCDebug(LOG_AW) << "Source" << source;
|
|
|
|
// FIXME there is no possibility to check to which dataengine source
|
|
// connected we will try to disconnect it from systemmonitor and extsysmon
|
|
m_dataEngines[QString("systemmonitor")]->disconnectSource(source, parent());
|
|
m_dataEngines[QString("extsysmon")]->disconnectSource(source, parent());
|
|
}
|
|
|
|
|
|
void AWDataEngineAggregator::reconnectSources(const int interval)
|
|
{
|
|
qCDebug(LOG_AW) << "Reconnect sources with interval" << interval;
|
|
|
|
m_dataEngines[QString("systemmonitor")]->connectAllSources(parent(),
|
|
interval);
|
|
m_dataEngines[QString("extsysmon")]->connectAllSources(parent(), interval);
|
|
m_dataEngines[QString("time")]->connectSource(QString("Local"), parent(),
|
|
1000);
|
|
}
|