##// END OF EJS Templates
Merge branch 'feature/DatetimeColumns' into develop
Merge branch 'feature/DatetimeColumns' into develop

File last commit:

r243:e94f13bbc48f
r284:8ab9ca5324b3 merge
Show More
VariableController.cpp
164 lines | 5.6 KiB | text/x-c | CppLexer
/ core / src / Variable / VariableController.cpp
The mock plugin can now create data with view operation
r235 #include <Variable/Variable.h>
Create a variable notify the variable cache parameter
r225 #include <Variable/VariableCacheController.h>
Alexandre Leroux
Inits variable controller and adds it to the SciQlop app
r111 #include <Variable/VariableController.h>
Alexandre Leroux
Adds Variable model in the Variable controller
r113 #include <Variable/VariableModel.h>
Alexandre Leroux
Inits variable controller and adds it to the SciQlop app
r111
Alexandre Leroux
Updates VariableController::createVariable() method...
r166 #include <Data/DataProviderParameters.h>
#include <Data/IDataProvider.h>
#include <Data/IDataSeries.h>
Time widget is now used with the variable createion request
r193 #include <Time/TimeController.h>
Alexandre Leroux
Updates VariableController::createVariable() method...
r166
#include <QDateTime>
The mock plugin can now create data with view operation
r235 #include <QElapsedTimer>
Alexandre Leroux
Inits variable controller and adds it to the SciQlop app
r111 #include <QMutex>
#include <QThread>
Create a variable notify the variable cache parameter
r225 #include <unordered_map>
Alexandre Leroux
Inits variable controller and adds it to the SciQlop app
r111 Q_LOGGING_CATEGORY(LOG_VariableController, "VariableController")
Alexandre Leroux
Updates VariableController::createVariable() method...
r166 namespace {
/// @todo Generates default dataseries, according to the provider passed in parameter. This method
/// will be deleted when the timerange is recovered from SciQlop
Time widget is now used with the variable createion request
r193 std::unique_ptr<IDataSeries> generateDefaultDataSeries(const IDataProvider &provider,
const SqpDateTime &dateTime) noexcept
Alexandre Leroux
Updates VariableController::createVariable() method...
r166 {
Time widget is now used with the variable createion request
r193 auto parameters = DataProviderParameters{dateTime};
Alexandre Leroux
Updates VariableController::createVariable() method...
r166
return provider.retrieveData(parameters);
}
} // namespace
Alexandre Leroux
Inits variable controller and adds it to the SciQlop app
r111 struct VariableController::VariableControllerPrivate {
Alexandre Leroux
Use raw pointer for VariableModel (QObject class)
r159 explicit VariableControllerPrivate(VariableController *parent)
Create a variable notify the variable cache parameter
r225 : m_WorkingMutex{},
m_VariableModel{new VariableModel{parent}},
m_VariableCacheController{std::make_unique<VariableCacheController>()}
Alexandre Leroux
Inits variable controller and adds it to the SciQlop app
r111 {
}
QMutex m_WorkingMutex;
Alexandre Leroux
Use raw pointer for VariableModel (QObject class)
r159 /// Variable model. The VariableController has the ownership
VariableModel *m_VariableModel;
Time widget is now used with the variable createion request
r193
Create a variable notify the variable cache parameter
r225
Correction MR
r195 TimeController *m_TimeController{nullptr};
Create a variable notify the variable cache parameter
r225 std::unique_ptr<VariableCacheController> m_VariableCacheController;
The mock plugin can now create data with view operation
r235
std::unordered_map<std::shared_ptr<Variable>, std::shared_ptr<IDataProvider> >
m_VariableToProviderMap;
Alexandre Leroux
Inits variable controller and adds it to the SciQlop app
r111 };
VariableController::VariableController(QObject *parent)
Alexandre Leroux
Use raw pointer for VariableModel (QObject class)
r159 : QObject{parent}, impl{spimpl::make_unique_impl<VariableControllerPrivate>(this)}
Alexandre Leroux
Inits variable controller and adds it to the SciQlop app
r111 {
Add the TimeWidget
r134 qCDebug(LOG_VariableController()) << tr("VariableController construction")
<< QThread::currentThread();
Alexandre Leroux
Inits variable controller and adds it to the SciQlop app
r111 }
VariableController::~VariableController()
{
Add the TimeWidget
r134 qCDebug(LOG_VariableController()) << tr("VariableController destruction")
<< QThread::currentThread();
Alexandre Leroux
Inits variable controller and adds it to the SciQlop app
r111 this->waitForFinish();
}
Alexandre Leroux
Updates VariableController::createVariable() method...
r166 VariableModel *VariableController::variableModel() noexcept
Alexandre Leroux
Adds Variable model in the Variable controller
r113 {
Alexandre Leroux
Updates VariableController::createVariable() method...
r166 return impl->m_VariableModel;
Alexandre Leroux
Adds Variable model in the Variable controller
r113 }
Time widget is now used with the variable createion request
r193 void VariableController::setTimeController(TimeController *timeController) noexcept
{
impl->m_TimeController = timeController;
}
Alexandre Leroux
Updates VariableController::createVariable() method...
r166 void VariableController::createVariable(const QString &name,
std::shared_ptr<IDataProvider> provider) noexcept
Alexandre Leroux
Affects model to the Variable Widget
r152 {
Time widget is now used with the variable createion request
r193
if (!impl->m_TimeController) {
qCCritical(LOG_VariableController())
<< tr("Impossible to create variable: The time controller is null");
return;
}
Alexandre Leroux
Updates VariableController::createVariable() method...
r166 /// @todo : for the moment :
/// - the provider is only used to retrieve data from the variable for its initialization, but
/// it will be retained later
/// - default data are generated for the variable, without taking into account the timerange set
/// in sciqlop
Create a variable notify the variable cache parameter
r225 auto dateTime = impl->m_TimeController->dateTime();
Time widget is now used with the variable createion request
r193 if (auto newVariable = impl->m_VariableModel->createVariable(
A variable is now created with its dateTime too....
r228 name, dateTime, generateDefaultDataSeries(*provider, dateTime))) {
Create a variable notify the variable cache parameter
r225
The mock plugin can now create data with view operation
r235 // store the provider
impl->m_VariableToProviderMap[newVariable] = provider;
qRegisterMetaType<std::shared_ptr<IDataSeries> >();
qRegisterMetaType<SqpDateTime>();
connect(provider.get(), &IDataProvider::dataProvided, newVariable.get(),
&Variable::onAddDataSeries);
Create a variable notify the variable cache parameter
r225 // store in cache
impl->m_VariableCacheController->addDateTime(newVariable, dateTime);
// notify the creation
Alexandre Leroux
Updates VariableController::createVariable() method...
r166 emit variableCreated(newVariable);
}
Alexandre Leroux
Affects model to the Variable Widget
r152 }
The mock plugin can now create data with view operation
r235
void VariableController::requestDataLoading(std::shared_ptr<Variable> variable,
const SqpDateTime &dateTime)
{
// we want to load data of the variable for the dateTime.
// First we check if the cache contains some of them.
// For the other, we ask the provider to give them.
if (variable) {
QElapsedTimer timer;
timer.start();
Correction for pull request
r243 qCInfo(LOG_VariableController()) << "TORM: The slow s0 operation took" << timer.elapsed()
The mock plugin can now create data with view operation
r235 << "milliseconds";
auto dateTimeListNotInCache
= impl->m_VariableCacheController->provideNotInCacheDateTimeList(variable, dateTime);
Correction for pull request
r243 qCInfo(LOG_VariableController()) << "TORM: The slow s1 operation took" << timer.elapsed()
The mock plugin can now create data with view operation
r235 << "milliseconds";
// Ask the provider for each data on the dateTimeListNotInCache
impl->m_VariableToProviderMap.at(variable)->requestDataLoading(dateTimeListNotInCache);
Correction for pull request
r243 qCInfo(LOG_VariableController()) << "TORM: The slow s2 operation took" << timer.elapsed()
The mock plugin can now create data with view operation
r235 << "milliseconds";
// store in cache
impl->m_VariableCacheController->addDateTime(variable, dateTime);
Correction for pull request
r243 qCInfo(LOG_VariableController()) << "TORM: The slow s3 operation took" << timer.elapsed()
The mock plugin can now create data with view operation
r235 << "milliseconds";
}
else {
qCCritical(LOG_VariableController()) << tr("Impossible to load data of a variable null");
}
}
Alexandre Leroux
Inits variable controller and adds it to the SciQlop app
r111 void VariableController::initialize()
{
qCDebug(LOG_VariableController()) << tr("VariableController init") << QThread::currentThread();
impl->m_WorkingMutex.lock();
qCDebug(LOG_VariableController()) << tr("VariableController init END");
}
void VariableController::finalize()
{
impl->m_WorkingMutex.unlock();
}
void VariableController::waitForFinish()
{
QMutexLocker locker{&impl->m_WorkingMutex};
}