2017-09-26 12:38:34 +01:00
|
|
|
#include "LegacyUpgradeTask.h"
|
|
|
|
#include "settings/INISettingsObject.h"
|
|
|
|
#include "FileSystem.h"
|
|
|
|
#include "NullInstance.h"
|
|
|
|
#include "pathmatcher/RegexpMatcher.h"
|
|
|
|
#include <QtConcurrentRun>
|
|
|
|
#include "LegacyInstance.h"
|
|
|
|
#include "minecraft/MinecraftInstance.h"
|
2017-10-11 22:04:24 +01:00
|
|
|
#include "minecraft/ComponentList.h"
|
2019-08-03 02:12:48 +01:00
|
|
|
#include "LegacyModList.h"
|
2017-09-27 14:39:13 +01:00
|
|
|
#include "classparser.h"
|
2017-09-26 12:38:34 +01:00
|
|
|
|
2018-03-19 01:36:12 +00:00
|
|
|
LegacyUpgradeTask::LegacyUpgradeTask(InstancePtr origInstance)
|
2017-09-26 12:38:34 +01:00
|
|
|
{
|
2018-07-15 13:51:05 +01:00
|
|
|
m_origInstance = origInstance;
|
2017-09-26 12:38:34 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void LegacyUpgradeTask::executeTask()
|
|
|
|
{
|
2018-07-15 13:51:05 +01:00
|
|
|
setStatus(tr("Copying instance %1").arg(m_origInstance->name()));
|
2017-09-26 12:38:34 +01:00
|
|
|
|
2018-07-15 13:51:05 +01:00
|
|
|
FS::copy folderCopy(m_origInstance->instanceRoot(), m_stagingPath);
|
|
|
|
folderCopy.followSymlinks(true);
|
2017-09-26 12:38:34 +01:00
|
|
|
|
2018-07-15 13:51:05 +01:00
|
|
|
m_copyFuture = QtConcurrent::run(QThreadPool::globalInstance(), folderCopy);
|
|
|
|
connect(&m_copyFutureWatcher, &QFutureWatcher<bool>::finished, this, &LegacyUpgradeTask::copyFinished);
|
|
|
|
connect(&m_copyFutureWatcher, &QFutureWatcher<bool>::canceled, this, &LegacyUpgradeTask::copyAborted);
|
|
|
|
m_copyFutureWatcher.setFuture(m_copyFuture);
|
2017-09-26 12:38:34 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static QString decideVersion(const QString& currentVersion, const QString& intendedVersion)
|
|
|
|
{
|
2018-07-15 13:51:05 +01:00
|
|
|
if(intendedVersion != currentVersion)
|
|
|
|
{
|
|
|
|
if(!intendedVersion.isEmpty())
|
|
|
|
{
|
|
|
|
return intendedVersion;
|
|
|
|
}
|
|
|
|
else if(!currentVersion.isEmpty())
|
|
|
|
{
|
|
|
|
return currentVersion;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if(!intendedVersion.isEmpty())
|
|
|
|
{
|
|
|
|
return intendedVersion;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return QString();
|
2017-09-26 12:38:34 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void LegacyUpgradeTask::copyFinished()
|
|
|
|
{
|
2018-07-15 13:51:05 +01:00
|
|
|
auto successful = m_copyFuture.result();
|
|
|
|
if(!successful)
|
|
|
|
{
|
|
|
|
emitFailed(tr("Instance folder copy failed."));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
auto legacyInst = std::dynamic_pointer_cast<LegacyInstance>(m_origInstance);
|
2017-09-26 12:38:34 +01:00
|
|
|
|
2018-07-15 13:51:05 +01:00
|
|
|
auto instanceSettings = std::make_shared<INISettingsObject>(FS::PathCombine(m_stagingPath, "instance.cfg"));
|
|
|
|
instanceSettings->registerSetting("InstanceType", "Legacy");
|
|
|
|
instanceSettings->set("InstanceType", "OneSix");
|
|
|
|
// NOTE: this scope ensures the instance is fully saved before we emitSucceeded
|
|
|
|
{
|
|
|
|
MinecraftInstance inst(m_globalSettings, instanceSettings, m_stagingPath);
|
|
|
|
inst.setName(m_instName);
|
2017-11-11 00:38:31 +00:00
|
|
|
|
2018-07-15 13:51:05 +01:00
|
|
|
QString preferredVersionNumber = decideVersion(legacyInst->currentVersionId(), legacyInst->intendedVersionId());
|
|
|
|
if(preferredVersionNumber.isNull())
|
|
|
|
{
|
|
|
|
// try to decide version based on the jar(s?)
|
|
|
|
preferredVersionNumber = classparser::GetMinecraftJarVersion(legacyInst->baseJar());
|
|
|
|
if(preferredVersionNumber.isNull())
|
|
|
|
{
|
|
|
|
preferredVersionNumber = classparser::GetMinecraftJarVersion(legacyInst->runnableJar());
|
|
|
|
if(preferredVersionNumber.isNull())
|
|
|
|
{
|
|
|
|
emitFailed(tr("Could not decide Minecraft version."));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
auto components = inst.getComponentList();
|
|
|
|
components->buildingFromScratch();
|
|
|
|
components->setComponentVersion("net.minecraft", preferredVersionNumber, true);
|
2017-09-26 12:38:34 +01:00
|
|
|
|
2018-07-15 13:51:05 +01:00
|
|
|
QString jarPath = legacyInst->mainJarToPreserve();
|
|
|
|
if(!jarPath.isNull())
|
|
|
|
{
|
|
|
|
qDebug() << "Preserving base jar! : " << jarPath;
|
|
|
|
// FIXME: handle case when the jar is unreadable?
|
|
|
|
// TODO: check the hash, if it's the same as the upstream jar, do not do this
|
|
|
|
components->installCustomJar(jarPath);
|
|
|
|
}
|
2017-09-26 12:38:34 +01:00
|
|
|
|
2019-08-03 02:12:48 +01:00
|
|
|
auto jarMods = legacyInst->jarModList()->allMods();
|
2018-07-15 13:51:05 +01:00
|
|
|
for(auto & jarMod: jarMods)
|
|
|
|
{
|
2019-08-03 02:12:48 +01:00
|
|
|
QString modPath = jarMod.absoluteFilePath();
|
2018-07-15 13:51:05 +01:00
|
|
|
qDebug() << "jarMod: " << modPath;
|
|
|
|
components->installJarMods({modPath});
|
|
|
|
}
|
2017-09-26 12:38:34 +01:00
|
|
|
|
2018-07-15 13:51:05 +01:00
|
|
|
// remove all the extra garbage we no longer need
|
|
|
|
auto removeAll = [&](const QString &root, const QStringList &things)
|
|
|
|
{
|
|
|
|
for(auto &thing : things)
|
|
|
|
{
|
|
|
|
auto removePath = FS::PathCombine(root, thing);
|
|
|
|
QFileInfo stat(removePath);
|
|
|
|
if(stat.isDir())
|
|
|
|
{
|
|
|
|
FS::deletePath(removePath);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
QFile::remove(removePath);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
QStringList rootRemovables = {"modlist", "version", "instMods"};
|
|
|
|
QStringList mcRemovables = {"bin", "MultiMCLauncher.jar", "icon.png"};
|
|
|
|
removeAll(inst.instanceRoot(), rootRemovables);
|
2018-07-27 22:57:09 +01:00
|
|
|
removeAll(inst.gameRoot(), mcRemovables);
|
2018-07-15 13:51:05 +01:00
|
|
|
}
|
|
|
|
emitSucceeded();
|
2017-09-26 12:38:34 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void LegacyUpgradeTask::copyAborted()
|
|
|
|
{
|
2018-07-15 13:51:05 +01:00
|
|
|
emitFailed(tr("Instance folder copy has been aborted."));
|
|
|
|
return;
|
2017-09-26 12:38:34 +01:00
|
|
|
}
|
|
|
|
|