diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2024-01-02 18:06:17 +0100 |
---|---|---|
committer | Rémi Verschelde <rverschelde@gmail.com> | 2024-01-02 18:06:17 +0100 |
commit | 37df2ff38708187366539240bbcaebeef0ee2928 (patch) | |
tree | 3e15ce620d38c392999afa4143928b6fa9bff1fb /drivers/unix/os_unix.cpp | |
parent | b4b96ab4e377553a95500e1e682a113454acc485 (diff) | |
parent | fe6b07381189adb57dbc78150eab602044d541d0 (diff) | |
download | redot-engine-37df2ff38708187366539240bbcaebeef0ee2928.tar.gz |
Merge pull request #86682 from Daylily-Zeleen/daylily-zeleen/distinguish_between_dynamic_libaray_not_found_and_can't_open
Distinguish between dynamic library not found and can't be opened.
Diffstat (limited to 'drivers/unix/os_unix.cpp')
-rw-r--r-- | drivers/unix/os_unix.cpp | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/unix/os_unix.cpp b/drivers/unix/os_unix.cpp index 9a77930d75..50abd5af42 100644 --- a/drivers/unix/os_unix.cpp +++ b/drivers/unix/os_unix.cpp @@ -656,6 +656,8 @@ Error OS_Unix::open_dynamic_library(const String p_path, void *&p_library_handle path = get_executable_path().get_base_dir().path_join("../lib").path_join(p_path.get_file()); } + ERR_FAIL_COND_V(!FileAccess::exists(path), ERR_FILE_NOT_FOUND); + p_library_handle = dlopen(path.utf8().get_data(), GODOT_DLOPEN_MODE); ERR_FAIL_NULL_V_MSG(p_library_handle, ERR_CANT_OPEN, vformat("Can't open dynamic library: %s. Error: %s.", p_path, dlerror())); |