PrismLauncher/api/logic/InstanceCopyTask.cpp

57 lines
1.8 KiB
C++
Raw Normal View History

2016-10-03 00:55:54 +02:00
#include "InstanceCopyTask.h"
#include "settings/INISettingsObject.h"
#include "FileSystem.h"
#include "NullInstance.h"
#include "pathmatcher/RegexpMatcher.h"
#include <QtConcurrentRun>
2016-10-03 00:55:54 +02:00
2018-03-19 02:36:12 +01:00
InstanceCopyTask::InstanceCopyTask(InstancePtr origInstance, bool copySaves)
2016-10-03 00:55:54 +02:00
{
2018-07-15 14:51:05 +02:00
m_origInstance = origInstance;
if(!copySaves)
{
// FIXME: get this from the original instance type...
auto matcherReal = new RegexpMatcher("[.]?minecraft/saves");
matcherReal->caseSensitive(false);
m_matcher.reset(matcherReal);
}
}
2016-10-03 00:55:54 +02:00
void InstanceCopyTask::executeTask()
{
2018-07-15 14:51:05 +02:00
setStatus(tr("Copying instance %1").arg(m_origInstance->name()));
2018-07-15 14:51:05 +02:00
FS::copy folderCopy(m_origInstance->instanceRoot(), m_stagingPath);
folderCopy.followSymlinks(false).blacklist(m_matcher.get());
2018-07-15 14:51:05 +02:00
m_copyFuture = QtConcurrent::run(QThreadPool::globalInstance(), folderCopy);
connect(&m_copyFutureWatcher, &QFutureWatcher<bool>::finished, this, &InstanceCopyTask::copyFinished);
connect(&m_copyFutureWatcher, &QFutureWatcher<bool>::canceled, this, &InstanceCopyTask::copyAborted);
m_copyFutureWatcher.setFuture(m_copyFuture);
}
void InstanceCopyTask::copyFinished()
{
2018-07-15 14:51:05 +02:00
auto successful = m_copyFuture.result();
if(!successful)
{
emitFailed(tr("Instance folder copy failed."));
return;
}
// FIXME: shouldn't this be able to report errors?
auto instanceSettings = std::make_shared<INISettingsObject>(FS::PathCombine(m_stagingPath, "instance.cfg"));
instanceSettings->registerSetting("InstanceType", "Legacy");
InstancePtr inst(new NullInstance(m_globalSettings, instanceSettings, m_stagingPath));
inst->setName(m_instName);
inst->setIconKey(m_instIcon);
emitSucceeded();
2016-10-03 00:55:54 +02:00
}
void InstanceCopyTask::copyAborted()
{
2018-07-15 14:51:05 +02:00
emitFailed(tr("Instance folder copy has been aborted."));
return;
}