diff options
| author | Rémi Verschelde <rverschelde@gmail.com> | 2023-10-22 12:12:17 +0200 |
|---|---|---|
| committer | Rémi Verschelde <rverschelde@gmail.com> | 2023-10-22 12:12:17 +0200 |
| commit | 542f6e10ebb1f992614b10f3888c40b2c47334f1 (patch) | |
| tree | d31ab6b63ad5abf993505ab20d2aae7a765f3056 | |
| parent | 14913f178ba2e85f37f83f787672c7abf1468a06 (diff) | |
| parent | f2bcd7d61f31d0a1204c3724660dc501e4b2b67f (diff) | |
| download | redot-engine-542f6e10ebb1f992614b10f3888c40b2c47334f1.tar.gz | |
Merge pull request #83734 from MarioLiebisch/fix-extension-load-error
GDExtension: Fixed error on loading extensions
| -rw-r--r-- | core/extension/gdextension.cpp | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/core/extension/gdextension.cpp b/core/extension/gdextension.cpp index 26512d0c56..136a5bfbb2 100644 --- a/core/extension/gdextension.cpp +++ b/core/extension/gdextension.cpp @@ -959,13 +959,15 @@ Ref<Resource> GDExtensionResourceLoader::load(const String &p_path, const String // object if one has already been loaded (even if caching is disabled at the resource // loader level). GDExtensionManager *manager = GDExtensionManager::get_singleton(); - Ref<GDExtension> lib = manager->get_extension(p_path); - if (lib.is_null()) { - Error err = load_gdextension_resource(p_path, lib); - if (err != OK && r_error) { - // Errors already logged in load_gdextension_resource(). - *r_error = err; - } + if (manager->is_extension_loaded(p_path)) { + return manager->get_extension(p_path); + } + + Ref<GDExtension> lib; + Error err = load_gdextension_resource(p_path, lib); + if (err != OK && r_error) { + // Errors already logged in load_gdextension_resource(). + *r_error = err; } return lib; } |
