forked from eden-emu/eden
		
	yuzu: Enable to use controller to restart a game
- Show the right confirm dialog if wanted - Create generic method to ask close confirmation - Add "R + Plus + Minus" default shortcut to Restart emulation
This commit is contained in:
		
							parent
							
								
									6c246f2ac5
								
							
						
					
					
						commit
						48b67fc4a0
					
				
					 3 changed files with 29 additions and 18 deletions
				
			
		|  | @ -128,7 +128,7 @@ const std::array<UISettings::Shortcut, 22> Config::default_hotkeys{{ | ||||||
|     {QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Fullscreen")),               QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Main Window")), {QStringLiteral("F11"),     QStringLiteral("Home+B"), Qt::WindowShortcut, false}}, |     {QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Fullscreen")),               QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Main Window")), {QStringLiteral("F11"),     QStringLiteral("Home+B"), Qt::WindowShortcut, false}}, | ||||||
|     {QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Load File")),                QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Main Window")), {QStringLiteral("Ctrl+O"),  QStringLiteral(""), Qt::WidgetWithChildrenShortcut, false}}, |     {QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Load File")),                QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Main Window")), {QStringLiteral("Ctrl+O"),  QStringLiteral(""), Qt::WidgetWithChildrenShortcut, false}}, | ||||||
|     {QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Load/Remove Amiibo")),       QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Main Window")), {QStringLiteral("F2"),      QStringLiteral("Home+A"), Qt::WidgetWithChildrenShortcut, false}}, |     {QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Load/Remove Amiibo")),       QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Main Window")), {QStringLiteral("F2"),      QStringLiteral("Home+A"), Qt::WidgetWithChildrenShortcut, false}}, | ||||||
|     {QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Restart Emulation")),        QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Main Window")), {QStringLiteral("F6"),      QStringLiteral(""), Qt::WindowShortcut, false}}, |     {QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Restart Emulation")),        QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Main Window")), {QStringLiteral("F6"),      QStringLiteral("R+Plus+Minus"), Qt::WindowShortcut, false}}, | ||||||
|     {QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Stop Emulation")),           QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Main Window")), {QStringLiteral("F5"),      QStringLiteral("L+Plus+Minus"), Qt::WindowShortcut, false}}, |     {QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Stop Emulation")),           QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Main Window")), {QStringLiteral("F5"),      QStringLiteral("L+Plus+Minus"), Qt::WindowShortcut, false}}, | ||||||
|     {QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "TAS Record")),               QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Main Window")), {QStringLiteral("Ctrl+F7"), QStringLiteral(""), Qt::ApplicationShortcut, false}}, |     {QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "TAS Record")),               QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Main Window")), {QStringLiteral("Ctrl+F7"), QStringLiteral(""), Qt::ApplicationShortcut, false}}, | ||||||
|     {QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "TAS Reset")),                QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Main Window")), {QStringLiteral("Ctrl+F6"), QStringLiteral(""), Qt::ApplicationShortcut, false}}, |     {QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "TAS Reset")),                QStringLiteral(QT_TRANSLATE_NOOP("Hotkeys", "Main Window")), {QStringLiteral("Ctrl+F6"), QStringLiteral(""), Qt::ApplicationShortcut, false}}, | ||||||
|  |  | ||||||
|  | @ -3400,10 +3400,13 @@ void GMainWindow::OnRestartGame() { | ||||||
|     if (!system->IsPoweredOn()) { |     if (!system->IsPoweredOn()) { | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     // Make a copy since ShutdownGame edits game_path
 | 
 | ||||||
|     const auto current_game = QString(current_game_path); |     if (ConfirmShutdownGame()) { | ||||||
|     ShutdownGame(); |         // Make a copy since ShutdownGame edits game_path
 | ||||||
|     BootGame(current_game); |         const auto current_game = QString(current_game_path); | ||||||
|  |         ShutdownGame(); | ||||||
|  |         BootGame(current_game); | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void GMainWindow::OnPauseGame() { | void GMainWindow::OnPauseGame() { | ||||||
|  | @ -3425,15 +3428,27 @@ void GMainWindow::OnPauseContinueGame() { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void GMainWindow::OnStopGame() { | void GMainWindow::OnStopGame() { | ||||||
|     // Open (or not) the right confirm dialog based on current setting and game exit lock
 |     if (ConfirmShutdownGame()) { | ||||||
|  |         play_time_manager->Stop(); | ||||||
|  |         // Update game list to show new play time
 | ||||||
|  |         game_list->PopulateAsync(UISettings::values.game_dirs); | ||||||
|  |         if (OnShutdownBegin()) { | ||||||
|  |             OnShutdownBeginDialog(); | ||||||
|  |         } else { | ||||||
|  |             OnEmulationStopped(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | bool GMainWindow::ConfirmShutdownGame() { | ||||||
|     if (UISettings::values.confirm_before_stopping.GetValue() == ConfirmStop::Ask_Always) { |     if (UISettings::values.confirm_before_stopping.GetValue() == ConfirmStop::Ask_Always) { | ||||||
|         if (system->GetExitLocked()) { |         if (system->GetExitLocked()) { | ||||||
|             if (!ConfirmForceLockedExit()) { |             if (!ConfirmForceLockedExit()) { | ||||||
|                 return; |                 return false; | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             if (!ConfirmChangeGame()) { |             if (!ConfirmChangeGame()) { | ||||||
|                 return; |                 return false; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } else { |     } else { | ||||||
|  | @ -3441,19 +3456,11 @@ void GMainWindow::OnStopGame() { | ||||||
|                 ConfirmStop::Ask_Based_On_Game && |                 ConfirmStop::Ask_Based_On_Game && | ||||||
|             system->GetExitLocked()) { |             system->GetExitLocked()) { | ||||||
|             if (!ConfirmForceLockedExit()) { |             if (!ConfirmForceLockedExit()) { | ||||||
|                 return; |                 return false; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 |     return true; | ||||||
|     play_time_manager->Stop(); |  | ||||||
|     // Update game list to show new play time
 |  | ||||||
|     game_list->PopulateAsync(UISettings::values.game_dirs); |  | ||||||
|     if (OnShutdownBegin()) { |  | ||||||
|         OnShutdownBeginDialog(); |  | ||||||
|     } else { |  | ||||||
|         OnEmulationStopped(); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void GMainWindow::OnLoadComplete() { | void GMainWindow::OnLoadComplete() { | ||||||
|  |  | ||||||
|  | @ -426,6 +426,10 @@ private: | ||||||
|     bool CheckSystemArchiveDecryption(); |     bool CheckSystemArchiveDecryption(); | ||||||
|     bool CheckFirmwarePresence(); |     bool CheckFirmwarePresence(); | ||||||
|     void ConfigureFilesystemProvider(const std::string& filepath); |     void ConfigureFilesystemProvider(const std::string& filepath); | ||||||
|  |     /**
 | ||||||
|  |     * Open (or not) the right confirm dialog based on current setting and game exit lock | ||||||
|  |     */ | ||||||
|  |     bool ConfirmShutdownGame(); | ||||||
| 
 | 
 | ||||||
|     QString GetTasStateDescription() const; |     QString GetTasStateDescription() const; | ||||||
|     bool CreateShortcut(const std::string& shortcut_path, const std::string& title, |     bool CreateShortcut(const std::string& shortcut_path, const std::string& title, | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 flodavid
						flodavid