forked from eden-emu/eden
		
	yuzu: game_list: Fix 'Open Save Data Location' for device saves.
This commit is contained in:
		
							parent
							
								
									ab9ddab0a2
								
							
						
					
					
						commit
						551c61bf27
					
				
					 4 changed files with 49 additions and 27 deletions
				
			
		|  | @ -488,11 +488,11 @@ void GameList::AddGamePopup(QMenu& context_menu, u64 program_id, std::string pat | |||
|     auto it = FindMatchingCompatibilityEntry(compatibility_list, program_id); | ||||
|     navigate_to_gamedb_entry->setVisible(it != compatibility_list.end() && program_id != 0); | ||||
| 
 | ||||
|     connect(open_save_location, &QAction::triggered, [this, program_id]() { | ||||
|         emit OpenFolderRequested(program_id, GameListOpenTarget::SaveData); | ||||
|     connect(open_save_location, &QAction::triggered, [this, program_id, path]() { | ||||
|         emit OpenFolderRequested(GameListOpenTarget::SaveData, path); | ||||
|     }); | ||||
|     connect(open_lfs_location, &QAction::triggered, [this, program_id]() { | ||||
|         emit OpenFolderRequested(program_id, GameListOpenTarget::ModData); | ||||
|     connect(open_lfs_location, &QAction::triggered, [this, program_id, path]() { | ||||
|         emit OpenFolderRequested(GameListOpenTarget::ModData, path); | ||||
|     }); | ||||
|     connect(open_transferable_shader_cache, &QAction::triggered, | ||||
|             [this, program_id]() { emit OpenTransferableShaderCacheRequested(program_id); }); | ||||
|  |  | |||
|  | @ -73,7 +73,7 @@ public: | |||
| signals: | ||||
|     void GameChosen(QString game_path); | ||||
|     void ShouldCancelWorker(); | ||||
|     void OpenFolderRequested(u64 program_id, GameListOpenTarget target); | ||||
|     void OpenFolderRequested(GameListOpenTarget target, const std::string& game_path); | ||||
|     void OpenTransferableShaderCacheRequested(u64 program_id); | ||||
|     void DumpRomFSRequested(u64 program_id, const std::string& game_path); | ||||
|     void CopyTIDRequested(u64 program_id); | ||||
|  |  | |||
|  | @ -1154,40 +1154,62 @@ void GMainWindow::OnGameListLoadFile(QString game_path) { | |||
|     BootGame(game_path); | ||||
| } | ||||
| 
 | ||||
| void GMainWindow::OnGameListOpenFolder(u64 program_id, GameListOpenTarget target) { | ||||
| void GMainWindow::OnGameListOpenFolder(GameListOpenTarget target, const std::string& game_path) { | ||||
|     std::string path; | ||||
|     QString open_target; | ||||
| 
 | ||||
|     const auto v_file = Core::GetGameFileFromPath(vfs, game_path); | ||||
|     const auto loader = Loader::GetLoader(v_file); | ||||
|     FileSys::NACP control{}; | ||||
|     u64 program_id{}; | ||||
| 
 | ||||
|     loader->ReadControlData(control); | ||||
|     loader->ReadProgramId(program_id); | ||||
| 
 | ||||
|     const bool has_user_save{control.GetDefaultNormalSaveSize() > 0}; | ||||
|     const bool has_device_save{control.GetDeviceSaveDataSize() > 0}; | ||||
| 
 | ||||
|     ASSERT_MSG(has_user_save != has_device_save, "Game uses both user and device savedata?"); | ||||
| 
 | ||||
|     switch (target) { | ||||
|     case GameListOpenTarget::SaveData: { | ||||
|         open_target = tr("Save Data"); | ||||
|         const std::string nand_dir = FileUtil::GetUserPath(FileUtil::UserPath::NANDDir); | ||||
|         ASSERT(program_id != 0); | ||||
| 
 | ||||
|         const auto select_profile = [this] { | ||||
|             QtProfileSelectionDialog dialog(this); | ||||
|             dialog.setWindowFlags(Qt::Dialog | Qt::CustomizeWindowHint | Qt::WindowTitleHint | | ||||
|                                   Qt::WindowSystemMenuHint | Qt::WindowCloseButtonHint); | ||||
|             dialog.setWindowModality(Qt::WindowModal); | ||||
|         if (has_user_save) { | ||||
|             // User save data
 | ||||
|             const auto select_profile = [this] { | ||||
|                 QtProfileSelectionDialog dialog(this); | ||||
|                 dialog.setWindowFlags(Qt::Dialog | Qt::CustomizeWindowHint | Qt::WindowTitleHint | | ||||
|                                       Qt::WindowSystemMenuHint | Qt::WindowCloseButtonHint); | ||||
|                 dialog.setWindowModality(Qt::WindowModal); | ||||
| 
 | ||||
|             if (dialog.exec() == QDialog::Rejected) { | ||||
|                 return -1; | ||||
|                 if (dialog.exec() == QDialog::Rejected) { | ||||
|                     return -1; | ||||
|                 } | ||||
| 
 | ||||
|                 return dialog.GetIndex(); | ||||
|             }; | ||||
| 
 | ||||
|             const auto index = select_profile(); | ||||
|             if (index == -1) { | ||||
|                 return; | ||||
|             } | ||||
| 
 | ||||
|             return dialog.GetIndex(); | ||||
|         }; | ||||
| 
 | ||||
|         const auto index = select_profile(); | ||||
|         if (index == -1) { | ||||
|             return; | ||||
|             Service::Account::ProfileManager manager; | ||||
|             const auto user_id = manager.GetUser(static_cast<std::size_t>(index)); | ||||
|             ASSERT(user_id); | ||||
|             path = nand_dir + FileSys::SaveDataFactory::GetFullPath( | ||||
|                                   FileSys::SaveDataSpaceId::NandUser, | ||||
|                                   FileSys::SaveDataType::SaveData, program_id, user_id->uuid, 0); | ||||
|         } else { | ||||
|             // Device save data
 | ||||
|             path = nand_dir + FileSys::SaveDataFactory::GetFullPath( | ||||
|                                   FileSys::SaveDataSpaceId::NandUser, | ||||
|                                   FileSys::SaveDataType::SaveData, program_id, {}, 0); | ||||
|         } | ||||
| 
 | ||||
|         Service::Account::ProfileManager manager; | ||||
|         const auto user_id = manager.GetUser(static_cast<std::size_t>(index)); | ||||
|         ASSERT(user_id); | ||||
|         path = nand_dir + FileSys::SaveDataFactory::GetFullPath(FileSys::SaveDataSpaceId::NandUser, | ||||
|                                                                 FileSys::SaveDataType::SaveData, | ||||
|                                                                 program_id, user_id->uuid, 0); | ||||
| 
 | ||||
|         if (!FileUtil::Exists(path)) { | ||||
|             FileUtil::CreateFullPath(path); | ||||
|             FileUtil::CreateDir(path); | ||||
|  |  | |||
|  | @ -183,7 +183,7 @@ private slots: | |||
|     void OnMenuReportCompatibility(); | ||||
|     /// Called whenever a user selects a game in the game list widget.
 | ||||
|     void OnGameListLoadFile(QString game_path); | ||||
|     void OnGameListOpenFolder(u64 program_id, GameListOpenTarget target); | ||||
|     void OnGameListOpenFolder(GameListOpenTarget target, const std::string& game_path); | ||||
|     void OnTransferableShaderCacheOpenFile(u64 program_id); | ||||
|     void OnGameListDumpRomFS(u64 program_id, const std::string& game_path); | ||||
|     void OnGameListCopyTID(u64 program_id); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei