mirror of
				https://github.com/RetroDECK/Duckstation.git
				synced 2025-04-10 19:15:14 +00:00 
			
		
		
		
	System: Don't wipe out nonpersistent memory cards during game change
This commit is contained in:
		
							parent
							
								
									3f2c034869
								
							
						
					
					
						commit
						6a2b2ac7f8
					
				|  | @ -848,7 +848,7 @@ void HostInterface::CheckForSettingsChanges(const Settings& old_settings) | |||
|          System::HasMediaSubImages()) || | ||||
|         g_settings.memory_card_directory != old_settings.memory_card_directory) | ||||
|     { | ||||
|       System::UpdateMemoryCards(); | ||||
|       System::UpdateMemoryCardTypes(); | ||||
|     } | ||||
| 
 | ||||
|     if (g_settings.rewind_enable != old_settings.rewind_enable || | ||||
|  |  | |||
|  | @ -263,6 +263,11 @@ struct Settings | |||
| 
 | ||||
|   float GetDisplayAspectRatioValue() const; | ||||
| 
 | ||||
|   ALWAYS_INLINE static bool IsPerGameMemoryCardType(MemoryCardType type) | ||||
|   { | ||||
|     return (type == MemoryCardType::PerGame || type == MemoryCardType::PerGameTitle || | ||||
|             type == MemoryCardType::PerGameFileTitle); | ||||
|   } | ||||
|   bool HasAnyPerGameMemoryCards() const; | ||||
| 
 | ||||
|   static void CPUOverclockPercentToFraction(u32 percent, u32* numerator, u32* denominator); | ||||
|  |  | |||
|  | @ -783,7 +783,7 @@ bool Boot(const SystemBootParameters& params) | |||
| 
 | ||||
|   Bus::SetBIOS(*bios_image); | ||||
|   UpdateControllers(); | ||||
|   UpdateMemoryCards(); | ||||
|   UpdateMemoryCardTypes(); | ||||
|   UpdateMultitaps(); | ||||
|   Reset(); | ||||
| 
 | ||||
|  | @ -1230,7 +1230,7 @@ bool DoLoadState(ByteStream* state, bool force_software_renderer, bool update_di | |||
|       g_cdrom.InsertMedia(std::move(media)); | ||||
| 
 | ||||
|     UpdateControllers(); | ||||
|     UpdateMemoryCards(); | ||||
|     UpdateMemoryCardTypes(); | ||||
|     UpdateMultitaps(); | ||||
|   } | ||||
|   else | ||||
|  | @ -1243,7 +1243,7 @@ bool DoLoadState(ByteStream* state, bool force_software_renderer, bool update_di | |||
| 
 | ||||
|     // ensure the correct card is loaded
 | ||||
|     if (g_settings.HasAnyPerGameMemoryCards()) | ||||
|       UpdateMemoryCards(); | ||||
|       UpdatePerGameMemoryCards(); | ||||
|   } | ||||
| 
 | ||||
|   if (header.data_compression_type != 0) | ||||
|  | @ -1784,42 +1784,31 @@ void ResetControllers() | |||
|   } | ||||
| } | ||||
| 
 | ||||
| void UpdateMemoryCards() | ||||
| static std::unique_ptr<MemoryCard> GetMemoryCardForSlot(u32 slot, MemoryCardType type) | ||||
| { | ||||
|   // Disable memory cards when running PSFs.
 | ||||
|   const bool is_running_psf = !s_running_game_path.empty() && IsPsfFileName(s_running_game_path.c_str()); | ||||
| 
 | ||||
|   for (u32 i = 0; i < NUM_CONTROLLER_AND_CARD_PORTS; i++) | ||||
|   { | ||||
|     g_pad.SetMemoryCard(i, nullptr); | ||||
|   if (is_running_psf) | ||||
|       continue; | ||||
|     return nullptr; | ||||
| 
 | ||||
|     std::unique_ptr<MemoryCard> card; | ||||
|     const MemoryCardType type = g_settings.memory_card_types[i]; | ||||
|   switch (type) | ||||
|   { | ||||
|       case MemoryCardType::None: | ||||
|         continue; | ||||
| 
 | ||||
|     case MemoryCardType::PerGame: | ||||
|     { | ||||
|       if (s_running_game_code.empty()) | ||||
|       { | ||||
|         g_host_interface->AddFormattedOSDMessage( | ||||
|           5.0f, | ||||
|             g_host_interface->TranslateString("System", | ||||
|                                               "Per-game memory card cannot be used for slot %u as the running " | ||||
|           g_host_interface->TranslateString("System", "Per-game memory card cannot be used for slot %u as the running " | ||||
|                                                       "game has no code. Using shared card instead."), | ||||
|             i + 1u); | ||||
|           card = MemoryCard::Open(g_host_interface->GetSharedMemoryCardPath(i)); | ||||
|           slot + 1u); | ||||
|         return MemoryCard::Open(g_host_interface->GetSharedMemoryCardPath(slot)); | ||||
|       } | ||||
|       else | ||||
|       { | ||||
|           card = MemoryCard::Open(g_host_interface->GetGameMemoryCardPath(s_running_game_code.c_str(), i)); | ||||
|         return MemoryCard::Open(g_host_interface->GetGameMemoryCardPath(s_running_game_code.c_str(), slot)); | ||||
|       } | ||||
|     } | ||||
|       break; | ||||
| 
 | ||||
|     case MemoryCardType::PerGameTitle: | ||||
|     { | ||||
|  | @ -1827,19 +1816,17 @@ void UpdateMemoryCards() | |||
|       { | ||||
|         g_host_interface->AddFormattedOSDMessage( | ||||
|           5.0f, | ||||
|             g_host_interface->TranslateString("System", | ||||
|                                               "Per-game memory card cannot be used for slot %u as the running " | ||||
|           g_host_interface->TranslateString("System", "Per-game memory card cannot be used for slot %u as the running " | ||||
|                                                       "game has no title. Using shared card instead."), | ||||
|             i + 1u); | ||||
|           card = MemoryCard::Open(g_host_interface->GetSharedMemoryCardPath(i)); | ||||
|           slot + 1u); | ||||
|         return MemoryCard::Open(g_host_interface->GetSharedMemoryCardPath(slot)); | ||||
|       } | ||||
|       else | ||||
|       { | ||||
|           card = MemoryCard::Open(g_host_interface->GetGameMemoryCardPath( | ||||
|             MemoryCard::SanitizeGameTitleForFileName(s_running_game_title).c_str(), i)); | ||||
|         return MemoryCard::Open(g_host_interface->GetGameMemoryCardPath( | ||||
|           MemoryCard::SanitizeGameTitleForFileName(s_running_game_title).c_str(), slot)); | ||||
|       } | ||||
|     } | ||||
|       break; | ||||
| 
 | ||||
|     case MemoryCardType::PerGameFileTitle: | ||||
|     { | ||||
|  | @ -1849,36 +1836,62 @@ void UpdateMemoryCards() | |||
|       { | ||||
|         g_host_interface->AddFormattedOSDMessage( | ||||
|           5.0f, | ||||
|             g_host_interface->TranslateString("System", | ||||
|                                               "Per-game memory card cannot be used for slot %u as the running " | ||||
|           g_host_interface->TranslateString("System", "Per-game memory card cannot be used for slot %u as the running " | ||||
|                                                       "game has no path. Using shared card instead."), | ||||
|             i + 1u); | ||||
|           card = MemoryCard::Open(g_host_interface->GetSharedMemoryCardPath(i)); | ||||
|           slot + 1u); | ||||
|         return MemoryCard::Open(g_host_interface->GetSharedMemoryCardPath(slot)); | ||||
|       } | ||||
|       else | ||||
|       { | ||||
|           card = MemoryCard::Open( | ||||
|             g_host_interface->GetGameMemoryCardPath(MemoryCard::SanitizeGameTitleForFileName(file_title).c_str(), i)); | ||||
|         return MemoryCard::Open( | ||||
|           g_host_interface->GetGameMemoryCardPath(MemoryCard::SanitizeGameTitleForFileName(file_title).c_str(), slot)); | ||||
|       } | ||||
|     } | ||||
|       break; | ||||
| 
 | ||||
|     case MemoryCardType::Shared: | ||||
|     { | ||||
|         if (g_settings.memory_card_paths[i].empty()) | ||||
|           card = MemoryCard::Open(g_host_interface->GetSharedMemoryCardPath(i)); | ||||
|       if (g_settings.memory_card_paths[slot].empty()) | ||||
|         return MemoryCard::Open(g_host_interface->GetSharedMemoryCardPath(slot)); | ||||
|       else | ||||
|           card = MemoryCard::Open(g_settings.memory_card_paths[i]); | ||||
|         return MemoryCard::Open(g_settings.memory_card_paths[slot]); | ||||
|     } | ||||
|       break; | ||||
| 
 | ||||
|     case MemoryCardType::NonPersistent: | ||||
|       { | ||||
|         card = MemoryCard::Create(); | ||||
|       return MemoryCard::Create(); | ||||
| 
 | ||||
|     case MemoryCardType::None: | ||||
|     default: | ||||
|       return nullptr; | ||||
|   } | ||||
|       break; | ||||
| } | ||||
| 
 | ||||
| void UpdateMemoryCardTypes() | ||||
| { | ||||
|   for (u32 i = 0; i < NUM_CONTROLLER_AND_CARD_PORTS; i++) | ||||
|   { | ||||
|     g_pad.SetMemoryCard(i, nullptr); | ||||
| 
 | ||||
|     const MemoryCardType type = g_settings.memory_card_types[i]; | ||||
|     std::unique_ptr<MemoryCard> card = GetMemoryCardForSlot(i, type); | ||||
|     if (card) | ||||
|       g_pad.SetMemoryCard(i, std::move(card)); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| void UpdatePerGameMemoryCards() | ||||
| { | ||||
|   // Disable memory cards when running PSFs.
 | ||||
|   const bool is_running_psf = !s_running_game_path.empty() && IsPsfFileName(s_running_game_path.c_str()); | ||||
| 
 | ||||
|   for (u32 i = 0; i < NUM_CONTROLLER_AND_CARD_PORTS; i++) | ||||
|   { | ||||
|     const MemoryCardType type = g_settings.memory_card_types[i]; | ||||
|     if (!Settings::IsPerGameMemoryCardType(type)) | ||||
|       continue; | ||||
| 
 | ||||
|     g_pad.SetMemoryCard(i, nullptr); | ||||
| 
 | ||||
|     std::unique_ptr<MemoryCard> card = GetMemoryCardForSlot(i, type); | ||||
|     if (card) | ||||
|       g_pad.SetMemoryCard(i, std::move(card)); | ||||
|   } | ||||
|  | @ -1996,7 +2009,7 @@ bool InsertMedia(const char* path) | |||
|   { | ||||
|     g_host_interface->AddOSDMessage( | ||||
|       g_host_interface->TranslateStdString("System", "Game changed, reloading memory cards."), 10.0f); | ||||
|     UpdateMemoryCards(); | ||||
|     UpdatePerGameMemoryCards(); | ||||
|   } | ||||
| 
 | ||||
|   ClearMemorySaveStates(); | ||||
|  |  | |||
|  | @ -180,7 +180,8 @@ Controller* GetController(u32 slot); | |||
| void UpdateControllers(); | ||||
| void UpdateControllerSettings(); | ||||
| void ResetControllers(); | ||||
| void UpdateMemoryCards(); | ||||
| void UpdateMemoryCardTypes(); | ||||
| void UpdatePerGameMemoryCards(); | ||||
| bool HasMemoryCard(u32 slot); | ||||
| void SwapMemoryCards(); | ||||
| void UpdateMultitaps(); | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Connor McLaughlin
						Connor McLaughlin