Skip to content
Snippets Groups Projects
Commit 3dd26887 authored by bunnei's avatar bunnei
Browse files

Qt: Fix loading a new game without stopping emulation.

parent 5a855bdb
No related branches found
No related tags found
No related merge requests found
...@@ -199,6 +199,10 @@ void GMainWindow::OnDisplayTitleBars(bool show) ...@@ -199,6 +199,10 @@ void GMainWindow::OnDisplayTitleBars(bool show)
void GMainWindow::BootGame(std::string filename) { void GMainWindow::BootGame(std::string filename) {
LOG_INFO(Frontend, "Citra starting...\n"); LOG_INFO(Frontend, "Citra starting...\n");
// Shutdown previous session if the emu thread is still active...
if (emu_thread != nullptr)
ShutdownGame();
System::Init(render_window); System::Init(render_window);
// Load a game or die... // Load a game or die...
...@@ -217,6 +221,25 @@ void GMainWindow::BootGame(std::string filename) { ...@@ -217,6 +221,25 @@ void GMainWindow::BootGame(std::string filename) {
OnStartGame(); OnStartGame();
} }
void GMainWindow::ShutdownGame() {
emu_thread->SetCpuRunning(false);
emu_thread->ShutdownCpu();
emu_thread->WaitForCpuShutdown();
emu_thread->Stop();
delete emu_thread;
emu_thread = nullptr;
System::Shutdown();
ui.action_Start->setEnabled(true);
ui.action_Pause->setEnabled(false);
ui.action_Stop->setEnabled(false);
render_window->hide();
}
void GMainWindow::OnMenuLoadFile() void GMainWindow::OnMenuLoadFile()
{ {
QString filename = QFileDialog::getOpenFileName(this, tr("Load File"), QString(), tr("3DS executable (*.3ds *.3dsx *.elf *.axf *.bin *.cci *.cxi)")); QString filename = QFileDialog::getOpenFileName(this, tr("Load File"), QString(), tr("3DS executable (*.3ds *.3dsx *.elf *.axf *.bin *.cci *.cxi)"));
...@@ -249,21 +272,7 @@ void GMainWindow::OnPauseGame() ...@@ -249,21 +272,7 @@ void GMainWindow::OnPauseGame()
} }
void GMainWindow::OnStopGame() { void GMainWindow::OnStopGame() {
emu_thread->SetCpuRunning(false); ShutdownGame();
emu_thread->ShutdownCpu();
emu_thread->WaitForCpuShutdown();
emu_thread->Stop();
delete emu_thread;
System::Shutdown();
ui.action_Start->setEnabled(true);
ui.action_Pause->setEnabled(false);
ui.action_Stop->setEnabled(false);
render_window->hide();
} }
void GMainWindow::OnOpenHotkeysDialog() void GMainWindow::OnOpenHotkeysDialog()
......
...@@ -41,6 +41,7 @@ public: ...@@ -41,6 +41,7 @@ public:
private: private:
void BootGame(std::string filename); void BootGame(std::string filename);
void ShutdownGame();
void closeEvent(QCloseEvent* event) override; void closeEvent(QCloseEvent* event) override;
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment