mirror of https://github.com/PCSX2/pcsx2.git
Qt: Fix game properties for unscanned files
This commit is contained in:
parent
32621a9369
commit
2eb7c47572
|
@ -1126,8 +1126,9 @@ void MainWindow::onGameListEntryContextMenuRequested(const QPoint& point)
|
||||||
if (action->isEnabled())
|
if (action->isEnabled())
|
||||||
{
|
{
|
||||||
connect(action, &QAction::triggered, [entry]() {
|
connect(action, &QAction::triggered, [entry]() {
|
||||||
SettingsDialog::openGamePropertiesDialog(
|
SettingsDialog::openGamePropertiesDialog(entry, entry->title,
|
||||||
entry, (entry->type != GameList::EntryType::ELF) ? std::string_view(entry->serial) : std::string_view(), entry->crc);
|
(entry->type != GameList::EntryType::ELF) ? entry->serial : std::string(),
|
||||||
|
entry->crc);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1319,13 +1320,15 @@ void MainWindow::onViewGamePropertiesActionTriggered()
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// prefer to use a game list entry, if we have one, that way the summary is populated
|
// prefer to use a game list entry, if we have one, that way the summary is populated
|
||||||
if (!m_current_disc_path.isEmpty() && m_current_elf_override.isEmpty())
|
if (!m_current_disc_path.isEmpty() || !m_current_elf_override.isEmpty())
|
||||||
{
|
{
|
||||||
auto lock = GameList::GetLock();
|
auto lock = GameList::GetLock();
|
||||||
const GameList::Entry* entry = GameList::GetEntryForPath(m_current_disc_path.toUtf8().constData());
|
const QString& path = (m_current_elf_override.isEmpty() ? m_current_disc_path : m_current_elf_override);
|
||||||
|
const GameList::Entry* entry = GameList::GetEntryForPath(path.toUtf8().constData());
|
||||||
if (entry)
|
if (entry)
|
||||||
{
|
{
|
||||||
SettingsDialog::openGamePropertiesDialog(entry, entry->serial, entry->crc);
|
SettingsDialog::openGamePropertiesDialog(
|
||||||
|
entry, entry->title, m_current_elf_override.isEmpty() ? entry->serial : std::string(), entry->crc);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1339,9 +1342,15 @@ void MainWindow::onViewGamePropertiesActionTriggered()
|
||||||
|
|
||||||
// can't use serial for ELFs, because they might have a disc set
|
// can't use serial for ELFs, because they might have a disc set
|
||||||
if (m_current_elf_override.isEmpty())
|
if (m_current_elf_override.isEmpty())
|
||||||
SettingsDialog::openGamePropertiesDialog(nullptr, m_current_disc_serial.toStdString(), m_current_disc_crc);
|
{
|
||||||
|
SettingsDialog::openGamePropertiesDialog(
|
||||||
|
nullptr, m_current_title.toStdString(), m_current_disc_serial.toStdString(), m_current_disc_crc);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
SettingsDialog::openGamePropertiesDialog(nullptr, std::string_view(), m_current_disc_crc);
|
{
|
||||||
|
SettingsDialog::openGamePropertiesDialog(
|
||||||
|
nullptr, m_current_title.toStdString(), std::string(), m_current_disc_crc);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::onGitHubRepositoryActionTriggered()
|
void MainWindow::onGitHubRepositoryActionTriggered()
|
||||||
|
|
|
@ -27,10 +27,8 @@
|
||||||
|
|
||||||
#include "common/HeterogeneousContainers.h"
|
#include "common/HeterogeneousContainers.h"
|
||||||
|
|
||||||
GameCheatSettingsWidget::GameCheatSettingsWidget(const GameList::Entry* entry, SettingsDialog* dialog, QWidget* parent)
|
GameCheatSettingsWidget::GameCheatSettingsWidget(SettingsDialog* dialog, QWidget* parent)
|
||||||
: m_dialog(dialog)
|
: m_dialog(dialog)
|
||||||
, m_serial(entry->serial)
|
|
||||||
, m_crc(entry->crc)
|
|
||||||
{
|
{
|
||||||
m_ui.setupUi(this);
|
m_ui.setupUi(this);
|
||||||
QtUtils::ResizeColumnsForTreeView(m_ui.cheatList, {300, 100, -1});
|
QtUtils::ResizeColumnsForTreeView(m_ui.cheatList, {300, 100, -1});
|
||||||
|
@ -154,7 +152,7 @@ void GameCheatSettingsWidget::setStateRecursively(QTreeWidgetItem* parent, bool
|
||||||
void GameCheatSettingsWidget::reloadList()
|
void GameCheatSettingsWidget::reloadList()
|
||||||
{
|
{
|
||||||
u32 num_unlabelled_codes = 0;
|
u32 num_unlabelled_codes = 0;
|
||||||
m_patches = Patch::GetPatchInfo(m_serial, m_crc, true, &num_unlabelled_codes);
|
m_patches = Patch::GetPatchInfo(m_dialog->getSerial(), m_dialog->getDiscCRC(), true, &num_unlabelled_codes);
|
||||||
m_enabled_patches =
|
m_enabled_patches =
|
||||||
m_dialog->getSettingsInterface()->GetStringList(Patch::CHEATS_CONFIG_SECTION, Patch::PATCH_ENABLE_CONFIG_KEY);
|
m_dialog->getSettingsInterface()->GetStringList(Patch::CHEATS_CONFIG_SECTION, Patch::PATCH_ENABLE_CONFIG_KEY);
|
||||||
|
|
||||||
|
|
|
@ -39,7 +39,7 @@ class GameCheatSettingsWidget : public QWidget
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
GameCheatSettingsWidget(const GameList::Entry* entry, SettingsDialog* dialog, QWidget* parent);
|
GameCheatSettingsWidget(SettingsDialog* dialog, QWidget* parent);
|
||||||
~GameCheatSettingsWidget();
|
~GameCheatSettingsWidget();
|
||||||
|
|
||||||
private Q_SLOTS:
|
private Q_SLOTS:
|
||||||
|
@ -59,9 +59,6 @@ private:
|
||||||
Ui::GameCheatSettingsWidget m_ui;
|
Ui::GameCheatSettingsWidget m_ui;
|
||||||
SettingsDialog* m_dialog;
|
SettingsDialog* m_dialog;
|
||||||
|
|
||||||
std::string m_serial;
|
|
||||||
u32 m_crc;
|
|
||||||
|
|
||||||
UnorderedStringMap<QTreeWidgetItem*> m_parent_map;
|
UnorderedStringMap<QTreeWidgetItem*> m_parent_map;
|
||||||
std::vector<Patch::PatchInfo> m_patches;
|
std::vector<Patch::PatchInfo> m_patches;
|
||||||
std::vector<std::string> m_enabled_patches;
|
std::vector<std::string> m_enabled_patches;
|
||||||
|
|
|
@ -59,10 +59,8 @@ void GamePatchDetailsWidget::onEnabledStateChanged(int state)
|
||||||
g_emu_thread->reloadGameSettings();
|
g_emu_thread->reloadGameSettings();
|
||||||
}
|
}
|
||||||
|
|
||||||
GamePatchSettingsWidget::GamePatchSettingsWidget(const GameList::Entry* entry, SettingsDialog* dialog, QWidget* parent)
|
GamePatchSettingsWidget::GamePatchSettingsWidget(SettingsDialog* dialog, QWidget* parent)
|
||||||
: m_dialog(dialog)
|
: m_dialog(dialog)
|
||||||
, m_serial(entry->serial)
|
|
||||||
, m_crc(entry->crc)
|
|
||||||
{
|
{
|
||||||
m_ui.setupUi(this);
|
m_ui.setupUi(this);
|
||||||
m_ui.scrollArea->setFrameShape(QFrame::WinPanel);
|
m_ui.scrollArea->setFrameShape(QFrame::WinPanel);
|
||||||
|
@ -86,7 +84,7 @@ void GamePatchSettingsWidget::onReloadClicked()
|
||||||
void GamePatchSettingsWidget::reloadList()
|
void GamePatchSettingsWidget::reloadList()
|
||||||
{
|
{
|
||||||
// Patches shouldn't have any unlabelled patch groups, because they're new.
|
// Patches shouldn't have any unlabelled patch groups, because they're new.
|
||||||
std::vector<Patch::PatchInfo> patches = Patch::GetPatchInfo(m_serial, m_crc, false, nullptr);
|
std::vector<Patch::PatchInfo> patches = Patch::GetPatchInfo(m_dialog->getSerial(), m_dialog->getDiscCRC(), false, nullptr);
|
||||||
std::vector<std::string> enabled_list =
|
std::vector<std::string> enabled_list =
|
||||||
m_dialog->getSettingsInterface()->GetStringList(Patch::PATCHES_CONFIG_SECTION, Patch::PATCH_ENABLE_CONFIG_KEY);
|
m_dialog->getSettingsInterface()->GetStringList(Patch::PATCHES_CONFIG_SECTION, Patch::PATCH_ENABLE_CONFIG_KEY);
|
||||||
|
|
||||||
|
|
|
@ -52,7 +52,7 @@ class GamePatchSettingsWidget : public QWidget
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
GamePatchSettingsWidget(const GameList::Entry* entry, SettingsDialog* dialog, QWidget* parent);
|
GamePatchSettingsWidget(SettingsDialog* dialog, QWidget* parent);
|
||||||
~GamePatchSettingsWidget();
|
~GamePatchSettingsWidget();
|
||||||
|
|
||||||
private Q_SLOTS:
|
private Q_SLOTS:
|
||||||
|
@ -63,7 +63,4 @@ private:
|
||||||
|
|
||||||
Ui::GamePatchSettingsWidget m_ui;
|
Ui::GamePatchSettingsWidget m_ui;
|
||||||
SettingsDialog* m_dialog;
|
SettingsDialog* m_dialog;
|
||||||
|
|
||||||
std::string m_serial;
|
|
||||||
u32 m_crc;
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -53,15 +53,17 @@ static QList<SettingsDialog*> s_open_game_properties_dialogs;
|
||||||
|
|
||||||
SettingsDialog::SettingsDialog(QWidget* parent)
|
SettingsDialog::SettingsDialog(QWidget* parent)
|
||||||
: QDialog(parent)
|
: QDialog(parent)
|
||||||
, m_game_crc(0)
|
, m_disc_crc(0)
|
||||||
{
|
{
|
||||||
setupUi(nullptr);
|
setupUi(nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
SettingsDialog::SettingsDialog(QWidget* parent, std::unique_ptr<SettingsInterface> sif, const GameList::Entry* game, u32 game_crc)
|
SettingsDialog::SettingsDialog(QWidget* parent, std::unique_ptr<SettingsInterface> sif, const GameList::Entry* game,
|
||||||
|
std::string serial, u32 disc_crc)
|
||||||
: QDialog(parent)
|
: QDialog(parent)
|
||||||
, m_sif(std::move(sif))
|
, m_sif(std::move(sif))
|
||||||
, m_game_crc(game_crc)
|
, m_serial(std::move(serial))
|
||||||
|
, m_disc_crc(disc_crc)
|
||||||
{
|
{
|
||||||
setupUi(game);
|
setupUi(game);
|
||||||
|
|
||||||
|
@ -77,10 +79,19 @@ void SettingsDialog::setupUi(const GameList::Entry* game)
|
||||||
|
|
||||||
if (isPerGameSettings())
|
if (isPerGameSettings())
|
||||||
{
|
{
|
||||||
|
QString summary = tr("<strong>Summary</strong><hr>Eventually this will be where we can see patches and compute "
|
||||||
|
"hashes/verify dumps/etc.");
|
||||||
if (game)
|
if (game)
|
||||||
{
|
{
|
||||||
addWidget(new GameSummaryWidget(game, this, m_ui.settingsContainer), tr("Summary"), QStringLiteral("file-list-line"),
|
addWidget(new GameSummaryWidget(game, this, m_ui.settingsContainer), tr("Summary"),
|
||||||
tr("<strong>Summary</strong><hr>Eventually this will be where we can see patches and compute hashes/verify dumps/etc."));
|
QStringLiteral("file-list-line"), std::move(summary));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
QLabel* placeholder_label =
|
||||||
|
new QLabel(tr("Summary is unavailable for files not present in game list."), m_ui.settingsContainer);
|
||||||
|
placeholder_label->setAlignment(Qt::AlignLeft | Qt::AlignTop);
|
||||||
|
addWidget(placeholder_label, tr("Summary"), QStringLiteral("file-list-line"), std::move(summary));
|
||||||
}
|
}
|
||||||
|
|
||||||
m_ui.restoreDefaultsButton->setVisible(false);
|
m_ui.restoreDefaultsButton->setVisible(false);
|
||||||
|
@ -108,13 +119,13 @@ void SettingsDialog::setupUi(const GameList::Entry* game)
|
||||||
tr("<strong>Emulation Settings</strong><hr>These options determine the configuration of frame pacing and game "
|
tr("<strong>Emulation Settings</strong><hr>These options determine the configuration of frame pacing and game "
|
||||||
"settings.<br><br>Mouse over an option for additional information."));
|
"settings.<br><br>Mouse over an option for additional information."));
|
||||||
|
|
||||||
if (isPerGameSettings() && game && game->crc != 0)
|
if (isPerGameSettings())
|
||||||
{
|
{
|
||||||
addWidget(m_game_patch_settings_widget = new GamePatchSettingsWidget(game, this, m_ui.settingsContainer),
|
addWidget(m_game_patch_settings_widget = new GamePatchSettingsWidget(this, m_ui.settingsContainer),
|
||||||
tr("Patches"), QStringLiteral("band-aid-line"),
|
tr("Patches"), QStringLiteral("band-aid-line"),
|
||||||
tr("<strong>Patches</strong><hr>This section allows you to select optional patches to apply to the game, "
|
tr("<strong>Patches</strong><hr>This section allows you to select optional patches to apply to the game, "
|
||||||
"which may provide performance, visual, or gameplay improvements."));
|
"which may provide performance, visual, or gameplay improvements."));
|
||||||
addWidget(m_game_cheat_settings_widget = new GameCheatSettingsWidget(game, this, m_ui.settingsContainer),
|
addWidget(m_game_cheat_settings_widget = new GameCheatSettingsWidget(this, m_ui.settingsContainer),
|
||||||
tr("Cheats"), QStringLiteral("cheats-line"),
|
tr("Cheats"), QStringLiteral("cheats-line"),
|
||||||
tr("<strong>Cheats</strong><hr>This section allows you to select which cheats you wish to enable. You "
|
tr("<strong>Cheats</strong><hr>This section allows you to select which cheats you wish to enable. You "
|
||||||
"cannot enable/disable cheats without labels for old-format pnach files, those will automatically "
|
"cannot enable/disable cheats without labels for old-format pnach files, those will automatically "
|
||||||
|
@ -517,12 +528,12 @@ void SettingsDialog::removeSettingValue(const char* section, const char* key)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void SettingsDialog::openGamePropertiesDialog(const GameList::Entry* game, const std::string_view& serial, u32 crc)
|
void SettingsDialog::openGamePropertiesDialog(const GameList::Entry* game, const std::string_view& title, std::string serial, u32 disc_crc)
|
||||||
{
|
{
|
||||||
// check for an existing dialog with this crc
|
// check for an existing dialog with this crc
|
||||||
for (SettingsDialog* dialog : s_open_game_properties_dialogs)
|
for (SettingsDialog* dialog : s_open_game_properties_dialogs)
|
||||||
{
|
{
|
||||||
if (dialog->m_game_crc == crc)
|
if (dialog->m_disc_crc == disc_crc)
|
||||||
{
|
{
|
||||||
dialog->show();
|
dialog->show();
|
||||||
dialog->setFocus();
|
dialog->setFocus();
|
||||||
|
@ -530,16 +541,16 @@ void SettingsDialog::openGamePropertiesDialog(const GameList::Entry* game, const
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string filename(VMManager::GetGameSettingsPath(serial, crc));
|
std::string filename(VMManager::GetGameSettingsPath(serial, disc_crc));
|
||||||
std::unique_ptr<INISettingsInterface> sif = std::make_unique<INISettingsInterface>(std::move(filename));
|
std::unique_ptr<INISettingsInterface> sif = std::make_unique<INISettingsInterface>(std::move(filename));
|
||||||
if (FileSystem::FileExists(sif->GetFileName().c_str()))
|
if (FileSystem::FileExists(sif->GetFileName().c_str()))
|
||||||
sif->Load();
|
sif->Load();
|
||||||
|
|
||||||
const QString window_title(tr("%1 [%2]")
|
const QString window_title(tr("%1 [%2]")
|
||||||
.arg(game ? QtUtils::StringViewToQString(game->title) : QStringLiteral("<UNKNOWN>"))
|
.arg(QtUtils::StringViewToQString(title))
|
||||||
.arg(QtUtils::StringViewToQString(Path::GetFileName(sif->GetFileName()))));
|
.arg(QtUtils::StringViewToQString(Path::GetFileName(sif->GetFileName()))));
|
||||||
|
|
||||||
SettingsDialog* dialog = new SettingsDialog(g_main_window, std::move(sif), game, crc);
|
SettingsDialog* dialog = new SettingsDialog(g_main_window, std::move(sif), game, std::move(serial), disc_crc);
|
||||||
dialog->setWindowTitle(window_title);
|
dialog->setWindowTitle(window_title);
|
||||||
dialog->setModal(false);
|
dialog->setModal(false);
|
||||||
dialog->show();
|
dialog->show();
|
||||||
|
|
|
@ -51,13 +51,15 @@ class SettingsDialog final : public QDialog
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit SettingsDialog(QWidget* parent);
|
explicit SettingsDialog(QWidget* parent);
|
||||||
SettingsDialog(QWidget* parent, std::unique_ptr<SettingsInterface> sif, const GameList::Entry* game, u32 game_crc);
|
SettingsDialog(QWidget* parent, std::unique_ptr<SettingsInterface> sif, const GameList::Entry* game, std::string serial, u32 disc_crc);
|
||||||
~SettingsDialog();
|
~SettingsDialog();
|
||||||
|
|
||||||
static void openGamePropertiesDialog(const GameList::Entry* game, const std::string_view& serial, u32 crc);
|
static void openGamePropertiesDialog(const GameList::Entry* game, const std::string_view& title, std::string serial, u32 disc_crc);
|
||||||
|
|
||||||
__fi bool isPerGameSettings() const { return static_cast<bool>(m_sif); }
|
|
||||||
__fi SettingsInterface* getSettingsInterface() const { return m_sif.get(); }
|
__fi SettingsInterface* getSettingsInterface() const { return m_sif.get(); }
|
||||||
|
__fi bool isPerGameSettings() const { return static_cast<bool>(m_sif); }
|
||||||
|
__fi const std::string& getSerial() const { return m_serial; }
|
||||||
|
__fi u32 getDiscCRC() const { return m_disc_crc; }
|
||||||
|
|
||||||
__fi InterfaceSettingsWidget* getInterfaceSettingsWidget() const { return m_interface_settings; }
|
__fi InterfaceSettingsWidget* getInterfaceSettingsWidget() const { return m_interface_settings; }
|
||||||
__fi GameListSettingsWidget* getGameListSettingsWidget() const { return m_game_list_settings; }
|
__fi GameListSettingsWidget* getGameListSettingsWidget() const { return m_game_list_settings; }
|
||||||
|
@ -143,5 +145,6 @@ private:
|
||||||
QObject* m_current_help_widget = nullptr;
|
QObject* m_current_help_widget = nullptr;
|
||||||
QMap<QObject*, QString> m_widget_help_text_map;
|
QMap<QObject*, QString> m_widget_help_text_map;
|
||||||
|
|
||||||
u32 m_game_crc;
|
std::string m_serial;
|
||||||
|
u32 m_disc_crc;
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue