1
0
mirror of https://github.com/vlang/v.git synced 2023-08-10 21:13:21 +03:00
v/vlib/dl/dl_windows.c.v

40 lines
1.2 KiB
V
Raw Normal View History

2020-04-28 12:53:55 +03:00
module dl
pub const (
2020-12-15 19:55:04 +03:00
rtld_now = 0
2020-05-22 18:36:09 +03:00
rtld_lazy = 0
2020-04-28 12:53:55 +03:00
)
fn C.LoadLibrary(libfilename &u16) voidptr
2020-04-28 12:53:55 +03:00
fn C.GetProcAddress(handle voidptr, procname byteptr) voidptr
2020-04-29 22:01:19 +03:00
fn C.FreeLibrary(handle voidptr) bool
// open loads a given module into the address space of the calling process.
2020-04-28 12:53:55 +03:00
pub fn open(filename string, flags int) voidptr {
2020-04-29 22:01:19 +03:00
res := C.LoadLibrary(filename.to_wide())
2020-04-28 12:53:55 +03:00
return res
}
2020-04-29 22:01:19 +03:00
// close frees the loaded a given module.
pub fn close(handle voidptr) bool {
return C.FreeLibrary(handle)
}
// sym returns an address of an exported function or variable from a given module.
2020-04-28 12:53:55 +03:00
pub fn sym(handle voidptr, symbol string) voidptr {
return C.GetProcAddress(handle, symbol.str)
}
// dlerror provides a text error diagnostic message for functions in `dl`
// it returns a human-readable string, describing the most recent error
// that occurred from a call to one of the `dl` functions, since the last
// call to dlerror()
pub fn dlerror() string {
// https://docs.microsoft.com/en-us/windows/win32/api/errhandlingapi/nf-errhandlingapi-getlasterror
// Unlike dlerror(), GetLastError returns just an error code, that is function specific.
cerr := int(C.GetLastError())
return 'error code $cerr'
}