diff --git a/Source/Core/Common/StringUtil.cpp b/Source/Core/Common/StringUtil.cpp index 1277a18f72..113d7b781a 100644 --- a/Source/Core/Common/StringUtil.cpp +++ b/Source/Core/Common/StringUtil.cpp @@ -704,4 +704,12 @@ void ToUpper(std::string* str) { std::transform(str->begin(), str->end(), str->begin(), [](char c) { return Common::ToUpper(c); }); } + +bool CaseInsensitiveEquals(std::string_view a, std::string_view b) +{ + if (a.size() != b.size()) + return false; + return std::equal(a.begin(), a.end(), b.begin(), + [](char ca, char cb) { return Common::ToLower(ca) == Common::ToLower(cb); }); +} } // namespace Common diff --git a/Source/Core/Common/StringUtil.h b/Source/Core/Common/StringUtil.h index 3ae97e5562..ed08e758dd 100644 --- a/Source/Core/Common/StringUtil.h +++ b/Source/Core/Common/StringUtil.h @@ -264,4 +264,5 @@ inline char ToUpper(char ch) } void ToLower(std::string* str); void ToUpper(std::string* str); +bool CaseInsensitiveEquals(std::string_view a, std::string_view b); } // namespace Common diff --git a/Source/Core/DiscIO/RiivolutionPatcher.cpp b/Source/Core/DiscIO/RiivolutionPatcher.cpp index 4b265599d8..f12664710d 100644 --- a/Source/Core/DiscIO/RiivolutionPatcher.cpp +++ b/Source/Core/DiscIO/RiivolutionPatcher.cpp @@ -320,14 +320,6 @@ static void ApplyPatchToFile(const Patch& patch, const File& file_patch, file_patch.m_fileoffset, file_patch.m_length, file_patch.m_resize); } -static bool CaseInsensitiveEquals(std::string_view a, std::string_view b) -{ - if (a.size() != b.size()) - return false; - return std::equal(a.begin(), a.end(), b.begin(), - [](char ca, char cb) { return Common::ToLower(ca) == Common::ToLower(cb); }); -} - static FSTBuilderNode* FindFileNodeInFST(std::string_view path, std::vector* fst, bool create_if_not_exists) { @@ -335,7 +327,7 @@ static FSTBuilderNode* FindFileNodeInFST(std::string_view path, std::vectorbegin(), fst->end(), [&](const FSTBuilderNode& node) { - return CaseInsensitiveEquals(node.m_filename, name); + return Common::CaseInsensitiveEquals(node.m_filename, name); }); if (it == fst->end()) @@ -377,7 +369,7 @@ static DiscIO::FSTBuilderNode* FindFilenameNodeInFST(std::string_view filename, if (result) return result; } - else if (CaseInsensitiveEquals(node.m_filename, filename)) + else if (Common::CaseInsensitiveEquals(node.m_filename, filename)) { return &node; } @@ -398,7 +390,7 @@ static void ApplyFilePatchToFST(const Patch& patch, const File& file, if (node) ApplyPatchToFile(patch, file, node); } - else if (dol_node && CaseInsensitiveEquals(file.m_disc, "main.dol")) + else if (dol_node && Common::CaseInsensitiveEquals(file.m_disc, "main.dol")) { // Special case: If the filename is "main.dol", we want to patch the main executable. ApplyPatchToFile(patch, file, dol_node);