forked from eden-emu/eden
		
	Merge pull request #2581 from lioncash/hex
common/hex_util: Combine HexVectorToString() and HexArrayToString()
This commit is contained in:
		
						commit
						aca05af798
					
				
					 11 changed files with 45 additions and 39 deletions
				
			
		|  | @ -294,7 +294,7 @@ void IPSwitchCompiler::Parse() { | |||
|                     LOG_INFO(Loader, | ||||
|                              "[IPSwitchCompiler ('{}')]     - Patching value at offset 0x{:08X} " | ||||
|                              "with byte string '{}'", | ||||
|                              patch_text->GetName(), offset, Common::HexVectorToString(replace)); | ||||
|                              patch_text->GetName(), offset, Common::HexToString(replace)); | ||||
|                 } | ||||
| 
 | ||||
|                 patch.records.insert_or_assign(offset, std::move(replace)); | ||||
|  |  | |||
|  | @ -142,7 +142,7 @@ std::vector<VirtualFile> PatchManager::CollectPatches(const std::vector<VirtualD | |||
|                     if (!compiler.IsValid()) | ||||
|                         continue; | ||||
| 
 | ||||
|                     auto this_build_id = Common::HexArrayToString(compiler.GetBuildID()); | ||||
|                     auto this_build_id = Common::HexToString(compiler.GetBuildID()); | ||||
|                     this_build_id = | ||||
|                         this_build_id.substr(0, this_build_id.find_last_not_of('0') + 1); | ||||
| 
 | ||||
|  | @ -168,7 +168,7 @@ std::vector<u8> PatchManager::PatchNSO(const std::vector<u8>& nso, const std::st | |||
|         return nso; | ||||
|     } | ||||
| 
 | ||||
|     const auto build_id_raw = Common::HexArrayToString(header.build_id); | ||||
|     const auto build_id_raw = Common::HexToString(header.build_id); | ||||
|     const auto build_id = build_id_raw.substr(0, build_id_raw.find_last_not_of('0') + 1); | ||||
| 
 | ||||
|     if (Settings::values.dump_nso) { | ||||
|  | @ -219,7 +219,7 @@ std::vector<u8> PatchManager::PatchNSO(const std::vector<u8>& nso, const std::st | |||
| } | ||||
| 
 | ||||
| bool PatchManager::HasNSOPatch(const std::array<u8, 32>& build_id_) const { | ||||
|     const auto build_id_raw = Common::HexArrayToString(build_id_); | ||||
|     const auto build_id_raw = Common::HexToString(build_id_); | ||||
|     const auto build_id = build_id_raw.substr(0, build_id_raw.find_last_not_of('0') + 1); | ||||
| 
 | ||||
|     LOG_INFO(Loader, "Querying NSO patch existence for build_id={}", build_id); | ||||
|  | @ -235,7 +235,7 @@ bool PatchManager::HasNSOPatch(const std::array<u8, 32>& build_id_) const { | |||
| static std::optional<CheatList> ReadCheatFileFromFolder(const Core::System& system, u64 title_id, | ||||
|                                                         const std::array<u8, 0x20>& build_id_, | ||||
|                                                         const VirtualDir& base_path, bool upper) { | ||||
|     const auto build_id_raw = Common::HexArrayToString(build_id_, upper); | ||||
|     const auto build_id_raw = Common::HexToString(build_id_, upper); | ||||
|     const auto build_id = build_id_raw.substr(0, sizeof(u64) * 2); | ||||
|     const auto file = base_path->GetFile(fmt::format("{}.txt", build_id)); | ||||
| 
 | ||||
|  |  | |||
|  | @ -53,13 +53,14 @@ static bool FollowsNcaIdFormat(std::string_view name) { | |||
| 
 | ||||
| static std::string GetRelativePathFromNcaID(const std::array<u8, 16>& nca_id, bool second_hex_upper, | ||||
|                                             bool within_two_digit) { | ||||
|     if (!within_two_digit) | ||||
|         return fmt::format("/{}.nca", Common::HexArrayToString(nca_id, second_hex_upper)); | ||||
|     if (!within_two_digit) { | ||||
|         return fmt::format("/{}.nca", Common::HexToString(nca_id, second_hex_upper)); | ||||
|     } | ||||
| 
 | ||||
|     Core::Crypto::SHA256Hash hash{}; | ||||
|     mbedtls_sha256(nca_id.data(), nca_id.size(), hash.data(), 0); | ||||
|     return fmt::format("/000000{:02X}/{}.nca", hash[0], | ||||
|                        Common::HexArrayToString(nca_id, second_hex_upper)); | ||||
|                        Common::HexToString(nca_id, second_hex_upper)); | ||||
| } | ||||
| 
 | ||||
| static std::string GetCNMTName(TitleType type, u64 title_id) { | ||||
|  | @ -376,10 +377,11 @@ std::vector<ContentProviderEntry> RegisteredCache::ListEntriesFilter( | |||
| } | ||||
| 
 | ||||
| static std::shared_ptr<NCA> GetNCAFromNSPForID(const NSP& nsp, const NcaID& id) { | ||||
|     const auto file = nsp.GetFile(fmt::format("{}.nca", Common::HexArrayToString(id, false))); | ||||
|     if (file == nullptr) | ||||
|     auto file = nsp.GetFile(fmt::format("{}.nca", Common::HexToString(id, false))); | ||||
|     if (file == nullptr) { | ||||
|         return nullptr; | ||||
|     return std::make_shared<NCA>(file); | ||||
|     } | ||||
|     return std::make_shared<NCA>(std::move(file)); | ||||
| } | ||||
| 
 | ||||
| InstallResult RegisteredCache::InstallEntry(const XCI& xci, bool overwrite_if_exists, | ||||
|  |  | |||
|  | @ -235,16 +235,18 @@ void NSP::ReadNCAs(const std::vector<VirtualFile>& files) { | |||
|         const auto section0 = nca->GetSubdirectories()[0]; | ||||
| 
 | ||||
|         for (const auto& inner_file : section0->GetFiles()) { | ||||
|             if (inner_file->GetExtension() != "cnmt") | ||||
|             if (inner_file->GetExtension() != "cnmt") { | ||||
|                 continue; | ||||
|             } | ||||
| 
 | ||||
|             const CNMT cnmt(inner_file); | ||||
|             auto& ncas_title = ncas[cnmt.GetTitleID()]; | ||||
| 
 | ||||
|             ncas_title[{cnmt.GetType(), ContentRecordType::Meta}] = nca; | ||||
|             for (const auto& rec : cnmt.GetContentRecords()) { | ||||
|                 const auto id_string = Common::HexArrayToString(rec.nca_id, false); | ||||
|                 const auto next_file = pfs->GetFile(fmt::format("{}.nca", id_string)); | ||||
|                 const auto id_string = Common::HexToString(rec.nca_id, false); | ||||
|                 auto next_file = pfs->GetFile(fmt::format("{}.nca", id_string)); | ||||
| 
 | ||||
|                 if (next_file == nullptr) { | ||||
|                     LOG_WARNING(Service_FS, | ||||
|                                 "NCA with ID {}.nca is listed in content metadata, but cannot " | ||||
|  | @ -253,9 +255,10 @@ void NSP::ReadNCAs(const std::vector<VirtualFile>& files) { | |||
|                     continue; | ||||
|                 } | ||||
| 
 | ||||
|                 auto next_nca = std::make_shared<NCA>(next_file, nullptr, 0, keys); | ||||
|                 if (next_nca->GetType() == NCAContentType::Program) | ||||
|                 auto next_nca = std::make_shared<NCA>(std::move(next_file), nullptr, 0, keys); | ||||
|                 if (next_nca->GetType() == NCAContentType::Program) { | ||||
|                     program_status[cnmt.GetTitleID()] = next_nca->GetStatus(); | ||||
|                 } | ||||
|                 if (next_nca->GetStatus() == Loader::ResultStatus::Success || | ||||
|                     (next_nca->GetStatus() == Loader::ResultStatus::ErrorMissingBKTRBaseRomFS && | ||||
|                      (cnmt.GetTitleID() & 0x800) != 0)) { | ||||
|  |  | |||
|  | @ -66,7 +66,7 @@ NAX::NAX(VirtualFile file_, std::array<u8, 0x10> nca_id) | |||
|     Core::Crypto::SHA256Hash hash{}; | ||||
|     mbedtls_sha256(nca_id.data(), nca_id.size(), hash.data(), 0); | ||||
|     status = Parse(fmt::format("/registered/000000{:02X}/{}.nca", hash[0], | ||||
|                                Common::HexArrayToString(nca_id, false))); | ||||
|                                Common::HexToString(nca_id, false))); | ||||
| } | ||||
| 
 | ||||
| NAX::~NAX() = default; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Zach Hilman
						Zach Hilman