Merge pull request #6347 from spycrab/qt_update_defiso

Qt/Settings: Update default gamelist path textbox when changed
This commit is contained in:
Stenzek 2018-02-03 00:55:45 +10:00 committed by GitHub
commit e20eac72f4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 22 additions and 3 deletions

View File

@ -368,7 +368,7 @@ void GameList::UninstallWAD()
void GameList::SetDefaultISO() void GameList::SetDefaultISO()
{ {
SConfig::GetInstance().m_strDefaultISO = GetSelectedGame()->GetFilePath().toStdString(); Settings::Instance().SetDefaultGame(GetSelectedGame()->GetFilePath());
} }
void GameList::OpenContainingFolder() void GameList::OpenContainingFolder()

View File

@ -72,6 +72,20 @@ void Settings::RemovePath(const QString& qpath)
emit PathRemoved(qpath); emit PathRemoved(qpath);
} }
QString Settings::GetDefaultGame() const
{
return QString::fromStdString(SConfig::GetInstance().m_strDefaultISO);
}
void Settings::SetDefaultGame(QString path)
{
if (GetDefaultGame() != path)
{
SConfig::GetInstance().m_strDefaultISO = path.toStdString();
emit DefaultGameChanged(path);
}
}
bool Settings::GetPreferredView() const bool Settings::GetPreferredView() const
{ {
return QSettings().value(QStringLiteral("PreferredView"), true).toBool(); return QSettings().value(QStringLiteral("PreferredView"), true).toBool();

View File

@ -53,6 +53,8 @@ public:
void RemovePath(const QString& path); void RemovePath(const QString& path);
bool GetPreferredView() const; bool GetPreferredView() const;
void SetPreferredView(bool list); void SetPreferredView(bool list);
QString GetDefaultGame() const;
void SetDefaultGame(QString path);
// Emulation // Emulation
int GetStateSlot() const; int GetStateSlot() const;
@ -96,6 +98,7 @@ signals:
void ThemeChanged(); void ThemeChanged();
void PathAdded(const QString&); void PathAdded(const QString&);
void PathRemoved(const QString&); void PathRemoved(const QString&);
void DefaultGameChanged(const QString&);
void HideCursorChanged(); void HideCursorChanged();
void VolumeChanged(int volume); void VolumeChanged(int volume);
void NANDRefresh(); void NANDRefresh();

View File

@ -97,9 +97,11 @@ QGridLayout* PathPane::MakePathsLayout()
QGridLayout* layout = new QGridLayout; QGridLayout* layout = new QGridLayout;
layout->setColumnStretch(1, 1); layout->setColumnStretch(1, 1);
m_game_edit = new QLineEdit(QString::fromStdString(SConfig::GetInstance().m_strDefaultISO)); m_game_edit = new QLineEdit(Settings::Instance().GetDefaultGame());
connect(m_game_edit, &QLineEdit::editingFinished, connect(m_game_edit, &QLineEdit::editingFinished,
[=] { SConfig::GetInstance().m_strDefaultISO = m_game_edit->text().toStdString(); }); [this] { Settings::Instance().SetDefaultGame(m_game_edit->text()); });
connect(&Settings::Instance(), &Settings::DefaultGameChanged,
[this](const QString& path) { m_game_edit->setText(path); });
QPushButton* game_open = new QPushButton; QPushButton* game_open = new QPushButton;
connect(game_open, &QPushButton::clicked, this, &PathPane::BrowseDefaultGame); connect(game_open, &QPushButton::clicked, this, &PathPane::BrowseDefaultGame);
layout->addWidget(new QLabel(tr("Default ISO:")), 0, 0); layout->addWidget(new QLabel(tr("Default ISO:")), 0, 0);