From 4a3ac16711b41d90e0666f478e3085f764c83208 Mon Sep 17 00:00:00 2001 From: viri Date: Sun, 6 Jun 2021 20:23:07 -0600 Subject: [PATCH] std.Progress: use `*W` functions on windows Closes #534. See: https://source.winehq.org/git/wine.git/blob/refs/heads/stable:/dlls/kernelbase/console.c#l520 --- lib/std/Progress.zig | 2 +- lib/std/os/windows.zig | 12 ++++++------ lib/std/os/windows/kernel32.zig | 3 ++- 3 files changed, 9 insertions(+), 8 deletions(-) diff --git a/lib/std/Progress.zig b/lib/std/Progress.zig index c912b60f57..059f6e73a7 100644 --- a/lib/std/Progress.zig +++ b/lib/std/Progress.zig @@ -234,7 +234,7 @@ fn refreshWithHeldLock(self: *Progress) void { self.terminal = null; break :winapi; } - if (windows.kernel32.FillConsoleOutputCharacterA( + if (windows.kernel32.FillConsoleOutputCharacterW( file.handle, ' ', fill_chars, diff --git a/lib/std/os/windows.zig b/lib/std/os/windows.zig index 8e8351e446..b5da153e59 100644 --- a/lib/std/os/windows.zig +++ b/lib/std/os/windows.zig @@ -1922,19 +1922,19 @@ pub fn loadWinsockExtensionFunction(comptime T: type, sock: ws2_32.SOCKET, guid: pub fn unexpectedError(err: Win32Error) std.os.UnexpectedError { if (std.os.unexpected_error_tracing) { // 614 is the length of the longest windows error desciption - var buf_u16: [614]u16 = undefined; - var buf_u8: [614]u8 = undefined; + var buf_wstr: [614]WCHAR = undefined; + var buf_utf8: [614]u8 = undefined; const len = kernel32.FormatMessageW( FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, null, err, MAKELANGID(LANG.NEUTRAL, SUBLANG.DEFAULT), - &buf_u16, - buf_u16.len / @sizeOf(TCHAR), + &buf_wstr, + buf_wstr.len, null, ); - _ = std.unicode.utf16leToUtf8(&buf_u8, buf_u16[0..len]) catch unreachable; - std.debug.warn("error.Unexpected: GetLastError({}): {s}\n", .{ @enumToInt(err), buf_u8[0..len] }); + _ = std.unicode.utf16leToUtf8(&buf_utf8, buf_wstr[0..len]) catch unreachable; + std.debug.warn("error.Unexpected: GetLastError({}): {s}\n", .{ @enumToInt(err), buf_utf8[0..len] }); std.debug.dumpCurrentStackTrace(null); } return error.Unexpected; diff --git a/lib/std/os/windows/kernel32.zig b/lib/std/os/windows/kernel32.zig index f2e8b87d74..8f100a9511 100644 --- a/lib/std/os/windows/kernel32.zig +++ b/lib/std/os/windows/kernel32.zig @@ -89,7 +89,8 @@ pub extern "kernel32" fn GetCommandLineW() callconv(WINAPI) LPWSTR; pub extern "kernel32" fn GetConsoleMode(in_hConsoleHandle: HANDLE, out_lpMode: *DWORD) callconv(WINAPI) BOOL; pub extern "kernel32" fn GetConsoleScreenBufferInfo(hConsoleOutput: HANDLE, lpConsoleScreenBufferInfo: *CONSOLE_SCREEN_BUFFER_INFO) callconv(WINAPI) BOOL; -pub extern "kernel32" fn FillConsoleOutputCharacterA(hConsoleOutput: HANDLE, cCharacter: TCHAR, nLength: DWORD, dwWriteCoord: COORD, lpNumberOfCharsWritten: LPDWORD) callconv(WINAPI) BOOL; +pub extern "kernel32" fn FillConsoleOutputCharacterA(hConsoleOutput: HANDLE, cCharacter: CHAR, nLength: DWORD, dwWriteCoord: COORD, lpNumberOfCharsWritten: LPDWORD) callconv(WINAPI) BOOL; +pub extern "kernel32" fn FillConsoleOutputCharacterW(hConsoleOutput: HANDLE, cCharacter: WCHAR, nLength: DWORD, dwWriteCoord: COORD, lpNumberOfCharsWritten: LPDWORD) callconv(WINAPI) BOOL; pub extern "kernel32" fn FillConsoleOutputAttribute(hConsoleOutput: HANDLE, wAttribute: WORD, nLength: DWORD, dwWriteCoord: COORD, lpNumberOfAttrsWritten: LPDWORD) callconv(WINAPI) BOOL; pub extern "kernel32" fn SetConsoleCursorPosition(hConsoleOutput: HANDLE, dwCursorPosition: COORD) callconv(WINAPI) BOOL;