From 160b605640cd7b53cb2bda59d5b3e1d816730ec6 Mon Sep 17 00:00:00 2001 From: Bastian Buck <59334447+bstnbuck@users.noreply.github.com> Date: Sun, 25 Apr 2021 17:16:14 +0200 Subject: [PATCH] os: use C.GetUserNameW for os.loginname() instead + improvements os.uname() (#9872) --- vlib/builtin/cfns.c.v | 2 ++ vlib/os/os_windows.c.v | 15 ++++++++++----- 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/vlib/builtin/cfns.c.v b/vlib/builtin/cfns.c.v index 1115ed92e0..4ef0312cd9 100644 --- a/vlib/builtin/cfns.c.v +++ b/vlib/builtin/cfns.c.v @@ -217,6 +217,8 @@ fn C.ExpandEnvironmentStringsW(lpSrc &u16, lpDst &u16, nSize u32) u32 fn C.GetComputerNameW(&u16, &u32) bool +fn C.GetUserNameW(&u16, &u32) bool + [trusted] fn C.SendMessageTimeout() u32 diff --git a/vlib/os/os_windows.c.v b/vlib/os/os_windows.c.v index 160a9c55ed..9cfb26e8bc 100644 --- a/vlib/os/os_windows.c.v +++ b/vlib/os/os_windows.c.v @@ -2,6 +2,7 @@ module os import strings +#flag windows -l advapi32 #include pub const ( @@ -376,10 +377,9 @@ pub fn debugger_present() bool { } pub fn uname() Uname { - // TODO: use Win32 Api functions instead sys_and_ver := execute('cmd /c ver').output.split('[') - nodename := execute('cmd /c hostname').output - machine := execute('cmd /c echo %PROCESSOR_ARCHITECTURE%').output + nodename := hostname() + machine := getenv('PROCESSOR_ARCHITECTURE') return Uname{ sysname: sys_and_ver[0].trim_space() nodename: nodename @@ -400,8 +400,13 @@ pub fn hostname() string { } pub fn loginname() string { - // TODO: use C.GetUserName(&char, u32) bool instead - return execute('cmd /c echo %USERNAME%').output + loginname := [255]u16{} + size := u32(255) + res := C.GetUserNameW(&loginname[0], &size) + if !res { + return error(get_error_msg(int(C.GetLastError()))) + } + return unsafe { string_from_wide(&loginname[0]) } } // `is_writable_folder` - `folder` exists and is writable to the process