92aa24ae34
It causes some weird problems and adds refcounting overhead. Signed-off-by: flow <flowlnlnln@gmail.com>
63 lines
1.7 KiB
C++
63 lines
1.7 KiB
C++
#pragma once
|
|
|
|
#include "BaseInstance.h"
|
|
#include "ModDownloadTask.h"
|
|
#include "ReviewMessageBox.h"
|
|
|
|
#include "minecraft/mod/ModFolderModel.h"
|
|
|
|
#include "modplatform/CheckUpdateTask.h"
|
|
|
|
class Mod;
|
|
class ModrinthCheckUpdate;
|
|
class FlameCheckUpdate;
|
|
class ConcurrentTask;
|
|
|
|
class ModUpdateDialog final : public ReviewMessageBox {
|
|
Q_OBJECT
|
|
public:
|
|
explicit ModUpdateDialog(QWidget* parent,
|
|
BaseInstance* instance,
|
|
const std::shared_ptr<ModFolderModel> mod_model,
|
|
QList<Mod*>& search_for);
|
|
|
|
void checkCandidates();
|
|
|
|
void appendMod(const CheckUpdateTask::UpdatableMod& info);
|
|
|
|
const QList<ModDownloadTask*> getTasks();
|
|
auto indexDir() const -> QDir { return m_mod_model->indexDir(); }
|
|
|
|
auto noUpdates() const -> bool { return m_no_updates; };
|
|
auto aborted() const -> bool { return m_aborted; };
|
|
|
|
private:
|
|
auto ensureMetadata() -> bool;
|
|
|
|
private slots:
|
|
void onMetadataEnsured(Mod*);
|
|
void onMetadataFailed(Mod*, bool try_others = false, ModPlatform::Provider first_choice = ModPlatform::Provider::MODRINTH);
|
|
|
|
private:
|
|
QWidget* m_parent;
|
|
|
|
ModrinthCheckUpdate* m_modrinth_check_task = nullptr;
|
|
FlameCheckUpdate* m_flame_check_task = nullptr;
|
|
|
|
const std::shared_ptr<ModFolderModel> m_mod_model;
|
|
|
|
QList<Mod*>& m_candidates;
|
|
QList<Mod*> m_modrinth_to_update;
|
|
QList<Mod*> m_flame_to_update;
|
|
|
|
ConcurrentTask* m_second_try_metadata;
|
|
QList<std::tuple<Mod*, QString>> m_failed_metadata;
|
|
QList<std::tuple<Mod*, QString, QUrl>> m_failed_check_update;
|
|
|
|
QHash<QString, ModDownloadTask*> m_tasks;
|
|
BaseInstance* m_instance;
|
|
|
|
bool m_no_updates = false;
|
|
bool m_aborted = false;
|
|
};
|