mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
builtin: make the C. WIN32 API declarations more precise, to catch errors earlier (#16090)
This commit is contained in:
parent
126c4c5751
commit
71bff213ef
@ -226,15 +226,15 @@ fn C._fileno(int) int
|
|||||||
|
|
||||||
fn C._get_osfhandle(fd int) C.intptr_t
|
fn C._get_osfhandle(fd int) C.intptr_t
|
||||||
|
|
||||||
fn C.GetModuleFileName(hModule voidptr, lpFilename &u16, nSize u32) int
|
fn C.GetModuleFileName(hModule voidptr, lpFilename &u16, nSize u32) u32
|
||||||
|
|
||||||
fn C.GetModuleFileNameW(hModule voidptr, lpFilename &u16, nSize u32) u32
|
fn C.GetModuleFileNameW(hModule voidptr, lpFilename &u16, nSize u32) u32
|
||||||
|
|
||||||
fn C.CreateFile(lpFilename &u16, dwDesiredAccess u32, dwShareMode u32, lpSecurityAttributes &u16, dwCreationDisposition u32, dwFlagsAndAttributes u32, hTemplateFile voidptr) voidptr
|
fn C.CreateFile(lpFilename &u16, dwDesiredAccess u32, dwShareMode u32, lpSecurityAttributes &u16, dwCreationDisposition u32, dwFlagsAndAttributes u32, hTemplateFile voidptr) voidptr
|
||||||
|
|
||||||
fn C.CreateFileW(lpFilename &u16, dwDesiredAccess u32, dwShareMode u32, lpSecurityAttributes &u16, dwCreationDisposition u32, dwFlagsAndAttributes u32, hTemplateFile voidptr) u32
|
fn C.CreateFileW(lpFilename &u16, dwDesiredAccess u32, dwShareMode u32, lpSecurityAttributes &u16, dwCreationDisposition u32, dwFlagsAndAttributes u32, hTemplateFile voidptr) voidptr
|
||||||
|
|
||||||
fn C.GetFinalPathNameByHandleW(hFile voidptr, lpFilePath &u16, nSize u32, dwFlags u32) int
|
fn C.GetFinalPathNameByHandleW(hFile voidptr, lpFilePath &u16, nSize u32, dwFlags u32) u32
|
||||||
|
|
||||||
fn C.CreatePipe(hReadPipe &voidptr, hWritePipe &voidptr, lpPipeAttributes voidptr, nSize u32) bool
|
fn C.CreatePipe(hReadPipe &voidptr, hWritePipe &voidptr, lpPipeAttributes voidptr, nSize u32) bool
|
||||||
|
|
||||||
@ -247,9 +247,9 @@ fn C.GetComputerNameW(&u16, &u32) bool
|
|||||||
fn C.GetUserNameW(&u16, &u32) bool
|
fn C.GetUserNameW(&u16, &u32) bool
|
||||||
|
|
||||||
[trusted]
|
[trusted]
|
||||||
fn C.SendMessageTimeout() u32
|
fn C.SendMessageTimeout() isize
|
||||||
|
|
||||||
fn C.SendMessageTimeoutW(hWnd voidptr, msg u32, wParam &u16, lParam &u32, fuFlags u32, uTimeout u32, lpdwResult &u64) u32
|
fn C.SendMessageTimeoutW(hWnd voidptr, msg u32, wParam &u16, lParam &u32, fuFlags u32, uTimeout u32, lpdwResult &u64) isize
|
||||||
|
|
||||||
fn C.CreateProcessW(lpApplicationName &u16, lpCommandLine &u16, lpProcessAttributes voidptr, lpThreadAttributes voidptr, bInheritHandles bool, dwCreationFlags u32, lpEnvironment voidptr, lpCurrentDirectory &u16, lpStartupInfo voidptr, lpProcessInformation voidptr) bool
|
fn C.CreateProcessW(lpApplicationName &u16, lpCommandLine &u16, lpProcessAttributes voidptr, lpThreadAttributes voidptr, bInheritHandles bool, dwCreationFlags u32, lpEnvironment voidptr, lpCurrentDirectory &u16, lpStartupInfo voidptr, lpProcessInformation voidptr) bool
|
||||||
|
|
||||||
@ -257,33 +257,32 @@ fn C.ReadFile(hFile voidptr, lpBuffer voidptr, nNumberOfBytesToRead u32, lpNumbe
|
|||||||
|
|
||||||
fn C.GetFileAttributesW(lpFileName &u8) u32
|
fn C.GetFileAttributesW(lpFileName &u8) u32
|
||||||
|
|
||||||
fn C.RegQueryValueEx(hKey voidptr, lpValueName &u16, lp_reserved &u32, lpType &u32, lpData &u8, lpcbData &u32) voidptr
|
fn C.RegQueryValueEx(hKey voidptr, lpValueName &u16, lp_reserved &u32, lpType &u32, lpData &u8, lpcbData &u32) int
|
||||||
|
|
||||||
fn C.RegQueryValueExW(hKey voidptr, lpValueName &u16, lp_reserved &u32, lpType &u32, lpData &u8, lpcbData &u32) int
|
fn C.RegQueryValueExW(hKey voidptr, lpValueName &u16, lp_reserved &u32, lpType &u32, lpData &u8, lpcbData &u32) int
|
||||||
|
|
||||||
fn C.RegOpenKeyEx(hKey voidptr, lpSubKey &u16, ulOptions u32, samDesired u32, phkResult voidptr) voidptr
|
fn C.RegOpenKeyEx(hKey voidptr, lpSubKey &u16, ulOptions u32, samDesired u32, phkResult voidptr) int
|
||||||
|
|
||||||
fn C.RegOpenKeyExW(hKey voidptr, lpSubKey &u16, ulOptions u32, samDesired u32, phkResult voidptr) int
|
fn C.RegOpenKeyExW(hKey voidptr, lpSubKey &u16, ulOptions u32, samDesired u32, phkResult voidptr) int
|
||||||
|
|
||||||
fn C.RegSetValueEx() voidptr
|
fn C.RegSetValueEx(hKey voidptr, lpValueName &u16, dwType u32, lpData &u16, cbData u32) int
|
||||||
|
|
||||||
fn C.RegSetValueExW(hKey voidptr, lpValueName &u16, reserved u32, dwType u32, lpData &u8, lpcbData u32) int
|
fn C.RegSetValueExW(hKey voidptr, lpValueName &u16, reserved u32, dwType u32, const_lpData &u8, cbData u32) int
|
||||||
|
|
||||||
fn C.RegCloseKey(hKey voidptr)
|
fn C.RegCloseKey(hKey voidptr) int
|
||||||
|
|
||||||
fn C.RemoveDirectory(lpPathName &u16) int
|
fn C.RemoveDirectory(lpPathName &u16) bool
|
||||||
|
|
||||||
|
fn C.RemoveDirectoryW(lpPathName &u16) bool
|
||||||
|
|
||||||
// fn C.GetStdHandle() voidptr
|
|
||||||
fn C.GetStdHandle(u32) voidptr
|
fn C.GetStdHandle(u32) voidptr
|
||||||
|
|
||||||
// fn C.SetConsoleMode()
|
fn C.SetConsoleMode(voidptr, u32) bool
|
||||||
fn C.SetConsoleMode(voidptr, u32) int
|
|
||||||
|
|
||||||
// fn C.GetConsoleMode() int
|
fn C.GetConsoleMode(voidptr, &u32) bool
|
||||||
fn C.GetConsoleMode(voidptr, &u32) int
|
|
||||||
|
|
||||||
[trusted]
|
[trusted]
|
||||||
fn C.GetCurrentProcessId() int
|
fn C.GetCurrentProcessId() u32
|
||||||
|
|
||||||
fn C.wprintf()
|
fn C.wprintf()
|
||||||
|
|
||||||
|
@ -496,8 +496,8 @@ pub fn rm(path string) ! {
|
|||||||
pub fn rmdir(path string) ! {
|
pub fn rmdir(path string) ! {
|
||||||
$if windows {
|
$if windows {
|
||||||
rc := C.RemoveDirectory(path.to_wide())
|
rc := C.RemoveDirectory(path.to_wide())
|
||||||
if rc == 0 {
|
if !rc {
|
||||||
// https://docs.microsoft.com/en-us/windows/win32/api/fileapi/nf-fileapi-removedirectorya - 0 is failure
|
// https://docs.microsoft.com/en-us/windows/win32/api/fileapi/nf-fileapi-removedirectorya - 0 == false, is failure
|
||||||
return error('Failed to remove "$path": ' + posix_get_error_msg(C.errno))
|
return error('Failed to remove "$path": ' + posix_get_error_msg(C.errno))
|
||||||
}
|
}
|
||||||
} $else {
|
} $else {
|
||||||
@ -651,8 +651,8 @@ pub fn executable() string {
|
|||||||
// https://docs.microsoft.com/en-us/windows/win32/api/fileapi/nf-fileapi-getfinalpathnamebyhandlew
|
// https://docs.microsoft.com/en-us/windows/win32/api/fileapi/nf-fileapi-getfinalpathnamebyhandlew
|
||||||
final_len := C.GetFinalPathNameByHandleW(file, unsafe { &u16(&final_path[0]) },
|
final_len := C.GetFinalPathNameByHandleW(file, unsafe { &u16(&final_path[0]) },
|
||||||
max_path_buffer_size, 0)
|
max_path_buffer_size, 0)
|
||||||
if final_len < max_path_buffer_size {
|
if final_len < u32(max_path_buffer_size) {
|
||||||
sret := unsafe { string_from_wide2(&u16(&final_path[0]), final_len) }
|
sret := unsafe { string_from_wide2(&u16(&final_path[0]), int(final_len)) }
|
||||||
defer {
|
defer {
|
||||||
unsafe { sret.free() }
|
unsafe { sret.free() }
|
||||||
}
|
}
|
||||||
@ -665,7 +665,7 @@ pub fn executable() string {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
res := unsafe { string_from_wide2(pu16_result, len) }
|
res := unsafe { string_from_wide2(pu16_result, int(len)) }
|
||||||
return res
|
return res
|
||||||
}
|
}
|
||||||
$if macos {
|
$if macos {
|
||||||
@ -852,8 +852,8 @@ pub fn real_path(fpath string) string {
|
|||||||
// https://docs.microsoft.com/en-us/windows/win32/api/fileapi/nf-fileapi-getfinalpathnamebyhandlew
|
// https://docs.microsoft.com/en-us/windows/win32/api/fileapi/nf-fileapi-getfinalpathnamebyhandlew
|
||||||
final_len := C.GetFinalPathNameByHandleW(file, pu16_fullpath, max_path_buffer_size,
|
final_len := C.GetFinalPathNameByHandleW(file, pu16_fullpath, max_path_buffer_size,
|
||||||
0)
|
0)
|
||||||
if final_len < max_path_buffer_size {
|
if final_len < u32(max_path_buffer_size) {
|
||||||
rt := unsafe { string_from_wide2(pu16_fullpath, final_len) }
|
rt := unsafe { string_from_wide2(pu16_fullpath, int(final_len)) }
|
||||||
srt := rt[4..]
|
srt := rt[4..]
|
||||||
unsafe { res.free() }
|
unsafe { res.free() }
|
||||||
res = srt.clone()
|
res = srt.clone()
|
||||||
|
@ -45,17 +45,17 @@ pub fn init(cfg Config) &Context {
|
|||||||
panic('could not get stdin handle')
|
panic('could not get stdin handle')
|
||||||
}
|
}
|
||||||
// save the current input mode, to be restored on exit
|
// save the current input mode, to be restored on exit
|
||||||
if C.GetConsoleMode(stdin_handle, &ui.stdin_at_startup) == 0 {
|
if !C.GetConsoleMode(stdin_handle, &ui.stdin_at_startup) {
|
||||||
panic('could not get stdin console mode')
|
panic('could not get stdin console mode')
|
||||||
}
|
}
|
||||||
|
|
||||||
// enable extended input flags (see https://stackoverflow.com/a/46802726)
|
// enable extended input flags (see https://stackoverflow.com/a/46802726)
|
||||||
// 0x80 == C.ENABLE_EXTENDED_FLAGS
|
// 0x80 == C.ENABLE_EXTENDED_FLAGS
|
||||||
if C.SetConsoleMode(stdin_handle, 0x80) == 0 {
|
if !C.SetConsoleMode(stdin_handle, 0x80) {
|
||||||
panic('could not set raw input mode')
|
panic('could not set raw input mode')
|
||||||
}
|
}
|
||||||
// enable window and mouse input events.
|
// enable window and mouse input events.
|
||||||
if C.SetConsoleMode(stdin_handle, C.ENABLE_WINDOW_INPUT | C.ENABLE_MOUSE_INPUT) == 0 {
|
if !C.SetConsoleMode(stdin_handle, C.ENABLE_WINDOW_INPUT | C.ENABLE_MOUSE_INPUT) {
|
||||||
panic('could not set raw input mode')
|
panic('could not set raw input mode')
|
||||||
}
|
}
|
||||||
// store the current title, so restore_terminal_state can get it back
|
// store the current title, so restore_terminal_state can get it back
|
||||||
|
Loading…
Reference in New Issue
Block a user