2022-01-14 09:43:42 +01:00
|
|
|
#include "ModDownloadTask.h"
|
2022-01-14 12:47:18 +01:00
|
|
|
#include "Application.h"
|
2022-01-14 09:43:42 +01:00
|
|
|
|
2022-01-14 12:47:18 +01:00
|
|
|
ModDownloadTask::ModDownloadTask(const QUrl sourceUrl,const QString filename, const std::shared_ptr<ModFolderModel> mods)
|
|
|
|
: m_sourceUrl(sourceUrl), mods(mods), filename(filename) {
|
2022-01-14 09:43:42 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void ModDownloadTask::executeTask() {
|
2022-01-14 12:47:18 +01:00
|
|
|
setStatus(tr("Downloading mod:\n%1").arg(m_sourceUrl.toString()));
|
|
|
|
|
2022-01-15 10:25:24 +01:00
|
|
|
m_filesNetJob.reset(new NetJob(tr("Mod download"), APPLICATION->network()));
|
2022-01-14 12:47:18 +01:00
|
|
|
m_filesNetJob->addNetAction(Net::Download::makeFile(m_sourceUrl, mods->dir().absoluteFilePath(filename)));
|
|
|
|
connect(m_filesNetJob.get(), &NetJob::succeeded, this, &ModDownloadTask::downloadSucceeded);
|
|
|
|
connect(m_filesNetJob.get(), &NetJob::progress, this, &ModDownloadTask::downloadProgressChanged);
|
|
|
|
connect(m_filesNetJob.get(), &NetJob::failed, this, &ModDownloadTask::downloadFailed);
|
|
|
|
m_filesNetJob->start();
|
|
|
|
}
|
|
|
|
|
|
|
|
void ModDownloadTask::downloadSucceeded()
|
|
|
|
{
|
2022-01-14 09:43:42 +01:00
|
|
|
emitSucceeded();
|
2022-01-14 12:47:18 +01:00
|
|
|
m_filesNetJob.reset();
|
|
|
|
}
|
|
|
|
|
|
|
|
void ModDownloadTask::downloadFailed(QString reason)
|
|
|
|
{
|
|
|
|
emitFailed(reason);
|
|
|
|
m_filesNetJob.reset();
|
2022-01-14 09:43:42 +01:00
|
|
|
}
|
2022-01-14 12:47:18 +01:00
|
|
|
|
|
|
|
void ModDownloadTask::downloadProgressChanged(qint64 current, qint64 total)
|
|
|
|
{
|
|
|
|
emit progress(current, total);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool ModDownloadTask::abort() {
|
|
|
|
return m_filesNetJob->abort();
|
|
|
|
}
|
|
|
|
|