GameList: make GetSelectedGame a pointer to GameFile

This commit is contained in:
Michael M 2017-08-10 13:19:34 -07:00
parent f2a9ad0089
commit 3c002f0213
5 changed files with 32 additions and 26 deletions

View File

@ -143,11 +143,11 @@ void GameList::MakeGridView()
void GameList::ShowContextMenu(const QPoint&) void GameList::ShowContextMenu(const QPoint&)
{ {
const auto game = GetSelectedGame(); const auto game = GetSelectedGame();
if (game.isEmpty()) if (game.isNull())
return; return;
QMenu* menu = new QMenu(this); QMenu* menu = new QMenu(this);
DiscIO::Platform platform = GameFile(game).GetPlatformID(); DiscIO::Platform platform = game->GetPlatformID();
menu->addAction(tr("&Properties"), this, &GameList::OpenProperties); menu->addAction(tr("&Properties"), this, &GameList::OpenProperties);
menu->addAction(tr("&Wiki"), this, &GameList::OpenWiki); menu->addAction(tr("&Wiki"), this, &GameList::OpenWiki);
menu->addSeparator(); menu->addSeparator();
@ -155,7 +155,7 @@ void GameList::ShowContextMenu(const QPoint&)
if (platform == DiscIO::Platform::GAMECUBE_DISC || platform == DiscIO::Platform::WII_DISC) if (platform == DiscIO::Platform::GAMECUBE_DISC || platform == DiscIO::Platform::WII_DISC)
{ {
menu->addAction(tr("Set as &default ISO"), this, &GameList::SetDefaultISO); menu->addAction(tr("Set as &default ISO"), this, &GameList::SetDefaultISO);
const auto blob_type = GameFile(game).GetBlobType(); const auto blob_type = game->GetBlobType();
if (blob_type == DiscIO::BlobType::GCZ) if (blob_type == DiscIO::BlobType::GCZ)
menu->addAction(tr("Decompress ISO..."), this, &GameList::CompressISO); menu->addAction(tr("Decompress ISO..."), this, &GameList::CompressISO);
@ -182,7 +182,7 @@ void GameList::ShowContextMenu(const QPoint&)
connect(this, &GameList::EmulationStopped, wad_install_action, connect(this, &GameList::EmulationStopped, wad_install_action,
[wad_install_action] { wad_install_action->setEnabled(true); }); [wad_install_action] { wad_install_action->setEnabled(true); });
connect(this, &GameList::EmulationStopped, wad_uninstall_action, [wad_uninstall_action, game] { connect(this, &GameList::EmulationStopped, wad_uninstall_action, [wad_uninstall_action, game] {
wad_uninstall_action->setEnabled(GameFile(game).IsInstalled()); wad_uninstall_action->setEnabled(game->IsInstalled());
}); });
menu->addSeparator(); menu->addSeparator();
@ -201,7 +201,7 @@ void GameList::ShowContextMenu(const QPoint&)
QAction* netplay_host = new QAction(tr("Host with NetPlay"), menu); QAction* netplay_host = new QAction(tr("Host with NetPlay"), menu);
connect(netplay_host, &QAction::triggered, connect(netplay_host, &QAction::triggered,
[this, game] { emit NetPlayHost(GameFile(game).GetUniqueID()); }); [this, game] { emit NetPlayHost(game->GetUniqueID()); });
connect(this, &GameList::EmulationStarted, netplay_host, connect(this, &GameList::EmulationStarted, netplay_host,
[netplay_host] { netplay_host->setEnabled(false); }); [netplay_host] { netplay_host->setEnabled(false); });
@ -216,7 +216,7 @@ void GameList::ShowContextMenu(const QPoint&)
void GameList::OpenProperties() void GameList::OpenProperties()
{ {
PropertiesDialog* properties = new PropertiesDialog(this, GameFile(GetSelectedGame())); PropertiesDialog* properties = new PropertiesDialog(this, *GetSelectedGame());
properties->show(); properties->show();
} }
@ -224,7 +224,7 @@ void GameList::ExportWiiSave()
{ {
QMessageBox result_dialog(this); QMessageBox result_dialog(this);
const bool success = GameFile(GetSelectedGame()).ExportWiiSave(); const bool success = GetSelectedGame()->ExportWiiSave();
result_dialog.setIcon(success ? QMessageBox::Information : QMessageBox::Critical); result_dialog.setIcon(success ? QMessageBox::Information : QMessageBox::Critical);
result_dialog.setText(success ? tr("Successfully exported save files") : result_dialog.setText(success ? tr("Successfully exported save files") :
@ -234,19 +234,19 @@ void GameList::ExportWiiSave()
void GameList::OpenWiki() void GameList::OpenWiki()
{ {
QString game_id = GameFile(GetSelectedGame()).GetGameID(); QString game_id = GetSelectedGame()->GetGameID();
QString url = QStringLiteral("https://wiki.dolphin-emu.org/index.php?title=").append(game_id); QString url = QStringLiteral("https://wiki.dolphin-emu.org/index.php?title=").append(game_id);
QDesktopServices::openUrl(QUrl(url)); QDesktopServices::openUrl(QUrl(url));
} }
void GameList::CompressISO() void GameList::CompressISO()
{ {
const auto original_path = GetSelectedGame(); auto file = GetSelectedGame();
auto file = GameFile(original_path); const auto original_path = file->GetFilePath();
const bool compressed = (file.GetBlobType() == DiscIO::BlobType::GCZ); const bool compressed = (file->GetBlobType() == DiscIO::BlobType::GCZ);
if (!compressed && file.GetPlatformID() == DiscIO::Platform::WII_DISC) if (!compressed && file->GetPlatformID() == DiscIO::Platform::WII_DISC)
{ {
QMessageBox wii_warning(this); QMessageBox wii_warning(this);
wii_warning.setIcon(QMessageBox::Warning); wii_warning.setIcon(QMessageBox::Warning);
@ -263,9 +263,9 @@ void GameList::CompressISO()
QString dst_path = QFileDialog::getSaveFileName( QString dst_path = QFileDialog::getSaveFileName(
this, compressed ? tr("Select where you want to save the decompressed image") : this, compressed ? tr("Select where you want to save the decompressed image") :
tr("Select where you want to save the compressed image"), tr("Select where you want to save the compressed image"),
QFileInfo(GetSelectedGame()) QFileInfo(GetSelectedGame()->GetFilePath())
.dir() .dir()
.absoluteFilePath(file.GetGameID()) .absoluteFilePath(file->GetGameID())
.append(compressed ? QStringLiteral(".gcm") : QStringLiteral(".gcz")), .append(compressed ? QStringLiteral(".gcm") : QStringLiteral(".gcz")),
compressed ? tr("Uncompressed GC/Wii images (*.iso *.gcm)") : compressed ? tr("Uncompressed GC/Wii images (*.iso *.gcm)") :
tr("Compressed GC/Wii images (*.gcz)")); tr("Compressed GC/Wii images (*.gcz)"));
@ -287,7 +287,7 @@ void GameList::CompressISO()
else else
{ {
good = DiscIO::CompressFileToBlob(original_path.toStdString(), dst_path.toStdString(), good = DiscIO::CompressFileToBlob(original_path.toStdString(), dst_path.toStdString(),
file.GetPlatformID() == DiscIO::Platform::WII_DISC ? 1 : 0, file->GetPlatformID() == DiscIO::Platform::WII_DISC ? 1 : 0,
16384, &CompressCB, &progress_dialog); 16384, &CompressCB, &progress_dialog);
} }
@ -307,7 +307,7 @@ void GameList::InstallWAD()
{ {
QMessageBox result_dialog(this); QMessageBox result_dialog(this);
const bool success = GameFile(GetSelectedGame()).Install(); const bool success = GetSelectedGame()->Install();
result_dialog.setIcon(success ? QMessageBox::Information : QMessageBox::Critical); result_dialog.setIcon(success ? QMessageBox::Information : QMessageBox::Critical);
result_dialog.setText(success ? tr("Successfully installed this title to the NAND.") : result_dialog.setText(success ? tr("Successfully installed this title to the NAND.") :
@ -329,7 +329,7 @@ void GameList::UninstallWAD()
QMessageBox result_dialog(this); QMessageBox result_dialog(this);
const bool success = GameFile(GetSelectedGame()).Uninstall(); const bool success = GetSelectedGame()->Uninstall();
result_dialog.setIcon(success ? QMessageBox::Information : QMessageBox::Critical); result_dialog.setIcon(success ? QMessageBox::Information : QMessageBox::Critical);
result_dialog.setText(success ? tr("Successfully removed this title from the NAND.") : result_dialog.setText(success ? tr("Successfully removed this title from the NAND.") :
@ -339,24 +339,24 @@ void GameList::UninstallWAD()
void GameList::SetDefaultISO() void GameList::SetDefaultISO()
{ {
SConfig::GetInstance().m_strDefaultISO = GetSelectedGame().toStdString(); SConfig::GetInstance().m_strDefaultISO = GetSelectedGame()->GetFilePath().toStdString();
} }
void GameList::OpenContainingFolder() void GameList::OpenContainingFolder()
{ {
QUrl url = QUrl::fromLocalFile(QFileInfo(GetSelectedGame()).dir().absolutePath()); QUrl url = QUrl::fromLocalFile(QFileInfo(GetSelectedGame()->GetFilePath()).dir().absolutePath());
QDesktopServices::openUrl(url); QDesktopServices::openUrl(url);
} }
void GameList::OpenSaveFolder() void GameList::OpenSaveFolder()
{ {
QUrl url = QUrl::fromLocalFile(GameFile(GetSelectedGame()).GetWiiFSPath()); QUrl url = QUrl::fromLocalFile(GetSelectedGame()->GetWiiFSPath());
QDesktopServices::openUrl(url); QDesktopServices::openUrl(url);
} }
void GameList::DeleteFile() void GameList::DeleteFile()
{ {
const auto game = GetSelectedGame(); const auto game = GetSelectedGame()->GetFilePath();
QMessageBox confirm_dialog(this); QMessageBox confirm_dialog(this);
confirm_dialog.setIcon(QMessageBox::Warning); confirm_dialog.setIcon(QMessageBox::Warning);
@ -393,7 +393,7 @@ void GameList::DeleteFile()
} }
} }
QString GameList::GetSelectedGame() const QSharedPointer<GameFile> GameList::GetSelectedGame() const
{ {
QAbstractItemView* view; QAbstractItemView* view;
QSortFilterProxyModel* proxy; QSortFilterProxyModel* proxy;
@ -411,9 +411,9 @@ QString GameList::GetSelectedGame() const
if (sel_model->hasSelection()) if (sel_model->hasSelection())
{ {
QModelIndex model_index = proxy->mapToSource(sel_model->selectedIndexes()[0]); QModelIndex model_index = proxy->mapToSource(sel_model->selectedIndexes()[0]);
return m_model->GetPath(model_index.row()); return m_model->GetGameFile(model_index.row());
} }
return QStringLiteral(""); return {};
} }
void GameList::SetPreferredView(bool list) void GameList::SetPreferredView(bool list)

View File

@ -19,7 +19,7 @@ class GameList final : public QStackedWidget
public: public:
explicit GameList(QWidget* parent = nullptr); explicit GameList(QWidget* parent = nullptr);
QString GetSelectedGame() const; QSharedPointer<GameFile> GetSelectedGame() const;
void SetListView() { SetPreferredView(true); } void SetListView() { SetPreferredView(true); }
void SetGridView() { SetPreferredView(false); } void SetGridView() { SetPreferredView(false); }

View File

@ -195,6 +195,11 @@ bool GameListModel::ShouldDisplayGameListItem(int index) const
} }
} }
QSharedPointer<GameFile> GameListModel::GetGameFile(int index) const
{
return m_games[index];
}
void GameListModel::UpdateGame(QSharedPointer<GameFile> game) void GameListModel::UpdateGame(QSharedPointer<GameFile> game)
{ {
QString path = game->GetFilePath(); QString path = game->GetFilePath();

View File

@ -25,6 +25,7 @@ public:
int rowCount(const QModelIndex& parent) const override; int rowCount(const QModelIndex& parent) const override;
int columnCount(const QModelIndex& parent) const override; int columnCount(const QModelIndex& parent) const override;
QSharedPointer<GameFile> GetGameFile(int index) const;
// Path of the Game at the specified index. // Path of the Game at the specified index.
QString GetPath(int index) const { return m_games[index]->GetFilePath(); } QString GetPath(int index) const { return m_games[index]->GetFilePath(); }
// Unique ID of the Game at the specified index // Unique ID of the Game at the specified index

View File

@ -310,7 +310,7 @@ void MainWindow::Play()
} }
else else
{ {
QString selection = m_game_list->GetSelectedGame(); QString selection = m_game_list->GetSelectedGame()->GetFilePath();
if (selection.length() > 0) if (selection.length() > 0)
{ {
StartGame(selection); StartGame(selection);