fix: fix segfault when resolving Flame resources
Signed-off-by: Sefa Eyeoglu <contact@scrumplex.net>
This commit is contained in:
		| @@ -12,6 +12,8 @@ bool Flame::FileResolvingTask::abort() | ||||
|     bool aborted = true; | ||||
|     if (m_dljob) | ||||
|         aborted &= m_dljob->abort(); | ||||
|     if (m_checkJob) | ||||
|         aborted &= m_checkJob->abort(); | ||||
|     return aborted ? Task::abort() : false; | ||||
| } | ||||
|  | ||||
| @@ -40,7 +42,7 @@ void Flame::FileResolvingTask::netJobFinished() | ||||
|     setProgress(1, 3); | ||||
|     int index = 0; | ||||
|     // job to check modrinth for blocked projects | ||||
|     auto job = new NetJob("Modrinth check", m_network); | ||||
|     m_checkJob = new NetJob("Modrinth check", m_network); | ||||
|     blockedProjects = QMap<File *,QByteArray *>(); | ||||
|     auto doc = Json::requireDocument(*result); | ||||
|     auto array = Json::requireArray(doc.object()["data"]); | ||||
| @@ -60,19 +62,15 @@ void Flame::FileResolvingTask::netJobFinished() | ||||
|                     out.resolved = true; | ||||
|                 }); | ||||
|  | ||||
|                 job->addNetAction(dl); | ||||
|                 m_checkJob->addNetAction(dl); | ||||
|                 blockedProjects.insert(&out, output); | ||||
|             } | ||||
|         } | ||||
|         index++; | ||||
|     } | ||||
|     connect(job, &NetJob::finished, this, | ||||
|         [this, &job] { | ||||
|             modrinthCheckFinished(); | ||||
|             job->deleteLater(); | ||||
|         }); | ||||
|     connect(m_checkJob.get(), &NetJob::finished, this, &Flame::FileResolvingTask::modrinthCheckFinished); | ||||
|  | ||||
|     job->start(); | ||||
|     m_checkJob->start(); | ||||
| } | ||||
|  | ||||
| void Flame::FileResolvingTask::modrinthCheckFinished() { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Sefa Eyeoglu
					Sefa Eyeoglu