fix(ManagedPackPage): only update the current instance exactly
Also carry on the original ID to avoid updating the wrong instance. Signed-off-by: flow <flowlnlnln@gmail.com>
This commit is contained in:
parent
80054e4db2
commit
bb386a1162
@ -265,7 +265,12 @@ void InstanceImportTask::processFlame()
|
|||||||
Q_ASSERT(pack_version_id_it != m_extra_info.constEnd());
|
Q_ASSERT(pack_version_id_it != m_extra_info.constEnd());
|
||||||
auto pack_version_id = pack_version_id_it.value();
|
auto pack_version_id = pack_version_id_it.value();
|
||||||
|
|
||||||
auto* inst_creation_task = new FlameCreationTask(m_stagingPath, m_globalSettings, m_parent, pack_id, pack_version_id);
|
QString original_instance_id;
|
||||||
|
auto original_instance_id_it = m_extra_info.constFind("original_instance_id");
|
||||||
|
if (original_instance_id_it != m_extra_info.constEnd())
|
||||||
|
original_instance_id = original_instance_id_it.value();
|
||||||
|
|
||||||
|
auto* inst_creation_task = new FlameCreationTask(m_stagingPath, m_globalSettings, m_parent, pack_id, pack_version_id, original_instance_id);
|
||||||
|
|
||||||
inst_creation_task->setName(*this);
|
inst_creation_task->setName(*this);
|
||||||
inst_creation_task->setIcon(m_instIcon);
|
inst_creation_task->setIcon(m_instIcon);
|
||||||
@ -273,7 +278,7 @@ void InstanceImportTask::processFlame()
|
|||||||
inst_creation_task->setConfirmUpdate(shouldConfirmUpdate());
|
inst_creation_task->setConfirmUpdate(shouldConfirmUpdate());
|
||||||
|
|
||||||
connect(inst_creation_task, &Task::succeeded, this, [this, inst_creation_task] {
|
connect(inst_creation_task, &Task::succeeded, this, [this, inst_creation_task] {
|
||||||
setOverride(inst_creation_task->shouldOverride());
|
setOverride(inst_creation_task->shouldOverride(), inst_creation_task->originalInstanceID());
|
||||||
emitSucceeded();
|
emitSucceeded();
|
||||||
});
|
});
|
||||||
connect(inst_creation_task, &Task::failed, this, &InstanceImportTask::emitFailed);
|
connect(inst_creation_task, &Task::failed, this, &InstanceImportTask::emitFailed);
|
||||||
@ -339,7 +344,12 @@ void InstanceImportTask::processModrinth()
|
|||||||
if (pack_version_id_it != m_extra_info.constEnd())
|
if (pack_version_id_it != m_extra_info.constEnd())
|
||||||
pack_version_id = pack_version_id_it.value();
|
pack_version_id = pack_version_id_it.value();
|
||||||
|
|
||||||
auto* inst_creation_task = new ModrinthCreationTask(m_stagingPath, m_globalSettings, m_parent, pack_id, pack_version_id);
|
QString original_instance_id;
|
||||||
|
auto original_instance_id_it = m_extra_info.constFind("original_instance_id");
|
||||||
|
if (original_instance_id_it != m_extra_info.constEnd())
|
||||||
|
original_instance_id = original_instance_id_it.value();
|
||||||
|
|
||||||
|
auto* inst_creation_task = new ModrinthCreationTask(m_stagingPath, m_globalSettings, m_parent, pack_id, pack_version_id, original_instance_id);
|
||||||
|
|
||||||
inst_creation_task->setName(*this);
|
inst_creation_task->setName(*this);
|
||||||
inst_creation_task->setIcon(m_instIcon);
|
inst_creation_task->setIcon(m_instIcon);
|
||||||
@ -347,7 +357,7 @@ void InstanceImportTask::processModrinth()
|
|||||||
inst_creation_task->setConfirmUpdate(shouldConfirmUpdate());
|
inst_creation_task->setConfirmUpdate(shouldConfirmUpdate());
|
||||||
|
|
||||||
connect(inst_creation_task, &Task::succeeded, this, [this, inst_creation_task] {
|
connect(inst_creation_task, &Task::succeeded, this, [this, inst_creation_task] {
|
||||||
setOverride(inst_creation_task->shouldOverride());
|
setOverride(inst_creation_task->shouldOverride(), inst_creation_task->originalInstanceID());
|
||||||
emitSucceeded();
|
emitSucceeded();
|
||||||
});
|
});
|
||||||
connect(inst_creation_task, &Task::failed, this, &InstanceImportTask::emitFailed);
|
connect(inst_creation_task, &Task::failed, this, &InstanceImportTask::emitFailed);
|
||||||
|
@ -816,7 +816,7 @@ class InstanceStaging : public Task {
|
|||||||
void childSucceded()
|
void childSucceded()
|
||||||
{
|
{
|
||||||
unsigned sleepTime = backoff();
|
unsigned sleepTime = backoff();
|
||||||
if (m_parent->commitStagedInstance(m_stagingPath, m_instance_name, m_groupName, m_child->shouldOverride()))
|
if (m_parent->commitStagedInstance(m_stagingPath, m_instance_name, m_groupName, *m_child.get()))
|
||||||
{
|
{
|
||||||
emitSucceeded();
|
emitSucceeded();
|
||||||
return;
|
return;
|
||||||
@ -880,25 +880,22 @@ QString InstanceList::getStagedInstancePath()
|
|||||||
return path;
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool InstanceList::commitStagedInstance(const QString& path, InstanceName const& instanceName, const QString& groupName, bool should_override)
|
bool InstanceList::commitStagedInstance(const QString& path, InstanceName const& instanceName, const QString& groupName, InstanceTask const& commiting)
|
||||||
{
|
{
|
||||||
QDir dir;
|
QDir dir;
|
||||||
QString instID;
|
QString instID;
|
||||||
InstancePtr inst;
|
InstancePtr inst;
|
||||||
|
|
||||||
|
auto should_override = commiting.shouldOverride();
|
||||||
|
|
||||||
if (should_override) {
|
if (should_override) {
|
||||||
// This is to avoid problems when the instance folder gets manually renamed
|
instID = commiting.originalInstanceID();
|
||||||
if ((inst = getInstanceByManagedName(instanceName.originalName()))) {
|
|
||||||
instID = QFileInfo(inst->instanceRoot()).fileName();
|
|
||||||
} else if ((inst = getInstanceByManagedName(instanceName.modifiedName()))) {
|
|
||||||
instID = QFileInfo(inst->instanceRoot()).fileName();
|
|
||||||
} else {
|
|
||||||
instID = FS::RemoveInvalidFilenameChars(instanceName.modifiedName(), '-');
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
instID = FS::DirNameFromString(instanceName.modifiedName(), m_instDir);
|
instID = FS::DirNameFromString(instanceName.modifiedName(), m_instDir);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Q_ASSERT(!instID.isEmpty());
|
||||||
|
|
||||||
{
|
{
|
||||||
WatchLock lock(m_watcher, m_instDir);
|
WatchLock lock(m_watcher, m_instDir);
|
||||||
QString destination = FS::PathCombine(m_instDir, instID);
|
QString destination = FS::PathCombine(m_instDir, instID);
|
||||||
|
@ -133,7 +133,7 @@ public:
|
|||||||
* should_override is used when another similar instance already exists, and we want to override it
|
* should_override is used when another similar instance already exists, and we want to override it
|
||||||
* - for instance, when updating it.
|
* - for instance, when updating it.
|
||||||
*/
|
*/
|
||||||
bool commitStagedInstance(const QString& keyPath, const InstanceName& instanceName, const QString& groupName, bool should_override);
|
bool commitStagedInstance(const QString& keyPath, const InstanceName& instanceName, const QString& groupName, const InstanceTask&);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Destroy a previously created staging area given by @keyPath - used when creation fails.
|
* Destroy a previously created staging area given by @keyPath - used when creation fails.
|
||||||
|
@ -49,8 +49,15 @@ class InstanceTask : public Task, public InstanceName {
|
|||||||
|
|
||||||
bool shouldOverride() const { return m_override_existing; }
|
bool shouldOverride() const { return m_override_existing; }
|
||||||
|
|
||||||
|
[[nodiscard]] QString originalInstanceID() const { return m_original_instance_id; };
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void setOverride(bool override) { m_override_existing = override; }
|
void setOverride(bool override, QString instance_id_to_override = {})
|
||||||
|
{
|
||||||
|
m_override_existing = override;
|
||||||
|
if (!instance_id_to_override.isEmpty())
|
||||||
|
m_original_instance_id = instance_id_to_override;
|
||||||
|
}
|
||||||
|
|
||||||
protected: /* data */
|
protected: /* data */
|
||||||
SettingsObjectPtr m_globalSettings;
|
SettingsObjectPtr m_globalSettings;
|
||||||
@ -60,4 +67,6 @@ class InstanceTask : public Task, public InstanceName {
|
|||||||
|
|
||||||
bool m_override_existing = false;
|
bool m_override_existing = false;
|
||||||
bool m_confirm_update = true;
|
bool m_confirm_update = true;
|
||||||
|
|
||||||
|
QString m_original_instance_id;
|
||||||
};
|
};
|
||||||
|
@ -81,7 +81,12 @@ bool FlameCreationTask::updateInstance()
|
|||||||
auto instance_list = APPLICATION->instances();
|
auto instance_list = APPLICATION->instances();
|
||||||
|
|
||||||
// FIXME: How to handle situations when there's more than one install already for a given modpack?
|
// FIXME: How to handle situations when there's more than one install already for a given modpack?
|
||||||
auto inst = instance_list->getInstanceByManagedName(originalName());
|
InstancePtr inst;
|
||||||
|
if (auto original_id = originalInstanceID(); !original_id.isEmpty()) {
|
||||||
|
inst = instance_list->getInstanceById(original_id);
|
||||||
|
Q_ASSERT(inst);
|
||||||
|
} else {
|
||||||
|
inst = instance_list->getInstanceByManagedName(originalName());
|
||||||
|
|
||||||
if (!inst) {
|
if (!inst) {
|
||||||
inst = instance_list->getInstanceById(originalName());
|
inst = instance_list->getInstanceById(originalName());
|
||||||
@ -89,6 +94,7 @@ bool FlameCreationTask::updateInstance()
|
|||||||
if (!inst)
|
if (!inst)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
QString index_path(FS::PathCombine(m_stagingPath, "manifest.json"));
|
QString index_path(FS::PathCombine(m_stagingPath, "manifest.json"));
|
||||||
|
|
||||||
@ -233,7 +239,7 @@ bool FlameCreationTask::updateInstance()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
setOverride(true);
|
setOverride(true, inst->id());
|
||||||
qDebug() << "Will override instance!";
|
qDebug() << "Will override instance!";
|
||||||
|
|
||||||
m_instance = inst;
|
m_instance = inst;
|
||||||
|
@ -51,11 +51,21 @@ class FlameCreationTask final : public InstanceCreationTask {
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
FlameCreationTask(const QString& staging_path, SettingsObjectPtr global_settings, QWidget* parent, QString id, QString version_id)
|
FlameCreationTask(const QString& staging_path,
|
||||||
: InstanceCreationTask(), m_parent(parent), m_managed_id(std::move(id)), m_managed_version_id(std::move(version_id))
|
SettingsObjectPtr global_settings,
|
||||||
|
QWidget* parent,
|
||||||
|
QString id,
|
||||||
|
QString version_id,
|
||||||
|
QString original_instance_id = {})
|
||||||
|
: InstanceCreationTask()
|
||||||
|
, m_parent(parent)
|
||||||
|
, m_managed_id(std::move(id))
|
||||||
|
, m_managed_version_id(std::move(version_id))
|
||||||
{
|
{
|
||||||
setStagingPath(staging_path);
|
setStagingPath(staging_path);
|
||||||
setParentSettings(global_settings);
|
setParentSettings(global_settings);
|
||||||
|
|
||||||
|
m_original_instance_id = std::move(original_instance_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool abort() override;
|
bool abort() override;
|
||||||
|
@ -33,7 +33,12 @@ bool ModrinthCreationTask::updateInstance()
|
|||||||
auto instance_list = APPLICATION->instances();
|
auto instance_list = APPLICATION->instances();
|
||||||
|
|
||||||
// FIXME: How to handle situations when there's more than one install already for a given modpack?
|
// FIXME: How to handle situations when there's more than one install already for a given modpack?
|
||||||
auto inst = instance_list->getInstanceByManagedName(originalName());
|
InstancePtr inst;
|
||||||
|
if (auto original_id = originalInstanceID(); !original_id.isEmpty()) {
|
||||||
|
inst = instance_list->getInstanceById(original_id);
|
||||||
|
Q_ASSERT(inst);
|
||||||
|
} else {
|
||||||
|
inst = instance_list->getInstanceByManagedName(originalName());
|
||||||
|
|
||||||
if (!inst) {
|
if (!inst) {
|
||||||
inst = instance_list->getInstanceById(originalName());
|
inst = instance_list->getInstanceById(originalName());
|
||||||
@ -41,6 +46,7 @@ bool ModrinthCreationTask::updateInstance()
|
|||||||
if (!inst)
|
if (!inst)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
QString index_path = FS::PathCombine(m_stagingPath, "modrinth.index.json");
|
QString index_path = FS::PathCombine(m_stagingPath, "modrinth.index.json");
|
||||||
if (!parseManifest(index_path, m_files, true, false))
|
if (!parseManifest(index_path, m_files, true, false))
|
||||||
@ -138,7 +144,7 @@ bool ModrinthCreationTask::updateInstance()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
setOverride(true);
|
setOverride(true, inst->id());
|
||||||
qDebug() << "Will override instance!";
|
qDebug() << "Will override instance!";
|
||||||
|
|
||||||
m_instance = inst;
|
m_instance = inst;
|
||||||
|
@ -14,11 +14,21 @@ class ModrinthCreationTask final : public InstanceCreationTask {
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
ModrinthCreationTask(QString staging_path, SettingsObjectPtr global_settings, QWidget* parent, QString id, QString version_id = {})
|
ModrinthCreationTask(QString staging_path,
|
||||||
: InstanceCreationTask(), m_parent(parent), m_managed_id(std::move(id)), m_managed_version_id(std::move(version_id))
|
SettingsObjectPtr global_settings,
|
||||||
|
QWidget* parent,
|
||||||
|
QString id,
|
||||||
|
QString version_id = {},
|
||||||
|
QString original_instance_id = {})
|
||||||
|
: InstanceCreationTask()
|
||||||
|
, m_parent(parent)
|
||||||
|
, m_managed_id(std::move(id))
|
||||||
|
, m_managed_version_id(std::move(version_id))
|
||||||
{
|
{
|
||||||
setStagingPath(staging_path);
|
setStagingPath(staging_path);
|
||||||
setParentSettings(global_settings);
|
setParentSettings(global_settings);
|
||||||
|
|
||||||
|
m_original_instance_id = std::move(original_instance_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool abort() override;
|
bool abort() override;
|
||||||
|
@ -275,6 +275,7 @@ void ModrinthManagedPackPage::update()
|
|||||||
// NOTE: Don't use 'm_pack.id' here, since we didn't completely parse all the metadata for the pack, including this field.
|
// NOTE: Don't use 'm_pack.id' here, since we didn't completely parse all the metadata for the pack, including this field.
|
||||||
extra_info.insert("pack_id", m_inst->getManagedPackID());
|
extra_info.insert("pack_id", m_inst->getManagedPackID());
|
||||||
extra_info.insert("pack_version_id", version.id);
|
extra_info.insert("pack_version_id", version.id);
|
||||||
|
extra_info.insert("original_instance_id", m_inst->id());
|
||||||
|
|
||||||
auto extracted = new InstanceImportTask(version.download_url, this, std::move(extra_info));
|
auto extracted = new InstanceImportTask(version.download_url, this, std::move(extra_info));
|
||||||
|
|
||||||
@ -413,6 +414,7 @@ void FlameManagedPackPage::update()
|
|||||||
QMap<QString, QString> extra_info;
|
QMap<QString, QString> extra_info;
|
||||||
extra_info.insert("pack_id", m_inst->getManagedPackID());
|
extra_info.insert("pack_id", m_inst->getManagedPackID());
|
||||||
extra_info.insert("pack_version_id", QString::number(version.fileId));
|
extra_info.insert("pack_version_id", QString::number(version.fileId));
|
||||||
|
extra_info.insert("original_instance_id", m_inst->id());
|
||||||
|
|
||||||
auto extracted = new InstanceImportTask(version.downloadUrl, this, std::move(extra_info));
|
auto extracted = new InstanceImportTask(version.downloadUrl, this, std::move(extra_info));
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user