aboutsummaryrefslogtreecommitdiff
path: root/platform/windows/os_windows.cpp
diff options
context:
space:
mode:
authorKarroffel2017-03-08 02:50:13 +0100
committerKarroffel2017-03-29 23:05:15 +0200
commit2281942fb3ac5889abc6e95df27a80e71fe32c0e (patch)
tree770e8ac3c7b7b8b241a04eb7495405e6d0a0068d /platform/windows/os_windows.cpp
parent92b6c8095acc8348da7657dde357202840c26382 (diff)
downloadgodot-2281942fb3ac5889abc6e95df27a80e71fe32c0e.tar.gz
godot-2281942fb3ac5889abc6e95df27a80e71fe32c0e.tar.zst
godot-2281942fb3ac5889abc6e95df27a80e71fe32c0e.zip
Added methods for opening dynamic libraries to OS
Diffstat (limited to 'platform/windows/os_windows.cpp')
-rw-r--r--platform/windows/os_windows.cpp26
1 files changed, 26 insertions, 0 deletions
diff --git a/platform/windows/os_windows.cpp b/platform/windows/os_windows.cpp
index f1a9ba559..75dc2ef69 100644
--- a/platform/windows/os_windows.cpp
+++ b/platform/windows/os_windows.cpp
@@ -1582,6 +1582,32 @@ bool OS_Windows::get_borderless_window() {
return video_mode.borderless_window;
}
+Error open_dynamic_library(const String p_path, void* &p_library_handle) {
+ p_library_handle = (void *) LoadLibrary(p_path.utf8().get_data());
+ if (!p_library_handle) {
+ ERR_EXPLAIN("Can't open dynamic library: " + p_path + ". Error: " + String::num(GetLastError()));
+ ERR_FAIL_V(ERR_CANT_OPEN);
+ }
+ return OK;
+}
+
+Error close_dynamic_library(void* p_library_handle) {
+ if (!FreeLibrary((HMODULE) p_library_handle)) {
+ return FAILED;
+ }
+ return OK;
+}
+
+Error get_dynamic_library_symbol_handle(void* p_library_handle, const String p_name, void* &p_symbol_handle) {
+ char *error;
+ p_symbol_handle = (void *) GetProcAddress((HMODULE) p_library_handle, p_name.utf8().get_data());
+ if (!p_symbol_handle) {
+ ERR_EXPLAIN("Can't resolve symbol " + p_name + ". Error: " + String::num(GetLastError()));
+ ERR_FAIL_V(ERR_CANT_RESOLVE);
+ }
+ return OK;
+}
+
void OS_Windows::request_attention() {
FLASHWINFO info;