DataSourceController.cpp
78 lines
| 2.5 KiB
| text/x-c
|
CppLexer
Alexandre Leroux
|
r32 | #include <DataSource/DataSourceController.h> | ||
Alexandre Leroux
|
r37 | #include <DataSource/DataSourceItem.h> | ||
r21 | ||||
#include <QMutex> | ||||
#include <QThread> | ||||
r25 | #include <QDir> | |||
#include <QStandardPaths> | ||||
Q_LOGGING_CATEGORY(LOG_DataSourceController, "DataSourceController") | ||||
r21 | ||||
class DataSourceController::DataSourceControllerPrivate { | ||||
public: | ||||
QMutex m_WorkingMutex; | ||||
Alexandre Leroux
|
r37 | /// Data sources registered | ||
Alexandre Leroux
|
r36 | QHash<QUuid, QString> m_DataSources; | ||
Alexandre Leroux
|
r37 | /// Data sources structures | ||
std::map<QUuid, std::unique_ptr<DataSourceItem> > m_DataSourceItems; | ||||
r21 | }; | |||
DataSourceController::DataSourceController(QObject *parent) | ||||
: impl{spimpl::make_unique_impl<DataSourceControllerPrivate>()} | ||||
{ | ||||
Alexandre Leroux
|
r32 | qCDebug(LOG_DataSourceController()) | ||
<< tr("DataSourceController construction") << QThread::currentThread(); | ||||
r21 | } | |||
DataSourceController::~DataSourceController() | ||||
{ | ||||
Alexandre Leroux
|
r32 | qCDebug(LOG_DataSourceController()) | ||
<< tr("DataSourceController destruction") << QThread::currentThread(); | ||||
r21 | this->waitForFinish(); | |||
} | ||||
Alexandre Leroux
|
r36 | QUuid DataSourceController::registerDataSource(const QString &dataSourceName) noexcept | ||
{ | ||||
auto dataSourceUid = QUuid::createUuid(); | ||||
impl->m_DataSources.insert(dataSourceUid, dataSourceName); | ||||
return dataSourceUid; | ||||
} | ||||
Alexandre Leroux
|
r37 | void DataSourceController::setDataSourceItem( | ||
const QUuid &dataSourceUid, std::unique_ptr<DataSourceItem> dataSourceItem) noexcept | ||||
{ | ||||
if (impl->m_DataSources.contains(dataSourceUid)) { | ||||
impl->m_DataSourceItems.insert(std::make_pair(dataSourceUid, std::move(dataSourceItem))); | ||||
// Retrieves the data source item to emit the signal with it | ||||
auto it = impl->m_DataSourceItems.find(dataSourceUid); | ||||
if (it != impl->m_DataSourceItems.end()) { | ||||
emit dataSourceItemSet(*it->second); | ||||
} | ||||
} | ||||
else { | ||||
qCWarning(LOG_DataSourceController()) << tr("Can't set data source item for uid %1 : no " | ||||
"data source has been registered with the uid") | ||||
.arg(dataSourceUid.toString()); | ||||
} | ||||
} | ||||
r21 | void DataSourceController::initialize() | |||
{ | ||||
Alexandre Leroux
|
r32 | qCDebug(LOG_DataSourceController()) | ||
<< tr("DataSourceController init") << QThread::currentThread(); | ||||
r21 | impl->m_WorkingMutex.lock(); | |||
Alexandre Leroux
|
r32 | qCDebug(LOG_DataSourceController()) << tr("DataSourceController init END"); | ||
r21 | } | |||
void DataSourceController::finalize() | ||||
{ | ||||
impl->m_WorkingMutex.unlock(); | ||||
} | ||||
void DataSourceController::waitForFinish() | ||||
{ | ||||
Alexandre Leroux
|
r32 | QMutexLocker locker{&impl->m_WorkingMutex}; | ||
r21 | } | |||