2016-08-14 02:33:31 +02:00
|
|
|
#include "Env.h"
|
|
|
|
#include "LibrariesTask.h"
|
2017-07-24 09:01:37 +02:00
|
|
|
#include "minecraft/MinecraftInstance.h"
|
2017-10-11 23:04:24 +02:00
|
|
|
#include "minecraft/ComponentList.h"
|
2016-08-14 02:33:31 +02:00
|
|
|
|
2017-07-24 09:01:37 +02:00
|
|
|
LibrariesTask::LibrariesTask(MinecraftInstance * inst)
|
2016-08-14 02:33:31 +02:00
|
|
|
{
|
|
|
|
m_inst = inst;
|
|
|
|
}
|
|
|
|
|
|
|
|
void LibrariesTask::executeTask()
|
|
|
|
{
|
2017-05-03 23:11:52 +02:00
|
|
|
setStatus(tr("Getting the library files from Mojang..."));
|
2016-08-14 02:33:31 +02:00
|
|
|
qDebug() << m_inst->name() << ": downloading libraries";
|
2017-07-24 09:01:37 +02:00
|
|
|
MinecraftInstance *inst = (MinecraftInstance *)m_inst;
|
2016-08-14 02:33:31 +02:00
|
|
|
|
|
|
|
// Build a list of URLs that will need to be downloaded.
|
2017-11-04 22:55:25 +01:00
|
|
|
auto components = inst->getComponentList();
|
|
|
|
auto profile = components->getProfile();
|
2016-08-14 02:33:31 +02:00
|
|
|
|
2017-04-13 09:28:25 +02:00
|
|
|
auto job = new NetJob(tr("Libraries for instance %1").arg(inst->name()));
|
|
|
|
downloadJob.reset(job);
|
2016-08-14 02:33:31 +02:00
|
|
|
|
|
|
|
auto metacache = ENV.metacache();
|
|
|
|
QList<LibraryPtr> brokenLocalLibs;
|
|
|
|
QStringList failedFiles;
|
2017-04-13 09:28:25 +02:00
|
|
|
auto createJob = [&](const LibraryPtr & lib)
|
|
|
|
{
|
|
|
|
if(!lib)
|
|
|
|
{
|
|
|
|
emitFailed(tr("Null jar is specified in the metadata, aborting."));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
auto dls = lib->getDownloads(currentSystem, metacache.get(), failedFiles, inst->getLocalLibraryPath());
|
|
|
|
for(auto dl : dls)
|
|
|
|
{
|
|
|
|
downloadJob->addNetAction(dl);
|
|
|
|
}
|
|
|
|
};
|
2017-04-06 23:31:23 +02:00
|
|
|
auto createJobs = [&](const QList<LibraryPtr> & libs)
|
2016-08-14 02:33:31 +02:00
|
|
|
{
|
2017-04-06 23:31:23 +02:00
|
|
|
for (auto lib : libs)
|
2016-08-14 02:33:31 +02:00
|
|
|
{
|
2017-04-13 09:28:25 +02:00
|
|
|
createJob(lib);
|
2016-08-14 02:33:31 +02:00
|
|
|
}
|
2017-04-06 23:31:23 +02:00
|
|
|
};
|
|
|
|
createJobs(profile->getLibraries());
|
|
|
|
createJobs(profile->getNativeLibraries());
|
2017-04-17 22:51:30 +02:00
|
|
|
createJobs(profile->getJarMods());
|
2017-04-13 09:28:25 +02:00
|
|
|
createJob(profile->getMainJar());
|
2017-04-06 23:31:23 +02:00
|
|
|
|
2016-08-14 02:33:31 +02:00
|
|
|
// FIXME: this is never filled!!!!
|
|
|
|
if (!brokenLocalLibs.empty())
|
|
|
|
{
|
|
|
|
downloadJob.reset();
|
|
|
|
QString failed_all = failedFiles.join("\n");
|
|
|
|
emitFailed(tr("Some libraries marked as 'local' are missing their jar "
|
|
|
|
"files:\n%1\n\nYou'll have to correct this problem manually. If this is "
|
|
|
|
"an externally tracked instance, make sure to run it at least once "
|
|
|
|
"outside of MultiMC.").arg(failed_all));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
connect(downloadJob.get(), &NetJob::succeeded, this, &LibrariesTask::emitSucceeded);
|
|
|
|
connect(downloadJob.get(), &NetJob::failed, this, &LibrariesTask::jarlibFailed);
|
|
|
|
connect(downloadJob.get(), &NetJob::progress, this, &LibrariesTask::progress);
|
|
|
|
downloadJob->start();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool LibrariesTask::canAbort() const
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void LibrariesTask::jarlibFailed(QString reason)
|
|
|
|
{
|
|
|
|
emitFailed(tr("Game update failed: it was impossible to fetch the required libraries.\nReason:\n%1").arg(reason));
|
|
|
|
}
|
|
|
|
|
|
|
|
bool LibrariesTask::abort()
|
|
|
|
{
|
|
|
|
if(downloadJob)
|
|
|
|
{
|
|
|
|
return downloadJob->abort();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
qWarning() << "Prematurely aborted LibrariesTask";
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|