openmw-tes3coop/apps/opencs/model/doc/loader.cpp

136 lines
3.5 KiB
C++
Raw Normal View History

2014-04-24 13:09:25 +00:00
#include "loader.hpp"
#include <QTimer>
2014-05-10 10:04:36 +00:00
#include "../tools/reportmodel.hpp"
2014-04-24 13:09:25 +00:00
#include "document.hpp"
2014-05-10 10:04:36 +00:00
#include "state.hpp"
2014-04-24 13:09:25 +00:00
2014-06-26 09:41:21 +00:00
CSMDoc::Loader::Stage::Stage() : mFile (0), mRecordsLoaded (0), mRecordsLeft (false) {}
2014-04-24 13:09:25 +00:00
CSMDoc::Loader::Loader()
{
QTimer *timer = new QTimer (this);
connect (timer, SIGNAL (timeout()), this, SLOT (load()));
timer->start();
2014-04-24 13:09:25 +00:00
}
QWaitCondition& CSMDoc::Loader::hasThingsToDo()
{
return mThingsToDo;
}
void CSMDoc::Loader::load()
{
if (mDocuments.empty())
{
mMutex.lock();
mThingsToDo.wait (&mMutex);
mMutex.unlock();
return;
}
std::vector<std::pair<Document *, Stage> >::iterator iter = mDocuments.begin();
2014-04-24 13:09:25 +00:00
Document *document = iter->first;
int size = static_cast<int> (document->getContentFiles().size());
int editedIndex = size-1; // index of the file to be edited/created
if (document->isNew())
--size;
bool done = false;
2014-04-24 13:09:25 +00:00
try
{
if (iter->second.mRecordsLeft)
{
Messages messages (Message::Severity_Error);
2016-01-03 17:20:34 +00:00
const int batchingSize = 50;
2014-05-03 13:33:35 +00:00
for (int i=0; i<batchingSize; ++i) // do not flood the system with update signals
2014-05-10 10:04:36 +00:00
if (document->getData().continueLoading (messages))
2014-05-03 13:33:35 +00:00
{
iter->second.mRecordsLeft = false;
break;
}
2014-06-26 09:41:21 +00:00
else
++(iter->second.mRecordsLoaded);
2014-05-03 13:33:35 +00:00
2014-05-10 10:04:36 +00:00
CSMWorld::UniversalId log (CSMWorld::UniversalId::Type_LoadErrorLog, 0);
2014-06-26 09:41:21 +00:00
{ // silence a g++ warning
for (CSMDoc::Messages::Iterator iter (messages.begin());
2014-05-10 10:04:36 +00:00
iter!=messages.end(); ++iter)
{
document->getReport (log)->add (*iter);
emit loadMessage (document, iter->mMessage);
}
2014-06-26 09:41:21 +00:00
}
2014-05-10 10:04:36 +00:00
2014-06-26 09:41:21 +00:00
emit nextRecord (document, iter->second.mRecordsLoaded);
return;
}
if (iter->second.mFile<size)
{
2014-05-03 11:01:29 +00:00
boost::filesystem::path path = document->getContentFiles()[iter->second.mFile];
int steps = document->getData().startLoading (path, iter->second.mFile!=editedIndex, false);
iter->second.mRecordsLeft = true;
2014-06-26 09:41:21 +00:00
iter->second.mRecordsLoaded = 0;
2014-05-03 13:33:35 +00:00
2014-06-26 09:41:21 +00:00
emit nextStage (document, path.filename().string(), steps);
}
else if (iter->second.mFile==size)
{
2014-05-03 13:33:35 +00:00
int steps = document->getData().startLoading (document->getProjectPath(), false, true);
iter->second.mRecordsLeft = true;
2014-06-26 09:41:21 +00:00
iter->second.mRecordsLoaded = 0;
2014-05-03 13:33:35 +00:00
2014-06-26 09:41:21 +00:00
emit nextStage (document, "Project File", steps);
}
else
{
done = true;
}
++(iter->second.mFile);
2014-04-24 13:09:25 +00:00
}
catch (const std::exception& e)
{
mDocuments.erase (iter);
2014-04-24 13:09:25 +00:00
emit documentNotLoaded (document, e.what());
return;
}
if (done)
{
mDocuments.erase (iter);
emit documentLoaded (document);
2014-04-24 13:09:25 +00:00
}
}
void CSMDoc::Loader::loadDocument (CSMDoc::Document *document)
2014-04-24 13:09:25 +00:00
{
mDocuments.push_back (std::make_pair (document, Stage()));
2014-04-24 13:09:25 +00:00
}
2014-05-03 14:44:50 +00:00
void CSMDoc::Loader::abortLoading (CSMDoc::Document *document)
2014-04-24 13:09:25 +00:00
{
for (std::vector<std::pair<Document *, Stage> >::iterator iter = mDocuments.begin();
2014-04-24 13:09:25 +00:00
iter!=mDocuments.end(); ++iter)
{
if (iter->first==document)
{
mDocuments.erase (iter);
emit documentNotLoaded (document, "");
break;
}
}
2014-05-03 14:44:50 +00:00
}