19 # include <util/pragma_push.def>
21 # pragma warning(disable : 4668)
23 # pragma warning(disable : 5039)
26 # include <util/pragma_pop.def>
36 int slength =
static_cast<int>(wcslen(s));
38 WideCharToMultiByte(CP_UTF8, 0, s, slength, NULL, 0, NULL, NULL);
39 std::string
r(rlength, 0);
40 WideCharToMultiByte(CP_UTF8, 0, s, slength, &
r[0], rlength, NULL, NULL);
44 return narrow(std::wstring(s));
48 std::wstring
widen(
const char *s)
52 int slength =
static_cast<int>(strlen(s));
53 int rlength = MultiByteToWideChar(CP_UTF8, 0, s, slength, NULL, 0);
54 std::wstring
r(rlength, 0);
55 MultiByteToWideChar(CP_UTF8, 0, s, slength, &
r[0], rlength);
59 return widen(std::string(s));
63 std::string
narrow(
const std::wstring &s)
67 int slength =
static_cast<int>(s.size());
69 WideCharToMultiByte(CP_UTF8, 0, &s[0], slength, NULL, 0, NULL, NULL);
70 std::string
r(rlength, 0);
71 WideCharToMultiByte(CP_UTF8, 0, &s[0], slength, &
r[0], rlength, NULL, NULL);
77 result.reserve(s.size());
79 for(
const auto codepoint : s)
86 std::wstring
widen(
const std::string &s)
90 int slength =
static_cast<int>(s.size());
91 int rlength = MultiByteToWideChar(CP_UTF8, 0, &s[0], slength, NULL, 0);
92 std::wstring
r(rlength, 0);
93 MultiByteToWideChar(CP_UTF8, 0, &s[0], slength, &
r[0], rlength);
100 r.reserve(utf32.size());
101 for(
auto codepoint : utf32)
112 result +=
static_cast<char>(c);
115 result +=
static_cast<char>((c >> 6) | 0xc0);
116 result +=
static_cast<char>((c & 0x3f) | 0x80);
120 result +=
static_cast<char>((c >> 12) | 0xe0);
121 result +=
static_cast<char>(((c >> 6) & 0x3f) | 0x80);
122 result +=
static_cast<char>((c & 0x3f) | 0x80);
126 result +=
static_cast<char>((c >> 18) | 0xf0);
127 result +=
static_cast<char>(((c >> 12) & 0x3f) | 0x80);
128 result +=
static_cast<char>(((c >> 6) & 0x3f) | 0x80);
129 result +=
static_cast<char>((c & 0x3f) | 0x80);
140 result.reserve(s.size());
142 for(
const auto c : s)
148 std::vector<std::string>
narrow_argv(
int argc,
const wchar_t **argv_wide)
150 if(argv_wide ==
nullptr)
151 return std::vector<std::string>();
153 std::vector<std::string> argv_narrow;
154 argv_narrow.reserve(argc);
156 for(
int i = 0; i != argc; ++i)
157 argv_narrow.push_back(
narrow(argv_wide[i]));
170 result +=
static_cast<wchar_t>(code);
179 code = code - 0x10000;
180 const uint16_t i1 =
static_cast<uint16_t
>(((code >> 10) & 0x3ff) | 0xD800);
181 result +=
static_cast<wchar_t>(i1);
182 const uint16_t i2 =
static_cast<uint16_t
>((code & 0x3ff) | 0xDC00);
183 result +=
static_cast<wchar_t>(i2);
194 result.reserve(in.size());
207 std::u32string result;
208 result.reserve(utf8_str.size());
210 while(i < utf8_str.size())
212 unsigned char c = utf8_str[i++];
222 else if(c <= 0xDF && i < utf8_str.size())
227 code = (c & 0x1Fu) << 6;
231 else if(c <= 0xEF && i + 1 < utf8_str.size())
233 code = (c & 0xFu) << 12;
235 code += (c & 0x3Fu) << 6;
239 else if(c <= 0xF7 && i + 2 < utf8_str.size())
241 code = (c & 0x7u) << 18;
243 code += (c & 0x3Fu) << 12;
245 code += (c & 0x3Fu) << 6;
258 result.append(1, code);
274 std::ostringstream &result,
275 const std::locale &loc)
292 else if(ch <= 255 && isprint(ch, loc))
294 const auto uch =
static_cast<unsigned char>(ch);
297 if(uch ==
'"' || uch ==
'\\')
305 result <<
"\\u" << std::hex << std::setw(4) << std::setfill(
'0')
306 <<
static_cast<unsigned int>(ch);
318 std::ostringstream &result,
319 const std::locale &loc)
321 if(ch == (
wchar_t)
'\'')
323 const auto uch =
static_cast<unsigned char>(ch);
325 result <<
'\\' << uch;
337 std::ostringstream result;
338 const std::locale loc;
352 std::ostringstream result;
353 const std::locale loc;
354 for(
const auto ch : in)
369 std::wstring wide_string(utf16_str.begin(), utf16_str.end());
370 return std::wstring_convert<std::codecvt_utf8_utf16<wchar_t>,
wchar_t>{}
371 .to_bytes(wide_string);
373 return std::wstring_convert<std::codecvt_utf8_utf16<char16_t>, char16_t>{}
374 .to_bytes(utf16_str);
381 return std::strtol(hex.c_str(),
nullptr, 16);