diff options
author | Petr Mrázek <peterix@gmail.com> | 2017-04-22 18:51:04 +0200 |
---|---|---|
committer | Petr Mrázek <peterix@gmail.com> | 2017-04-22 18:51:04 +0200 |
commit | 8ace5fa91d7abaadc00758e1f6eeb692f424a8ab (patch) | |
tree | 7ac7adf409e941b85bd92c362667fbfcf9ab8b86 /api/logic/minecraft/curse/FileResolvingTask.cpp | |
parent | 30863a88abbbac05aff914326557882a2f09f4e4 (diff) | |
download | MultiMC-8ace5fa91d7abaadc00758e1f6eeb692f424a8ab.tar MultiMC-8ace5fa91d7abaadc00758e1f6eeb692f424a8ab.tar.gz MultiMC-8ace5fa91d7abaadc00758e1f6eeb692f424a8ab.tar.lz MultiMC-8ace5fa91d7abaadc00758e1f6eeb692f424a8ab.tar.xz MultiMC-8ace5fa91d7abaadc00758e1f6eeb692f424a8ab.zip |
NOISSUE Add flame.
Diffstat (limited to 'api/logic/minecraft/curse/FileResolvingTask.cpp')
-rw-r--r-- | api/logic/minecraft/curse/FileResolvingTask.cpp | 66 |
1 files changed, 0 insertions, 66 deletions
diff --git a/api/logic/minecraft/curse/FileResolvingTask.cpp b/api/logic/minecraft/curse/FileResolvingTask.cpp deleted file mode 100644 index aaac404b..00000000 --- a/api/logic/minecraft/curse/FileResolvingTask.cpp +++ /dev/null @@ -1,66 +0,0 @@ -#include "FileResolvingTask.h" -#include "Json.h" - -const char * metabase = "https://cursemeta.dries007.net"; - -Curse::FileResolvingTask::FileResolvingTask(Curse::Manifest& toProcess) - : m_toProcess(toProcess) -{ -} - -void Curse::FileResolvingTask::executeTask() -{ - setStatus(tr("Resolving curse mod IDs...")); - setProgress(0, m_toProcess.files.size()); - m_dljob.reset(new NetJob("Curse file resolver")); - results.resize(m_toProcess.files.size()); - int index = 0; - for(auto & file: m_toProcess.files) - { - auto projectIdStr = QString::number(file.projectId); - auto fileIdStr = QString::number(file.fileId); - QString metaurl = QString("%1/%2/%3.json").arg(metabase, projectIdStr, fileIdStr); - auto dl = Net::Download::makeByteArray(QUrl(metaurl), &results[index]); - m_dljob->addNetAction(dl); - index ++; - } - connect(m_dljob.get(), &NetJob::finished, this, &Curse::FileResolvingTask::netJobFinished); - m_dljob->start(); -} - -void Curse::FileResolvingTask::netJobFinished() -{ - bool failed = false; - int index = 0; - for(auto & bytes: results) - { - try - { - auto doc = Json::requireDocument(bytes); - auto obj = Json::requireObject(doc); - // result code signifies true failure. - if(obj.contains("code")) - { - failed = true; - continue; - } - auto & out = m_toProcess.files[index]; - out.fileName = Json::requireString(obj, "FileNameOnDisk"); - out.url = Json::requireString(obj, "DownloadURL"); - out.resolved = true; - } - catch(JSONValidationError & e) - { - failed = true; - } - index++; - } - if(!failed) - { - emitSucceeded(); - } - else - { - emitFailed(tr("Some curse ID resolving tasks failed.")); - } -} |