2012-12-08 14:25:50 +00:00
|
|
|
|
|
|
|
#include "operation.hpp"
|
|
|
|
|
2012-12-08 17:38:36 +00:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
2012-12-08 14:25:50 +00:00
|
|
|
#include <QTimer>
|
|
|
|
|
2014-05-08 10:42:29 +00:00
|
|
|
#include "../world/universalid.hpp"
|
|
|
|
|
2013-09-14 12:56:23 +00:00
|
|
|
#include "state.hpp"
|
2012-12-08 16:53:45 +00:00
|
|
|
#include "stage.hpp"
|
|
|
|
|
2013-09-14 12:56:23 +00:00
|
|
|
void CSMDoc::Operation::prepareStages()
|
2012-12-08 16:53:45 +00:00
|
|
|
{
|
|
|
|
mCurrentStage = mStages.begin();
|
|
|
|
mCurrentStep = 0;
|
|
|
|
mCurrentStepTotal = 0;
|
|
|
|
mTotalSteps = 0;
|
2013-09-15 10:03:36 +00:00
|
|
|
mError = false;
|
2012-12-08 16:53:45 +00:00
|
|
|
|
|
|
|
for (std::vector<std::pair<Stage *, int> >::iterator iter (mStages.begin()); iter!=mStages.end(); ++iter)
|
|
|
|
{
|
2012-12-08 22:27:59 +00:00
|
|
|
iter->second = iter->first->setup();
|
|
|
|
mTotalSteps += iter->second;
|
2012-12-08 16:53:45 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-09-15 10:03:36 +00:00
|
|
|
CSMDoc::Operation::Operation (int type, bool ordered, bool finalAlways)
|
2014-10-10 22:06:50 +00:00
|
|
|
: mType (type), mStages(std::vector<std::pair<Stage *, int> >()), mCurrentStage(mStages.begin()),
|
|
|
|
mCurrentStep(0), mCurrentStepTotal(0), mTotalSteps(0), mOrdered (ordered),
|
|
|
|
mFinalAlways (finalAlways), mError(false)
|
2013-09-15 09:35:12 +00:00
|
|
|
{
|
|
|
|
connect (this, SIGNAL (finished()), this, SLOT (operationDone()));
|
|
|
|
}
|
2012-12-08 14:25:50 +00:00
|
|
|
|
2013-09-14 12:56:23 +00:00
|
|
|
CSMDoc::Operation::~Operation()
|
2012-12-08 16:53:45 +00:00
|
|
|
{
|
|
|
|
for (std::vector<std::pair<Stage *, int> >::iterator iter (mStages.begin()); iter!=mStages.end(); ++iter)
|
|
|
|
delete iter->first;
|
|
|
|
}
|
|
|
|
|
2013-09-14 12:56:23 +00:00
|
|
|
void CSMDoc::Operation::run()
|
2012-12-08 14:25:50 +00:00
|
|
|
{
|
2012-12-08 16:53:45 +00:00
|
|
|
prepareStages();
|
2012-12-08 14:25:50 +00:00
|
|
|
|
|
|
|
QTimer timer;
|
|
|
|
|
2013-09-15 07:32:20 +00:00
|
|
|
timer.connect (&timer, SIGNAL (timeout()), this, SLOT (executeStage()));
|
2012-12-08 14:25:50 +00:00
|
|
|
|
|
|
|
timer.start (0);
|
|
|
|
|
|
|
|
exec();
|
|
|
|
}
|
|
|
|
|
2013-09-14 12:56:23 +00:00
|
|
|
void CSMDoc::Operation::appendStage (Stage *stage)
|
2012-12-08 16:53:45 +00:00
|
|
|
{
|
|
|
|
mStages.push_back (std::make_pair (stage, 0));
|
|
|
|
}
|
|
|
|
|
2013-09-15 10:03:36 +00:00
|
|
|
bool CSMDoc::Operation::hasError() const
|
|
|
|
{
|
|
|
|
return mError;
|
|
|
|
}
|
|
|
|
|
2013-09-14 12:56:23 +00:00
|
|
|
void CSMDoc::Operation::abort()
|
2012-12-08 14:25:50 +00:00
|
|
|
{
|
2013-09-15 10:03:36 +00:00
|
|
|
if (!isRunning())
|
|
|
|
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 14:25:50 +00:00
|
|
|
}
|
|
|
|
|
2013-09-15 07:32:20 +00:00
|
|
|
void CSMDoc::Operation::executeStage()
|
2012-12-08 14:25:50 +00:00
|
|
|
{
|
2014-05-08 10:42:29 +00:00
|
|
|
Stage::Messages messages;
|
2012-12-08 17:38:36 +00:00
|
|
|
|
2012-12-08 16:53:45 +00:00
|
|
|
while (mCurrentStage!=mStages.end())
|
|
|
|
{
|
|
|
|
if (mCurrentStep>=mCurrentStage->second)
|
|
|
|
{
|
|
|
|
mCurrentStep = 0;
|
|
|
|
++mCurrentStage;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2013-09-15 10:03:36 +00:00
|
|
|
try
|
|
|
|
{
|
|
|
|
mCurrentStage->first->perform (mCurrentStep++, messages);
|
|
|
|
}
|
2013-09-27 11:54:51 +00:00
|
|
|
catch (const std::exception& e)
|
2013-09-15 10:03:36 +00:00
|
|
|
{
|
2014-05-08 10:42:29 +00:00
|
|
|
emit reportMessage (CSMWorld::UniversalId(), e.what(), mType);
|
2013-09-15 10:03:36 +00:00
|
|
|
abort();
|
|
|
|
}
|
|
|
|
|
2012-12-08 16:53:45 +00:00
|
|
|
++mCurrentStepTotal;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
emit progress (mCurrentStepTotal, mTotalSteps ? mTotalSteps : 1, mType);
|
2012-12-08 14:25:50 +00:00
|
|
|
|
2014-05-08 10:42:29 +00:00
|
|
|
for (Stage::Messages::const_iterator iter (messages.begin()); iter!=messages.end(); ++iter)
|
|
|
|
emit reportMessage (iter->first, iter->second, mType);
|
2012-12-08 17:38:36 +00:00
|
|
|
|
2012-12-08 16:53:45 +00:00
|
|
|
if (mCurrentStage==mStages.end())
|
2012-12-08 14:25:50 +00:00
|
|
|
exit();
|
2013-09-15 09:35:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void CSMDoc::Operation::operationDone()
|
|
|
|
{
|
2014-09-03 17:14:27 +00:00
|
|
|
emit done (mType, mError);
|
2014-10-10 22:06:50 +00:00
|
|
|
}
|