From b0784ba87168e24b0533fc8718a0157cda5ea405 Mon Sep 17 00:00:00 2001 From: est31 Date: Tue, 7 Jul 2015 05:55:07 +0200 Subject: Use UTF-8 instead of narrow Use wide_to_utf8 and utf8_to_wide instead of wide_to_narrow and narrow_to_wide at almost all places. Only exceptions: test functions for narrow conversion, and chat, which is done in a separate commit. --- src/util/string.cpp | 10 ++++++++++ 1 file changed, 10 insertions(+) (limited to 'src/util/string.cpp') diff --git a/src/util/string.cpp b/src/util/string.cpp index 187d2a078..60ccc9300 100644 --- a/src/util/string.cpp +++ b/src/util/string.cpp @@ -168,6 +168,16 @@ std::string wide_to_utf8(const std::wstring &input) #endif // _WIN32 +wchar_t *utf8_to_wide_c(const char *str) +{ + std::wstring ret = utf8_to_wide(std::string(str)).c_str(); + size_t len = ret.length(); + wchar_t *ret_c = new wchar_t[len + 1]; + memset(ret_c, 0, (len + 1) * sizeof(wchar_t)); + memcpy(ret_c, ret.c_str(), len * sizeof(wchar_t)); + return ret_c; +} + // You must free the returned string! // The returned string is allocated using new wchar_t *narrow_to_wide_c(const char *str) -- cgit v1.2.3