mirror of
https://github.com/PrismLauncher/PrismLauncher.git
synced 2025-05-29 05:10:20 +02:00
Fix interaction with invalid chars
Signed-off-by: Yihe Li <winmikedows@hotmail.com>
This commit is contained in:
parent
294448a01e
commit
a7af120cf0
@ -46,24 +46,27 @@
|
|||||||
#include "InstanceList.h"
|
#include "InstanceList.h"
|
||||||
#include "ui/dialogs/CustomMessageBox.h"
|
#include "ui/dialogs/CustomMessageBox.h"
|
||||||
|
|
||||||
bool askToUpdateInstanceDirName(InstancePtr instance, QWidget* parent)
|
QString askToUpdateInstanceDirName(InstancePtr instance, QWidget* parent)
|
||||||
{
|
{
|
||||||
QString renamingMode = APPLICATION->settings()->get("InstRenamingMode").toString();
|
QString renamingMode = APPLICATION->settings()->get("InstRenamingMode").toString();
|
||||||
if (renamingMode == "MetadataOnly")
|
if (renamingMode == "MetadataOnly")
|
||||||
return false;
|
return QString();
|
||||||
|
|
||||||
auto oldRoot = instance->instanceRoot();
|
auto oldRoot = instance->instanceRoot();
|
||||||
auto oldName = QFileInfo(oldRoot).baseName();
|
auto oldName = QFileInfo(oldRoot).baseName();
|
||||||
|
if (oldName == FS::RemoveInvalidFilenameChars(instance->name(), '-'))
|
||||||
|
return QString();
|
||||||
|
|
||||||
auto newName = FS::DirNameFromString(instance->name(), QFileInfo(oldRoot).dir().absolutePath());
|
auto newName = FS::DirNameFromString(instance->name(), QFileInfo(oldRoot).dir().absolutePath());
|
||||||
auto newRoot = FS::PathCombine(QFileInfo(oldRoot).dir().absolutePath(), newName);
|
auto newRoot = FS::PathCombine(QFileInfo(oldRoot).dir().absolutePath(), newName);
|
||||||
if (oldRoot == newRoot)
|
if (oldRoot == newRoot)
|
||||||
return false;
|
return QString();
|
||||||
|
|
||||||
// Check for conflict
|
// Check for conflict
|
||||||
if (QDir(newRoot).exists()) {
|
if (QDir(newRoot).exists()) {
|
||||||
QMessageBox::warning(parent, QObject::tr("Cannot rename instance"),
|
QMessageBox::warning(parent, QObject::tr("Cannot rename instance"),
|
||||||
QObject::tr("New instance root (%1) already exists. <br />Only the metadata will be renamed.").arg(newRoot));
|
QObject::tr("New instance root (%1) already exists. <br />Only the metadata will be renamed.").arg(newRoot));
|
||||||
return false;
|
return QString();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Ask if we should rename
|
// Ask if we should rename
|
||||||
@ -86,12 +89,12 @@ bool askToUpdateInstanceDirName(InstancePtr instance, QWidget* parent)
|
|||||||
APPLICATION->settings()->set("InstRenamingMode", "MetadataOnly");
|
APPLICATION->settings()->set("InstRenamingMode", "MetadataOnly");
|
||||||
}
|
}
|
||||||
if (res == QMessageBox::No)
|
if (res == QMessageBox::No)
|
||||||
return false;
|
return QString();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check for linked instances
|
// Check for linked instances
|
||||||
if (!checkLinkedInstances(instance->id(), parent))
|
if (!checkLinkedInstances(instance->id(), parent))
|
||||||
return false;
|
return QString();
|
||||||
|
|
||||||
// Now we can confirm that a renaming is happening
|
// Now we can confirm that a renaming is happening
|
||||||
if (!instance->syncInstanceDirName(newRoot)) {
|
if (!instance->syncInstanceDirName(newRoot)) {
|
||||||
@ -101,9 +104,9 @@ bool askToUpdateInstanceDirName(InstancePtr instance, QWidget* parent)
|
|||||||
" - New instance root: %2<br/>"
|
" - New instance root: %2<br/>"
|
||||||
"Only the metadata is renamed.")
|
"Only the metadata is renamed.")
|
||||||
.arg(oldRoot, newRoot));
|
.arg(oldRoot, newRoot));
|
||||||
return false;
|
return QString();
|
||||||
}
|
}
|
||||||
return true;
|
return newRoot;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool checkLinkedInstances(const QString& id, QWidget* parent)
|
bool checkLinkedInstances(const QString& id, QWidget* parent)
|
||||||
|
@ -39,8 +39,8 @@
|
|||||||
|
|
||||||
#include "BaseInstance.h"
|
#include "BaseInstance.h"
|
||||||
|
|
||||||
/// Update instanceRoot to make it sync with name/id; return true if a refresh is needed
|
/// Update instanceRoot to make it sync with name/id; return newRoot if a directory rename happened
|
||||||
bool askToUpdateInstanceDirName(InstancePtr instance, QWidget* parent);
|
QString askToUpdateInstanceDirName(InstancePtr instance, QWidget* parent);
|
||||||
|
|
||||||
/// Check if there are linked instances, and display a warning; return true if the operation should proceed
|
/// Check if there are linked instances, and display a warning; return true if the operation should proceed
|
||||||
bool checkLinkedInstances(const QString& id, QWidget* parent);
|
bool checkLinkedInstances(const QString& id, QWidget* parent);
|
||||||
|
@ -583,6 +583,18 @@ InstancePtr InstanceList::getInstanceById(QString instId) const
|
|||||||
return InstancePtr();
|
return InstancePtr();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
InstancePtr InstanceList::getInstanceByRoot(QString instanceRoot) const
|
||||||
|
{
|
||||||
|
if (instanceRoot.isEmpty())
|
||||||
|
return InstancePtr();
|
||||||
|
for (auto& inst : m_instances) {
|
||||||
|
if (inst->instanceRoot() == instanceRoot) {
|
||||||
|
return inst;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return InstancePtr();
|
||||||
|
}
|
||||||
|
|
||||||
InstancePtr InstanceList::getInstanceByManagedName(const QString& managed_name) const
|
InstancePtr InstanceList::getInstanceByManagedName(const QString& managed_name) const
|
||||||
{
|
{
|
||||||
if (managed_name.isEmpty())
|
if (managed_name.isEmpty())
|
||||||
@ -601,6 +613,11 @@ QModelIndex InstanceList::getInstanceIndexById(const QString& id) const
|
|||||||
return index(getInstIndex(getInstanceById(id).get()));
|
return index(getInstIndex(getInstanceById(id).get()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QModelIndex InstanceList::getInstanceIndexByRoot(const QString& instanceRoot) const
|
||||||
|
{
|
||||||
|
return index(getInstIndex(getInstanceByRoot(instanceRoot).get()));
|
||||||
|
}
|
||||||
|
|
||||||
int InstanceList::getInstIndex(BaseInstance* inst) const
|
int InstanceList::getInstIndex(BaseInstance* inst) const
|
||||||
{
|
{
|
||||||
int count = m_instances.count();
|
int count = m_instances.count();
|
||||||
|
@ -99,9 +99,11 @@ class InstanceList : public QAbstractListModel {
|
|||||||
|
|
||||||
/* O(n) */
|
/* O(n) */
|
||||||
InstancePtr getInstanceById(QString id) const;
|
InstancePtr getInstanceById(QString id) const;
|
||||||
|
InstancePtr getInstanceByRoot(QString instanceRoot) const;
|
||||||
/* O(n) */
|
/* O(n) */
|
||||||
InstancePtr getInstanceByManagedName(const QString& managed_name) const;
|
InstancePtr getInstanceByManagedName(const QString& managed_name) const;
|
||||||
QModelIndex getInstanceIndexById(const QString& id) const;
|
QModelIndex getInstanceIndexById(const QString& id) const;
|
||||||
|
QModelIndex getInstanceIndexByRoot(const QString& instanceRoot) const;
|
||||||
QStringList getGroups();
|
QStringList getGroups();
|
||||||
bool isGroupCollapsed(const QString& groupName);
|
bool isGroupCollapsed(const QString& groupName);
|
||||||
|
|
||||||
|
@ -294,6 +294,12 @@ MainWindow::MainWindow(QWidget* parent) : QMainWindow(parent), ui(new Ui::MainWi
|
|||||||
view->setFrameShape(QFrame::NoFrame);
|
view->setFrameShape(QFrame::NoFrame);
|
||||||
// do not show ugly blue border on the mac
|
// do not show ugly blue border on the mac
|
||||||
view->setAttribute(Qt::WA_MacShowFocusRect, false);
|
view->setAttribute(Qt::WA_MacShowFocusRect, false);
|
||||||
|
connect(view->itemDelegate(), &QAbstractItemDelegate::closeEditor, this, [this] {
|
||||||
|
if (auto newRoot = askToUpdateInstanceDirName(m_selectedInstance, this); !newRoot.isEmpty()) {
|
||||||
|
refreshInstances();
|
||||||
|
setSelectedInstanceByRoot(newRoot);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
view->installEventFilter(this);
|
view->installEventFilter(this);
|
||||||
view->setContextMenuPolicy(Qt::CustomContextMenu);
|
view->setContextMenuPolicy(Qt::CustomContextMenu);
|
||||||
@ -1133,6 +1139,18 @@ void MainWindow::setSelectedInstanceById(const QString& id)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MainWindow::setSelectedInstanceByRoot(const QString& instanceRoot)
|
||||||
|
{
|
||||||
|
if (instanceRoot.isNull())
|
||||||
|
return;
|
||||||
|
const QModelIndex index = APPLICATION->instances()->getInstanceIndexByRoot(instanceRoot);
|
||||||
|
if (index.isValid()) {
|
||||||
|
QModelIndex selectionIndex = proxymodel->mapFromSource(index);
|
||||||
|
view->selectionModel()->setCurrentIndex(selectionIndex, QItemSelectionModel::ClearAndSelect);
|
||||||
|
updateStatusCenter();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void MainWindow::on_actionChangeInstGroup_triggered()
|
void MainWindow::on_actionChangeInstGroup_triggered()
|
||||||
{
|
{
|
||||||
if (!m_selectedInstance)
|
if (!m_selectedInstance)
|
||||||
@ -1428,13 +1446,6 @@ void MainWindow::on_actionExportInstanceFlamePack_triggered()
|
|||||||
void MainWindow::on_actionRenameInstance_triggered()
|
void MainWindow::on_actionRenameInstance_triggered()
|
||||||
{
|
{
|
||||||
if (m_selectedInstance) {
|
if (m_selectedInstance) {
|
||||||
connect(view->itemDelegate(), &QAbstractItemDelegate::closeEditor, this, [this] {
|
|
||||||
if (askToUpdateInstanceDirName(m_selectedInstance, this)) {
|
|
||||||
auto newID = m_selectedInstance->name();
|
|
||||||
refreshInstances();
|
|
||||||
setSelectedInstanceById(newID);
|
|
||||||
}
|
|
||||||
}, Qt::SingleShotConnection);
|
|
||||||
view->edit(view->currentIndex());
|
view->edit(view->currentIndex());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -224,6 +224,7 @@ class MainWindow : public QMainWindow {
|
|||||||
void setCatBackground(bool enabled);
|
void setCatBackground(bool enabled);
|
||||||
void updateInstanceToolIcon(QString new_icon);
|
void updateInstanceToolIcon(QString new_icon);
|
||||||
void setSelectedInstanceById(const QString& id);
|
void setSelectedInstanceById(const QString& id);
|
||||||
|
void setSelectedInstanceByRoot(const QString& instanceRoot);
|
||||||
void updateStatusCenter();
|
void updateStatusCenter();
|
||||||
void setInstanceActionsEnabled(bool enabled);
|
void setInstanceActionsEnabled(bool enabled);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user