2016-08-14 02:33:31 +02:00
|
|
|
#include "Env.h"
|
|
|
|
#include <FileSystem.h>
|
|
|
|
#include <minecraft/VersionFilterData.h>
|
|
|
|
#include "FMLLibrariesTask.h"
|
2017-07-24 09:01:37 +02:00
|
|
|
#include "minecraft/MinecraftInstance.h"
|
|
|
|
#include "minecraft/MinecraftProfile.h"
|
2016-08-14 02:33:31 +02:00
|
|
|
|
2017-07-24 09:01:37 +02:00
|
|
|
FMLLibrariesTask::FMLLibrariesTask(MinecraftInstance * inst)
|
2016-08-14 02:33:31 +02:00
|
|
|
{
|
|
|
|
m_inst = inst;
|
|
|
|
}
|
|
|
|
void FMLLibrariesTask::executeTask()
|
|
|
|
{
|
|
|
|
// Get the mod list
|
2017-07-24 09:01:37 +02:00
|
|
|
MinecraftInstance *inst = (MinecraftInstance *)m_inst;
|
2016-08-14 02:33:31 +02:00
|
|
|
std::shared_ptr<MinecraftProfile> profile = inst->getMinecraftProfile();
|
|
|
|
bool forge_present = false;
|
|
|
|
|
|
|
|
if (!profile->hasTrait("legacyFML"))
|
|
|
|
{
|
|
|
|
emitSucceeded();
|
2017-07-07 19:50:24 +02:00
|
|
|
return;
|
2016-08-14 02:33:31 +02:00
|
|
|
}
|
|
|
|
|
2017-07-24 09:01:37 +02:00
|
|
|
QString version = inst->getComponentVersion("net.minecraft");
|
2016-08-14 02:33:31 +02:00
|
|
|
auto &fmlLibsMapping = g_VersionFilterData.fmlLibsMapping;
|
|
|
|
if (!fmlLibsMapping.contains(version))
|
|
|
|
{
|
|
|
|
emitSucceeded();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
auto &libList = fmlLibsMapping[version];
|
|
|
|
|
|
|
|
// determine if we need some libs for FML or forge
|
2017-05-03 23:11:52 +02:00
|
|
|
setStatus(tr("Checking for FML libraries..."));
|
2016-08-14 02:33:31 +02:00
|
|
|
forge_present = (profile->versionPatch("net.minecraftforge") != nullptr);
|
|
|
|
// we don't...
|
|
|
|
if (!forge_present)
|
|
|
|
{
|
|
|
|
emitSucceeded();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// now check the lib folder inside the instance for files.
|
|
|
|
for (auto &lib : libList)
|
|
|
|
{
|
2017-07-24 09:01:37 +02:00
|
|
|
QFileInfo libInfo(FS::PathCombine(inst->libDir(), lib.filename));
|
2016-08-14 02:33:31 +02:00
|
|
|
if (libInfo.exists())
|
|
|
|
continue;
|
|
|
|
fmlLibsToProcess.append(lib);
|
|
|
|
}
|
|
|
|
|
|
|
|
// if everything is in place, there's nothing to do here...
|
|
|
|
if (fmlLibsToProcess.isEmpty())
|
|
|
|
{
|
|
|
|
emitSucceeded();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// download missing libs to our place
|
2017-05-03 23:11:52 +02:00
|
|
|
setStatus(tr("Dowloading FML libraries..."));
|
2016-08-14 02:33:31 +02:00
|
|
|
auto dljob = new NetJob("FML libraries");
|
|
|
|
auto metacache = ENV.metacache();
|
|
|
|
for (auto &lib : fmlLibsToProcess)
|
|
|
|
{
|
|
|
|
auto entry = metacache->resolveEntry("fmllibs", lib.filename);
|
|
|
|
QString urlString = lib.ours ? URLConstants::FMLLIBS_OUR_BASE_URL + lib.filename
|
|
|
|
: URLConstants::FMLLIBS_FORGE_BASE_URL + lib.filename;
|
|
|
|
dljob->addNetAction(Net::Download::makeCached(QUrl(urlString), entry));
|
|
|
|
}
|
|
|
|
|
|
|
|
connect(dljob, &NetJob::succeeded, this, &FMLLibrariesTask::fmllibsFinished);
|
|
|
|
connect(dljob, &NetJob::failed, this, &FMLLibrariesTask::fmllibsFailed);
|
|
|
|
connect(dljob, &NetJob::progress, this, &FMLLibrariesTask::progress);
|
|
|
|
downloadJob.reset(dljob);
|
|
|
|
downloadJob->start();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool FMLLibrariesTask::canAbort() const
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void FMLLibrariesTask::fmllibsFinished()
|
|
|
|
{
|
|
|
|
downloadJob.reset();
|
|
|
|
if (!fmlLibsToProcess.isEmpty())
|
|
|
|
{
|
2017-05-03 23:11:52 +02:00
|
|
|
setStatus(tr("Copying FML libraries into the instance..."));
|
2017-07-24 09:01:37 +02:00
|
|
|
MinecraftInstance *inst = (MinecraftInstance *)m_inst;
|
2016-08-14 02:33:31 +02:00
|
|
|
auto metacache = ENV.metacache();
|
|
|
|
int index = 0;
|
|
|
|
for (auto &lib : fmlLibsToProcess)
|
|
|
|
{
|
|
|
|
progress(index, fmlLibsToProcess.size());
|
|
|
|
auto entry = metacache->resolveEntry("fmllibs", lib.filename);
|
2017-07-24 09:01:37 +02:00
|
|
|
auto path = FS::PathCombine(inst->libDir(), lib.filename);
|
2016-08-14 02:33:31 +02:00
|
|
|
if (!FS::ensureFilePathExists(path))
|
|
|
|
{
|
|
|
|
emitFailed(tr("Failed creating FML library folder inside the instance."));
|
|
|
|
return;
|
|
|
|
}
|
2017-07-24 09:01:37 +02:00
|
|
|
if (!QFile::copy(entry->getFullPath(), FS::PathCombine(inst->libDir(), lib.filename)))
|
2016-08-14 02:33:31 +02:00
|
|
|
{
|
|
|
|
emitFailed(tr("Failed copying Forge/FML library: %1.").arg(lib.filename));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
index++;
|
|
|
|
}
|
|
|
|
progress(index, fmlLibsToProcess.size());
|
|
|
|
}
|
|
|
|
emitSucceeded();
|
|
|
|
}
|
|
|
|
void FMLLibrariesTask::fmllibsFailed(QString reason)
|
|
|
|
{
|
|
|
|
QStringList failed = downloadJob->getFailedFiles();
|
|
|
|
QString failed_all = failed.join("\n");
|
|
|
|
emitFailed(tr("Failed to download the following files:\n%1\n\nReason:%2\nPlease try again.").arg(failed_all, reason));
|
|
|
|
}
|
|
|
|
|
|
|
|
bool FMLLibrariesTask::abort()
|
|
|
|
{
|
|
|
|
if(downloadJob)
|
|
|
|
{
|
|
|
|
return downloadJob->abort();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
qWarning() << "Prematurely aborted FMLLibrariesTask";
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|