Implement instance renaming

Signed-off-by: Yihe Li <winmikedows@hotmail.com>
This commit is contained in:
Yihe Li 2025-03-27 03:10:25 +08:00
parent 0da645594f
commit 4b20e3bc39
No known key found for this signature in database
6 changed files with 75 additions and 6 deletions

View File

@ -149,6 +149,11 @@ QStringList InstanceList::getLinkedInstancesById(const QString& id) const
return linkedInstances; return linkedInstances;
} }
QString InstanceList::getInstanceRootById(const InstanceId& id) const
{
return FS::PathCombine(m_instDir, id);
}
int InstanceList::rowCount(const QModelIndex& parent) const int InstanceList::rowCount(const QModelIndex& parent) const
{ {
Q_UNUSED(parent); Q_UNUSED(parent);
@ -627,7 +632,7 @@ InstancePtr InstanceList::loadInstance(const InstanceId& id)
loadGroupList(); loadGroupList();
} }
auto instanceRoot = FS::PathCombine(m_instDir, id); auto instanceRoot = getInstanceRootById(id);
auto instanceSettings = std::make_shared<INISettingsObject>(FS::PathCombine(instanceRoot, "instance.cfg")); auto instanceSettings = std::make_shared<INISettingsObject>(FS::PathCombine(instanceRoot, "instance.cfg"));
InstancePtr inst; InstancePtr inst;

View File

@ -152,6 +152,7 @@ class InstanceList : public QAbstractListModel {
QMimeData* mimeData(const QModelIndexList& indexes) const override; QMimeData* mimeData(const QModelIndexList& indexes) const override;
QStringList getLinkedInstancesById(const QString& id) const; QStringList getLinkedInstancesById(const QString& id) const;
QString getInstanceRootById(const InstanceId& id) const;
signals: signals:
void dataIsInvalid(); void dataIsInvalid();

View File

@ -54,6 +54,7 @@
#include <QActionGroup> #include <QActionGroup>
#include <QApplication> #include <QApplication>
#include <QButtonGroup> #include <QButtonGroup>
#include <QCheckBox>
#include <QFileDialog> #include <QFileDialog>
#include <QHBoxLayout> #include <QHBoxLayout>
#include <QHeaderView> #include <QHeaderView>
@ -564,6 +565,67 @@ void MainWindow::showInstanceContextMenu(const QPoint& pos)
myMenu.exec(view->mapToGlobal(pos)); myMenu.exec(view->mapToGlobal(pos));
} }
void MainWindow::updateInstanceRoot()
{
QString renamingMode = APPLICATION->settings()->get("InstRenamingMode").toString();
if (renamingMode == "MetadataOnly")
return;
auto oldRoot = m_selectedInstance->instanceRoot();
auto newID = m_selectedInstance->name();
auto newRoot = APPLICATION->instances()->getInstanceRootById(newID);
if (oldRoot == newRoot)
return;
// Check for conflict
if (QDir(newRoot).exists()) {
QMessageBox::warning(this, tr("Cannot rename instance"),
tr("New instance root (%1) already exists. <br />Only the metadata will be renamed.").arg(newRoot));
return;
}
// Ask if we should rename
if (renamingMode == "AskEverytime") {
QMessageBox messageBox(this);
messageBox.setText(tr("Do you want to also rename the instance\'s physical directory?"));
messageBox.setInformativeText(tr("The following renaming operation will be performed: <br/>"
" - Old instance root: %1<br/>"
" - New instance root: %2")
.arg(oldRoot, newRoot));
messageBox.setStandardButtons(QMessageBox::Yes | QMessageBox::No);
messageBox.setDefaultButton(QMessageBox::Yes);
messageBox.setIcon(QMessageBox::Question);
auto checkBox = new QCheckBox(tr("&Remember my choice"), this);
checkBox->setChecked(true);
messageBox.setCheckBox(checkBox);
auto res = messageBox.exec();
if (checkBox->isChecked()) {
if (res == QMessageBox::Yes)
APPLICATION->settings()->set("InstRenamingMode", "PhysicalDir");
else
APPLICATION->settings()->set("InstRenamingMode", "MetadataOnly");
}
if (res == QMessageBox::No)
return;
}
// Now we can confirm that a renaming is happening
auto ret = QFile::rename(oldRoot, newRoot);
if (!ret) {
QMessageBox::warning(this, tr("Cannot rename instance"),
tr("An error occurred when performing the following renaming operation: <br/>"
" - Old instance root: %1<br/>"
" - New instance root: %2<br/>"
"Only the metadata is renamed.")
.arg(oldRoot, newRoot));
return;
}
refreshInstances();
setSelectedInstanceById(newID);
}
void MainWindow::updateMainToolBar() void MainWindow::updateMainToolBar()
{ {
ui->menuBar->setVisible(APPLICATION->settings()->get("MenuBarInsteadOfToolBar").toBool()); ui->menuBar->setVisible(APPLICATION->settings()->get("MenuBarInsteadOfToolBar").toBool());
@ -1703,6 +1765,7 @@ void MainWindow::instanceDataChanged(const QModelIndex& topLeft, const QModelInd
QItemSelection test(topLeft, bottomRight); QItemSelection test(topLeft, bottomRight);
if (test.contains(current)) { if (test.contains(current)) {
instanceChanged(current, current); instanceChanged(current, current);
updateInstanceRoot();
} }
} }

View File

@ -176,6 +176,8 @@ class MainWindow : public QMainWindow {
void showInstanceContextMenu(const QPoint&); void showInstanceContextMenu(const QPoint&);
void updateInstanceRoot();
void updateMainToolBar(); void updateMainToolBar();
void updateLaunchButton(); void updateLaunchButton();

View File

@ -241,7 +241,7 @@ void LauncherPage::applySettings()
s->set("MoveModsFromDownloadsDir", ui->downloadsDirMoveCheckBox->isChecked()); s->set("MoveModsFromDownloadsDir", ui->downloadsDirMoveCheckBox->isChecked());
// Instance // Instance
auto sortMode = (InstSortMode) ui->viewSortingComboBox->currentIndex(); auto sortMode = (InstSortMode)ui->viewSortingComboBox->currentIndex();
switch (sortMode) { switch (sortMode) {
case Sort_LastLaunch: case Sort_LastLaunch:
s->set("InstSortMode", "LastLaunch"); s->set("InstSortMode", "LastLaunch");
@ -252,7 +252,7 @@ void LauncherPage::applySettings()
break; break;
} }
auto renamingMode = (InstRenamingMode) ui->renamingBehaviorComboBox->currentIndex(); auto renamingMode = (InstRenamingMode)ui->renamingBehaviorComboBox->currentIndex();
switch (renamingMode) { switch (renamingMode) {
case Rename_Metadata: case Rename_Metadata:
s->set("InstRenamingMode", "MetadataOnly"); s->set("InstRenamingMode", "MetadataOnly");
@ -334,7 +334,7 @@ void LauncherPage::loadSettings()
InstRenamingMode renamingModeEnum; InstRenamingMode renamingModeEnum;
if (renamingMode == "MetadataOnly") { if (renamingMode == "MetadataOnly") {
renamingModeEnum = Rename_Metadata; renamingModeEnum = Rename_Metadata;
} else if (renamingMode == "PhysicalDir"){ } else if (renamingMode == "PhysicalDir") {
renamingModeEnum = Rename_Physical; renamingModeEnum = Rename_Physical;
} else { } else {
renamingModeEnum = Rename_Ask; renamingModeEnum = Rename_Ask;

View File

@ -701,8 +701,6 @@
<tabstop>numberOfConcurrentDownloadsSpinBox</tabstop> <tabstop>numberOfConcurrentDownloadsSpinBox</tabstop>
<tabstop>numberOfManualRetriesSpinBox</tabstop> <tabstop>numberOfManualRetriesSpinBox</tabstop>
<tabstop>timeoutSecondsSpinBox</tabstop> <tabstop>timeoutSecondsSpinBox</tabstop>
<tabstop>sortLastLaunchedComboBox</tabstop>
<tabstop>sortByNameBtn</tabstop>
<tabstop>catOpacitySpinBox</tabstop> <tabstop>catOpacitySpinBox</tabstop>
<tabstop>preferMenuBarCheckBox</tabstop> <tabstop>preferMenuBarCheckBox</tabstop>
<tabstop>lineLimitSpinBox</tabstop> <tabstop>lineLimitSpinBox</tabstop>