summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2023-10-22 12:12:17 +0200
committerRémi Verschelde <rverschelde@gmail.com>2023-10-22 12:12:17 +0200
commit542f6e10ebb1f992614b10f3888c40b2c47334f1 (patch)
treed31ab6b63ad5abf993505ab20d2aae7a765f3056
parent14913f178ba2e85f37f83f787672c7abf1468a06 (diff)
parentf2bcd7d61f31d0a1204c3724660dc501e4b2b67f (diff)
downloadredot-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.cpp16
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;
}