2016-10-02 23:55:54 +01:00
|
|
|
#include "InstanceCopyTask.h"
|
|
|
|
#include "BaseInstanceProvider.h"
|
|
|
|
#include "settings/INISettingsObject.h"
|
|
|
|
#include "FileSystem.h"
|
|
|
|
#include "NullInstance.h"
|
|
|
|
#include "pathmatcher/RegexpMatcher.h"
|
2016-10-26 17:12:33 +01:00
|
|
|
#include <QtConcurrentRun>
|
2016-10-02 23:55:54 +01:00
|
|
|
|
|
|
|
InstanceCopyTask::InstanceCopyTask(SettingsObjectPtr settings, BaseInstanceProvider* target, InstancePtr origInstance, const QString& instName, const QString& instIcon, const QString& instGroup, bool copySaves)
|
|
|
|
{
|
|
|
|
m_globalSettings = settings;
|
|
|
|
m_target = target;
|
|
|
|
m_origInstance = origInstance;
|
|
|
|
m_instName = instName;
|
|
|
|
m_instIcon = instIcon;
|
|
|
|
m_instGroup = instGroup;
|
|
|
|
|
2016-12-08 20:58:31 +00:00
|
|
|
if(!copySaves)
|
2016-10-02 23:55:54 +01:00
|
|
|
{
|
|
|
|
// FIXME: get this from the original instance type...
|
|
|
|
auto matcherReal = new RegexpMatcher("[.]?minecraft/saves");
|
|
|
|
matcherReal->caseSensitive(false);
|
2016-12-08 20:58:31 +00:00
|
|
|
m_matcher.reset(matcherReal);
|
2016-10-02 23:55:54 +01:00
|
|
|
}
|
2016-12-08 20:58:31 +00:00
|
|
|
}
|
2016-10-02 23:55:54 +01:00
|
|
|
|
2016-12-08 20:58:31 +00:00
|
|
|
void InstanceCopyTask::executeTask()
|
|
|
|
{
|
2017-05-03 22:11:52 +01:00
|
|
|
setStatus(tr("Copying instance %1").arg(m_origInstance->name()));
|
2016-10-26 17:12:33 +01:00
|
|
|
m_stagingPath = m_target->getStagedInstancePath();
|
|
|
|
FS::copy folderCopy(m_origInstance->instanceRoot(), m_stagingPath);
|
2016-12-08 20:58:31 +00:00
|
|
|
folderCopy.followSymlinks(false).blacklist(m_matcher.get());
|
2016-10-26 17:12:33 +01: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()
|
|
|
|
{
|
|
|
|
auto successful = m_copyFuture.result();
|
|
|
|
if(!successful)
|
2016-10-02 23:55:54 +01:00
|
|
|
{
|
2016-10-26 17:12:33 +01:00
|
|
|
m_target->destroyStagingPath(m_stagingPath);
|
2016-10-02 23:55:54 +01:00
|
|
|
emitFailed(tr("Instance folder copy failed."));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
// FIXME: shouldn't this be able to report errors?
|
2016-10-26 17:12:33 +01:00
|
|
|
auto instanceSettings = std::make_shared<INISettingsObject>(FS::PathCombine(m_stagingPath, "instance.cfg"));
|
2016-10-02 23:55:54 +01:00
|
|
|
instanceSettings->registerSetting("InstanceType", "Legacy");
|
|
|
|
|
|
|
|
// FIXME: and this too? errors???
|
2017-01-22 14:20:05 +00:00
|
|
|
m_origInstance->copy(instanceSettings, m_stagingPath);
|
2016-10-02 23:55:54 +01:00
|
|
|
|
2016-10-26 17:12:33 +01:00
|
|
|
InstancePtr inst(new NullInstance(m_globalSettings, instanceSettings, m_stagingPath));
|
2016-10-02 23:55:54 +01:00
|
|
|
inst->setName(m_instName);
|
|
|
|
inst->setIconKey(m_instIcon);
|
2016-10-26 17:12:33 +01:00
|
|
|
m_target->commitStagedInstance(m_stagingPath, m_stagingPath, m_instName, m_instGroup);
|
2016-10-02 23:55:54 +01:00
|
|
|
emitSucceeded();
|
|
|
|
}
|
2016-10-26 17:12:33 +01:00
|
|
|
|
|
|
|
void InstanceCopyTask::copyAborted()
|
|
|
|
{
|
|
|
|
m_target->destroyStagingPath(m_stagingPath);
|
|
|
|
emitFailed(tr("Instance folder copy has been aborted."));
|
|
|
|
return;
|
|
|
|
}
|