android: jni: ensure NCAs from loaded filepath are registered in manual content provider
This commit is contained in:
		| @@ -30,6 +30,7 @@ | |||||||
| #include "core/cpu_manager.h" | #include "core/cpu_manager.h" | ||||||
| #include "core/crypto/key_manager.h" | #include "core/crypto/key_manager.h" | ||||||
| #include "core/file_sys/card_image.h" | #include "core/file_sys/card_image.h" | ||||||
|  | #include "core/file_sys/content_archive.h" | ||||||
| #include "core/file_sys/registered_cache.h" | #include "core/file_sys/registered_cache.h" | ||||||
| #include "core/file_sys/submission_package.h" | #include "core/file_sys/submission_package.h" | ||||||
| #include "core/file_sys/vfs.h" | #include "core/file_sys/vfs.h" | ||||||
| @@ -224,6 +225,42 @@ public: | |||||||
|         m_system.Renderer().NotifySurfaceChanged(); |         m_system.Renderer().NotifySurfaceChanged(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     void ConfigureFilesystemProvider(const std::string& filepath) { | ||||||
|  |         const auto file = m_system.GetFilesystem()->OpenFile(filepath, FileSys::Mode::Read); | ||||||
|  |         if (!file) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         auto loader = Loader::GetLoader(m_system, file); | ||||||
|  |         if (!loader) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         const auto file_type = loader->GetFileType(); | ||||||
|  |         if (file_type == Loader::FileType::Unknown || file_type == Loader::FileType::Error) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         u64 program_id = 0; | ||||||
|  |         const auto res2 = loader->ReadProgramId(program_id); | ||||||
|  |         if (res2 == Loader::ResultStatus::Success && file_type == Loader::FileType::NCA) { | ||||||
|  |             m_manual_provider->AddEntry(FileSys::TitleType::Application, | ||||||
|  |                                         FileSys::GetCRTypeFromNCAType(FileSys::NCA{file}.GetType()), | ||||||
|  |                                         program_id, file); | ||||||
|  |         } else if (res2 == Loader::ResultStatus::Success && | ||||||
|  |                    (file_type == Loader::FileType::XCI || file_type == Loader::FileType::NSP)) { | ||||||
|  |             const auto nsp = file_type == Loader::FileType::NSP | ||||||
|  |                                  ? std::make_shared<FileSys::NSP>(file) | ||||||
|  |                                  : FileSys::XCI{file}.GetSecurePartitionNSP(); | ||||||
|  |             for (const auto& title : nsp->GetNCAs()) { | ||||||
|  |                 for (const auto& entry : title.second) { | ||||||
|  |                     m_manual_provider->AddEntry(entry.first.first, entry.first.second, title.first, | ||||||
|  |                                                 entry.second->GetBaseFile()); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     Core::SystemResultStatus InitializeEmulation(const std::string& filepath) { |     Core::SystemResultStatus InitializeEmulation(const std::string& filepath) { | ||||||
|         std::scoped_lock lock(m_mutex); |         std::scoped_lock lock(m_mutex); | ||||||
|  |  | ||||||
| @@ -254,8 +291,14 @@ public: | |||||||
|             std::move(android_keyboard), // Software Keyboard |             std::move(android_keyboard), // Software Keyboard | ||||||
|             nullptr,                     // Web Browser |             nullptr,                     // Web Browser | ||||||
|         }); |         }); | ||||||
|  |  | ||||||
|  |         // Initialize filesystem. | ||||||
|  |         m_manual_provider = std::make_unique<FileSys::ManualContentProvider>(); | ||||||
|         m_system.SetContentProvider(std::make_unique<FileSys::ContentProviderUnion>()); |         m_system.SetContentProvider(std::make_unique<FileSys::ContentProviderUnion>()); | ||||||
|  |         m_system.RegisterContentProvider(FileSys::ContentProviderUnionSlot::FrontendManual, | ||||||
|  |                                          m_manual_provider.get()); | ||||||
|         m_system.GetFileSystemController().CreateFactories(*m_vfs); |         m_system.GetFileSystemController().CreateFactories(*m_vfs); | ||||||
|  |         ConfigureFilesystemProvider(filepath); | ||||||
|  |  | ||||||
|         // Initialize account manager |         // Initialize account manager | ||||||
|         m_profile_manager = std::make_unique<Service::Account::ProfileManager>(); |         m_profile_manager = std::make_unique<Service::Account::ProfileManager>(); | ||||||
| @@ -489,6 +532,7 @@ private: | |||||||
|     bool m_is_paused{}; |     bool m_is_paused{}; | ||||||
|     SoftwareKeyboard::AndroidKeyboard* m_software_keyboard{}; |     SoftwareKeyboard::AndroidKeyboard* m_software_keyboard{}; | ||||||
|     std::unique_ptr<Service::Account::ProfileManager> m_profile_manager; |     std::unique_ptr<Service::Account::ProfileManager> m_profile_manager; | ||||||
|  |     std::unique_ptr<FileSys::ManualContentProvider> m_manual_provider; | ||||||
|  |  | ||||||
|     // GPU driver parameters |     // GPU driver parameters | ||||||
|     std::shared_ptr<Common::DynamicLibrary> m_vulkan_library; |     std::shared_ptr<Common::DynamicLibrary> m_vulkan_library; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user