forked from eden-emu/eden
		
	drd: Parse title ID from program metadata
This commit is contained in:
		
							parent
							
								
									14a18fd7ae
								
							
						
					
					
						commit
						14bfdbe0e7
					
				
					 2 changed files with 29 additions and 4 deletions
				
			
		|  | @ -27,6 +27,14 @@ AppLoader_DeconstructedRomDirectory::AppLoader_DeconstructedRomDirectory(FileSys | ||||||
|     : AppLoader(std::move(file_)), override_update(override_update) { |     : AppLoader(std::move(file_)), override_update(override_update) { | ||||||
|     const auto dir = file->GetContainingDirectory(); |     const auto dir = file->GetContainingDirectory(); | ||||||
| 
 | 
 | ||||||
|  |     // Title ID
 | ||||||
|  |     const auto npdm = dir->GetFile("main.npdm"); | ||||||
|  |     if (npdm != nullptr) { | ||||||
|  |         const auto res = metadata.Load(npdm); | ||||||
|  |         if (res == ResultStatus::Success) | ||||||
|  |             title_id = metadata.GetTitleID(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     // Icon
 |     // Icon
 | ||||||
|     FileSys::VirtualFile icon_file = nullptr; |     FileSys::VirtualFile icon_file = nullptr; | ||||||
|     for (const auto& language : FileSys::LANGUAGE_NAMES) { |     for (const auto& language : FileSys::LANGUAGE_NAMES) { | ||||||
|  | @ -138,7 +146,6 @@ ResultStatus AppLoader_DeconstructedRomDirectory::Load( | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     auto& kernel = Core::System::GetInstance().Kernel(); |     auto& kernel = Core::System::GetInstance().Kernel(); | ||||||
|     title_id = metadata.GetTitleID(); |  | ||||||
|     process->program_id = metadata.GetTitleID(); |     process->program_id = metadata.GetTitleID(); | ||||||
|     process->svc_access_mask.set(); |     process->svc_access_mask.set(); | ||||||
|     process->resource_limit = |     process->resource_limit = | ||||||
|  |  | ||||||
|  | @ -7,6 +7,8 @@ | ||||||
| #include "common/file_util.h" | #include "common/file_util.h" | ||||||
| 
 | 
 | ||||||
| #include "core/core.h" | #include "core/core.h" | ||||||
|  | #include "core/file_sys/control_metadata.h" | ||||||
|  | #include "core/file_sys/patch_manager.h" | ||||||
| #include "core/loader/loader.h" | #include "core/loader/loader.h" | ||||||
| #include "core/settings.h" | #include "core/settings.h" | ||||||
| #include "core/telemetry_session.h" | #include "core/telemetry_session.h" | ||||||
|  | @ -88,12 +90,28 @@ TelemetrySession::TelemetrySession() { | ||||||
|                             std::chrono::system_clock::now().time_since_epoch()) |                             std::chrono::system_clock::now().time_since_epoch()) | ||||||
|                             .count()}; |                             .count()}; | ||||||
|     AddField(Telemetry::FieldType::Session, "Init_Time", init_time); |     AddField(Telemetry::FieldType::Session, "Init_Time", init_time); | ||||||
|     std::string program_name; | 
 | ||||||
|     const Loader::ResultStatus res{System::GetInstance().GetAppLoader().ReadTitle(program_name)}; |     u64 program_id{}; | ||||||
|  |     const Loader::ResultStatus res{System::GetInstance().GetAppLoader().ReadProgramId(program_id)}; | ||||||
|     if (res == Loader::ResultStatus::Success) { |     if (res == Loader::ResultStatus::Success) { | ||||||
|         AddField(Telemetry::FieldType::Session, "ProgramName", program_name); |         AddField(Telemetry::FieldType::Session, "ProgramId", program_id); | ||||||
|  | 
 | ||||||
|  |         std::string name; | ||||||
|  |         System::GetInstance().GetAppLoader().ReadTitle(name); | ||||||
|  | 
 | ||||||
|  |         if (name.empty()) { | ||||||
|  |             auto [nacp, icon_file] = FileSys::PatchManager(program_id).GetControlMetadata(); | ||||||
|  |             if (nacp != nullptr) | ||||||
|  |                 name = nacp->GetApplicationName(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         if (!name.empty()) | ||||||
|  |             AddField(Telemetry::FieldType::Session, "ProgramName", name); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     AddField(Telemetry::FieldType::Session, "ProgramFormat", | ||||||
|  |              static_cast<u8>(System::GetInstance().GetAppLoader().GetFileType())); | ||||||
|  | 
 | ||||||
|     // Log application information
 |     // Log application information
 | ||||||
|     Telemetry::AppendBuildInfo(field_collection); |     Telemetry::AppendBuildInfo(field_collection); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Zach Hilman
						Zach Hilman