citra-emu
/
citra-canary
Archived
1
0
Fork 0

Add check before closure when emulation is running

Implement confirmation in a specific function
Fix typos and coding style

Coding convention
This commit is contained in:
LittleWhite 2016-01-10 13:31:20 +01:00
parent 7497675a83
commit c2b210f713
2 changed files with 25 additions and 0 deletions

View File

@ -497,7 +497,25 @@ void GMainWindow::OnConfigure() {
//GControllerConfigDialog* dialog = new GControllerConfigDialog(controller_ports, this); //GControllerConfigDialog* dialog = new GControllerConfigDialog(controller_ports, this);
} }
bool GMainWindow::ConfirmClose() {
if (emu_thread != nullptr) {
auto answer = QMessageBox::question(this, tr("Citra"),
tr("Are you sure you want to close Citra?"),
QMessageBox::Yes | QMessageBox::No, QMessageBox::No);
if (answer == QMessageBox::No) {
return false;
}
}
return true;
}
void GMainWindow::closeEvent(QCloseEvent* event) { void GMainWindow::closeEvent(QCloseEvent* event) {
if (!ConfirmClose()) {
event->ignore();
return;
}
// Save window layout // Save window layout
QSettings settings(QSettings::IniFormat, QSettings::UserScope, "Citra team", "Citra"); QSettings settings(QSettings::IniFormat, QSettings::UserScope, "Citra team", "Citra");

View File

@ -82,6 +82,13 @@ private:
*/ */
void UpdateRecentFiles(); void UpdateRecentFiles();
/**
* If the emulation is running,
* asks the user if he really want to close the emulator
*
* @return true if the user confirmed
*/
bool ConfirmClose();
void closeEvent(QCloseEvent* event) override; void closeEvent(QCloseEvent* event) override;
private slots: private slots: