From 0c948a8df628ec6538f66d64676b69ce57efdd1f Mon Sep 17 00:00:00 2001 From: David Markowitz <39972741+EmosewaMC@users.noreply.github.com> Date: Tue, 24 Dec 2024 22:23:14 -0800 Subject: [PATCH] use simpler converter (#1695) --- dCommon/FdbToSqlite.cpp | 2 +- dCommon/GeneralUtils.cpp | 20 ++++++++++---------- dCommon/GeneralUtils.h | 2 +- 3 files changed, 12 insertions(+), 12 deletions(-) diff --git a/dCommon/FdbToSqlite.cpp b/dCommon/FdbToSqlite.cpp index 75e055bb..71f88313 100644 --- a/dCommon/FdbToSqlite.cpp +++ b/dCommon/FdbToSqlite.cpp @@ -72,7 +72,7 @@ std::string FdbToSqlite::Convert::ReadString(std::istream& cdClientBuffer) { const auto readString = BinaryIO::ReadU8String(cdClientBuffer); cdClientBuffer.seekg(prevPosition); - return GeneralUtils::Latin1ToWTF8(readString); + return GeneralUtils::Latin1ToUTF8(readString); } int32_t FdbToSqlite::Convert::SeekPointer(std::istream& cdClientBuffer) { diff --git a/dCommon/GeneralUtils.cpp b/dCommon/GeneralUtils.cpp index 819fa805..fcf6e2e7 100644 --- a/dCommon/GeneralUtils.cpp +++ b/dCommon/GeneralUtils.cpp @@ -167,11 +167,18 @@ std::u16string GeneralUtils::ASCIIToUTF16(const std::string_view string, const s return ret; } +std::string GeneralUtils::Latin1ToUTF8(const std::u8string_view string, const size_t size) { + std::string toReturn{}; -//! Converts a (potentially-ill-formed) Latin1 string to UTF-8 + for (const auto u : string) { + PushUTF8CodePoint(toReturn, u); + } + return toReturn; +} + +//! Converts a (potentially-ill-formed) UTF-16 string to UTF-8 //! See: -template -std::string ToWTF8(const StringType string, const size_t size) { +std::string GeneralUtils::UTF16ToWTF8(const std::u16string_view string, const size_t size) { const size_t newSize = MinSize(size, string); std::string ret; ret.reserve(newSize); @@ -196,13 +203,6 @@ std::string ToWTF8(const StringType string, const size_t size) { return ret; } -std::string GeneralUtils::Latin1ToWTF8(const std::u8string_view string, const size_t size) { - return ToWTF8(string, size); -} - -std::string GeneralUtils::UTF16ToWTF8(const std::u16string_view string, const size_t size) { - return ToWTF8(string, size); -} bool GeneralUtils::CaseInsensitiveStringCompare(const std::string_view a, const std::string_view b) { return std::equal(a.begin(), a.end(), b.begin(), b.end(), [](char a, char b) { return tolower(a) == tolower(b); }); diff --git a/dCommon/GeneralUtils.h b/dCommon/GeneralUtils.h index 469a16da..663ac7bc 100644 --- a/dCommon/GeneralUtils.h +++ b/dCommon/GeneralUtils.h @@ -57,7 +57,7 @@ namespace GeneralUtils { \param size A size to trim the string to. Default is SIZE_MAX (No trimming) \return An UTF-8 representation of the string */ - std::string Latin1ToWTF8(const std::u8string_view string, const size_t size = SIZE_MAX); + std::string Latin1ToUTF8(const std::u8string_view string, const size_t size = SIZE_MAX); //! Converts a UTF-16 string to a UTF-8 string /*!