make FileResolvingTask accept empty modlist
Signed-off-by: Trial97 <alexandru.tripon97@gmail.com>
This commit is contained in:
		| @@ -21,6 +21,10 @@ bool Flame::FileResolvingTask::abort() | |||||||
|  |  | ||||||
| void Flame::FileResolvingTask::executeTask() | void Flame::FileResolvingTask::executeTask() | ||||||
| { | { | ||||||
|  |     if (m_toProcess.files.isEmpty()) {  // no file to resolve so leave it empty and emit success immediately | ||||||
|  |         emitSucceeded(); | ||||||
|  |         return; | ||||||
|  |     } | ||||||
|     setStatus(tr("Resolving mod IDs...")); |     setStatus(tr("Resolving mod IDs...")); | ||||||
|     setProgress(0, 3); |     setProgress(0, 3); | ||||||
|     m_dljob.reset(new NetJob("Mod id resolver", m_network)); |     m_dljob.reset(new NetJob("Mod id resolver", m_network)); | ||||||
| @@ -128,12 +132,13 @@ void Flame::FileResolvingTask::netJobFinished() | |||||||
|     m_checkJob->start(); |     m_checkJob->start(); | ||||||
| } | } | ||||||
|  |  | ||||||
| void Flame::FileResolvingTask::modrinthCheckFinished() { | void Flame::FileResolvingTask::modrinthCheckFinished() | ||||||
|  | { | ||||||
|     setProgress(2, 3); |     setProgress(2, 3); | ||||||
|     qDebug() << "Finished with blocked mods : " << blockedProjects.size(); |     qDebug() << "Finished with blocked mods : " << blockedProjects.size(); | ||||||
|  |  | ||||||
|     for (auto it = blockedProjects.keyBegin(); it != blockedProjects.keyEnd(); it++) { |     for (auto it = blockedProjects.keyBegin(); it != blockedProjects.keyEnd(); it++) { | ||||||
|         auto &out = *it; |         auto& out = *it; | ||||||
|         auto bytes = blockedProjects[out]; |         auto bytes = blockedProjects[out]; | ||||||
|         if (!out->resolved) { |         if (!out->resolved) { | ||||||
|             continue; |             continue; | ||||||
| @@ -153,15 +158,13 @@ void Flame::FileResolvingTask::modrinthCheckFinished() { | |||||||
|             out->resolved = false; |             out->resolved = false; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     //copy to an output list and filter out projects found on modrinth |     // copy to an output list and filter out projects found on modrinth | ||||||
|     auto block = std::make_shared<QList<File*>>(); |     auto block = std::make_shared<QList<File*>>(); | ||||||
|     auto it = blockedProjects.keys(); |     auto it = blockedProjects.keys(); | ||||||
|     std::copy_if(it.begin(), it.end(), std::back_inserter(*block), [](File *f) { |     std::copy_if(it.begin(), it.end(), std::back_inserter(*block), [](File* f) { return !f->resolved; }); | ||||||
|         return !f->resolved; |     // Display not found mods early | ||||||
|     }); |  | ||||||
|     //Display not found mods early |  | ||||||
|     if (!block->empty()) { |     if (!block->empty()) { | ||||||
|         //blocked mods found, we need the slug for displaying.... we need another job :D ! |         // blocked mods found, we need the slug for displaying.... we need another job :D ! | ||||||
|         m_slugJob.reset(new NetJob("Slug Job", m_network)); |         m_slugJob.reset(new NetJob("Slug Job", m_network)); | ||||||
|         int index = 0; |         int index = 0; | ||||||
|         for (auto mod : *block) { |         for (auto mod : *block) { | ||||||
| @@ -173,8 +176,8 @@ void Flame::FileResolvingTask::modrinthCheckFinished() { | |||||||
|             QObject::connect(dl.get(), &Net::Download::succeeded, [block, index, output]() { |             QObject::connect(dl.get(), &Net::Download::succeeded, [block, index, output]() { | ||||||
|                 auto mod = block->at(index);  // use the shared_ptr so it is captured and only freed when we are done |                 auto mod = block->at(index);  // use the shared_ptr so it is captured and only freed when we are done | ||||||
|                 auto json = QJsonDocument::fromJson(*output); |                 auto json = QJsonDocument::fromJson(*output); | ||||||
|                 auto base = Json::requireString(Json::requireObject(Json::requireObject(Json::requireObject(json),"data"),"links"), |                 auto base = | ||||||
|                         "websiteUrl"); |                     Json::requireString(Json::requireObject(Json::requireObject(Json::requireObject(json), "data"), "links"), "websiteUrl"); | ||||||
|                 auto link = QString("%1/download/%2").arg(base, QString::number(mod->fileId)); |                 auto link = QString("%1/download/%2").arg(base, QString::number(mod->fileId)); | ||||||
|                 mod->websiteUrl = link; |                 mod->websiteUrl = link; | ||||||
|             }); |             }); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Trial97
					Trial97