diff --git a/Source/Core/Common/StringUtil.cpp b/Source/Core/Common/StringUtil.cpp index de06d3c3aa..8ac8a4a229 100644 --- a/Source/Core/Common/StringUtil.cpp +++ b/Source/Core/Common/StringUtil.cpp @@ -29,6 +29,7 @@ constexpr u32 CODEPAGE_SHIFT_JIS = 932; constexpr u32 CODEPAGE_WINDOWS_1252 = 1252; #else +#include #include #include #include @@ -472,6 +473,14 @@ std::string CP1252ToUTF8(const std::string& input) return UTF16ToUTF8(CPToUTF16(CODEPAGE_WINDOWS_1252, input)); } +std::string UTF16BEToUTF8(const char16_t* str, size_t max_size) +{ + const char16_t* str_end = std::find(str, str + max_size, '\0'); + std::wstring result(static_cast(str_end - str), '\0'); + std::transform(str, str_end, result.begin(), static_cast(Common::swap16)); + return UTF16ToUTF8(result); +} + #else template @@ -556,15 +565,14 @@ std::string UTF8ToSHIFTJIS(const std::string& input) std::string UTF16ToUTF8(const std::wstring& input) { - return CodeToUTF8("UTF-16LE", input); + std::wstring_convert, wchar_t> converter; + return converter.to_bytes(input); } -#endif - std::string UTF16BEToUTF8(const char16_t* str, size_t max_size) { const char16_t* str_end = std::find(str, str + max_size, '\0'); - std::wstring result(static_cast(str_end - str), '\0'); - std::transform(str, str_end, result.begin(), static_cast(Common::swap16)); - return UTF16ToUTF8(result); + return CodeToUTF8("UTF-16BE", std::u16string(str, static_cast(str_end - str))); } + +#endif