2012-12-08 15:25:50 +01:00
|
|
|
#include "operation.hpp"
|
|
|
|
|
2012-12-08 18:38:36 +01:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
2012-12-08 15:25:50 +01:00
|
|
|
#include <QTimer>
|
|
|
|
|
2014-05-08 12:42:29 +02:00
|
|
|
#include "../world/universalid.hpp"
|
|
|
|
|
2013-09-14 14:56:23 +02:00
|
|
|
#include "state.hpp"
|
2012-12-08 17:53:45 +01:00
|
|
|
#include "stage.hpp"
|
|
|
|
|
2013-09-14 14:56:23 +02:00
|
|
|
void CSMDoc::Operation::prepareStages()
|
2012-12-08 17:53:45 +01:00
|
|
|
{
|
|
|
|
mCurrentStage = mStages.begin();
|
|
|
|
mCurrentStep = 0;
|
|
|
|
mCurrentStepTotal = 0;
|
|
|
|
mTotalSteps = 0;
|
2013-09-15 12:03:36 +02:00
|
|
|
mError = false;
|
2012-12-08 17:53:45 +01:00
|
|
|
|
|
|
|
for (std::vector<std::pair<Stage *, int> >::iterator iter (mStages.begin()); iter!=mStages.end(); ++iter)
|
|
|
|
{
|
2012-12-08 23:27:59 +01:00
|
|
|
iter->second = iter->first->setup();
|
|
|
|
mTotalSteps += iter->second;
|
2012-12-08 17:53:45 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-09-15 12:03:36 +02:00
|
|
|
CSMDoc::Operation::Operation (int type, bool ordered, bool finalAlways)
|
2014-10-11 00:06:50 +02:00
|
|
|
: mType (type), mStages(std::vector<std::pair<Stage *, int> >()), mCurrentStage(mStages.begin()),
|
|
|
|
mCurrentStep(0), mCurrentStepTotal(0), mTotalSteps(0), mOrdered (ordered),
|
2015-06-20 19:04:19 +02:00
|
|
|
mFinalAlways (finalAlways), mError(false), mConnected (false), mPrepared (false),
|
|
|
|
mDefaultSeverity (Message::Severity_Error)
|
2013-09-15 11:35:12 +02:00
|
|
|
{
|
2015-03-14 12:00:24 +01:00
|
|
|
mTimer = new QTimer (this);
|
2013-09-15 11:35:12 +02:00
|
|
|
}
|
2012-12-08 15:25:50 +01:00
|
|
|
|
2013-09-14 14:56:23 +02:00
|
|
|
CSMDoc::Operation::~Operation()
|
2012-12-08 17:53:45 +01:00
|
|
|
{
|
|
|
|
for (std::vector<std::pair<Stage *, int> >::iterator iter (mStages.begin()); iter!=mStages.end(); ++iter)
|
|
|
|
delete iter->first;
|
|
|
|
}
|
|
|
|
|
2013-09-14 14:56:23 +02:00
|
|
|
void CSMDoc::Operation::run()
|
2012-12-08 15:25:50 +01:00
|
|
|
{
|
2015-03-14 12:00:24 +01:00
|
|
|
mTimer->stop();
|
2015-12-15 12:44:04 +01:00
|
|
|
|
2015-03-14 12:00:24 +01:00
|
|
|
if (!mConnected)
|
|
|
|
{
|
|
|
|
connect (mTimer, SIGNAL (timeout()), this, SLOT (executeStage()));
|
|
|
|
mConnected = true;
|
|
|
|
}
|
2015-06-20 14:21:52 +02:00
|
|
|
|
|
|
|
mPrepared = false;
|
2012-12-08 15:25:50 +01:00
|
|
|
|
2015-03-14 12:00:24 +01:00
|
|
|
mTimer->start (0);
|
2012-12-08 15:25:50 +01:00
|
|
|
}
|
|
|
|
|
2013-09-14 14:56:23 +02:00
|
|
|
void CSMDoc::Operation::appendStage (Stage *stage)
|
2012-12-08 17:53:45 +01:00
|
|
|
{
|
|
|
|
mStages.push_back (std::make_pair (stage, 0));
|
|
|
|
}
|
|
|
|
|
2015-06-20 19:04:19 +02:00
|
|
|
void CSMDoc::Operation::setDefaultSeverity (Message::Severity severity)
|
|
|
|
{
|
|
|
|
mDefaultSeverity = severity;
|
|
|
|
}
|
|
|
|
|
2013-09-15 12:03:36 +02:00
|
|
|
bool CSMDoc::Operation::hasError() const
|
|
|
|
{
|
|
|
|
return mError;
|
|
|
|
}
|
|
|
|
|
2013-09-14 14:56:23 +02:00
|
|
|
void CSMDoc::Operation::abort()
|
2012-12-08 15:25:50 +01:00
|
|
|
{
|
2015-03-14 12:00:24 +01:00
|
|
|
if (!mTimer->isActive())
|
2013-09-15 12:03:36 +02:00
|
|
|
return;
|
|
|
|
|
|
|
|
mError = true;
|
|
|
|
|
|
|
|
if (mFinalAlways)
|
|
|
|
{
|
|
|
|
if (mStages.begin()!=mStages.end() && mCurrentStage!=--mStages.end())
|
|
|
|
{
|
|
|
|
mCurrentStep = 0;
|
|
|
|
mCurrentStage = --mStages.end();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
mCurrentStage = mStages.end();
|
2012-12-08 15:25:50 +01:00
|
|
|
}
|
|
|
|
|
2013-09-15 09:32:20 +02:00
|
|
|
void CSMDoc::Operation::executeStage()
|
2012-12-08 15:25:50 +01:00
|
|
|
{
|
2015-06-20 14:21:52 +02:00
|
|
|
if (!mPrepared)
|
|
|
|
{
|
|
|
|
prepareStages();
|
|
|
|
mPrepared = true;
|
|
|
|
}
|
2015-12-15 12:44:04 +01:00
|
|
|
|
2015-06-20 19:04:19 +02:00
|
|
|
Messages messages (mDefaultSeverity);
|
2012-12-08 18:38:36 +01:00
|
|
|
|
2012-12-08 17:53:45 +01:00
|
|
|
while (mCurrentStage!=mStages.end())
|
|
|
|
{
|
|
|
|
if (mCurrentStep>=mCurrentStage->second)
|
|
|
|
{
|
|
|
|
mCurrentStep = 0;
|
|
|
|
++mCurrentStage;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2013-09-15 12:03:36 +02:00
|
|
|
try
|
|
|
|
{
|
|
|
|
mCurrentStage->first->perform (mCurrentStep++, messages);
|
|
|
|
}
|
2013-09-27 13:54:51 +02:00
|
|
|
catch (const std::exception& e)
|
2013-09-15 12:03:36 +02:00
|
|
|
{
|
2015-06-20 19:04:19 +02:00
|
|
|
emit reportMessage (Message (CSMWorld::UniversalId(), e.what(), "", Message::Severity_SeriousError), mType);
|
2013-09-15 12:03:36 +02:00
|
|
|
abort();
|
|
|
|
}
|
|
|
|
|
2012-12-08 17:53:45 +01:00
|
|
|
++mCurrentStepTotal;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
emit progress (mCurrentStepTotal, mTotalSteps ? mTotalSteps : 1, mType);
|
2012-12-08 15:25:50 +01:00
|
|
|
|
2014-12-07 18:57:47 +01:00
|
|
|
for (Messages::Iterator iter (messages.begin()); iter!=messages.end(); ++iter)
|
2015-06-20 17:56:42 +02:00
|
|
|
emit reportMessage (*iter, mType);
|
2012-12-08 18:38:36 +01:00
|
|
|
|
2012-12-08 17:53:45 +01:00
|
|
|
if (mCurrentStage==mStages.end())
|
2015-03-14 12:00:24 +01:00
|
|
|
operationDone();
|
2013-09-15 11:35:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void CSMDoc::Operation::operationDone()
|
|
|
|
{
|
2015-03-14 12:00:24 +01:00
|
|
|
mTimer->stop();
|
2014-09-03 19:14:27 +02:00
|
|
|
emit done (mType, mError);
|
2014-10-11 00:06:50 +02:00
|
|
|
}
|