diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2022-12-21 09:20:39 +0100 |
---|---|---|
committer | Rémi Verschelde <rverschelde@gmail.com> | 2022-12-21 09:20:39 +0100 |
commit | 0e125234a3373ed0145d3a624e244f2c2c6f63ac (patch) | |
tree | 5e0e93dab65bf62930b1c454903158b4efeba156 /platform | |
parent | 473656ef01e872a92844a50d01d6a7ede3dcc599 (diff) | |
parent | 3d8a942a56e1de32e23cd02eada3899c4d6d1033 (diff) |
Merge pull request #70389 from bruvzg/unicode_stdio
Fix reading Unicode from stdio.
Diffstat (limited to 'platform')
-rw-r--r-- | platform/windows/os_windows.cpp | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/platform/windows/os_windows.cpp b/platform/windows/os_windows.cpp index a083a98c72..f8633d29ac 100644 --- a/platform/windows/os_windows.cpp +++ b/platform/windows/os_windows.cpp @@ -1164,8 +1164,11 @@ bool OS_Windows::set_environment(const String &p_var, const String &p_value) con String OS_Windows::get_stdin_string(bool p_block) { if (p_block) { - char buff[1024]; - return fgets(buff, 1024, stdin); + WCHAR buff[1024]; + DWORD count = 0; + if (ReadConsoleW(GetStdHandle(STD_INPUT_HANDLE), buff, 1024, &count, nullptr)) { + return String::utf16((const char16_t *)buff, count); + } } return String(); |