Merge pull request #13093 from karroffel/gdnative-static-linking-is-kill

[GDNative] removed static linking fields
This commit is contained in:
Thomas Herzog 2017-11-20 15:43:14 +01:00 committed by GitHub
commit 14ff5aa6ee
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 3 additions and 41 deletions

View File

@ -64,7 +64,6 @@ void GDNativeLibrary::_bind_methods() {
ClassDB::bind_method(D_METHOD("get_current_library_path"), &GDNativeLibrary::get_current_library_path); ClassDB::bind_method(D_METHOD("get_current_library_path"), &GDNativeLibrary::get_current_library_path);
ClassDB::bind_method(D_METHOD("get_current_dependencies"), &GDNativeLibrary::get_current_dependencies); ClassDB::bind_method(D_METHOD("get_current_dependencies"), &GDNativeLibrary::get_current_dependencies);
ClassDB::bind_method(D_METHOD("is_current_library_statically_linked"), &GDNativeLibrary::is_current_library_statically_linked);
ClassDB::bind_method(D_METHOD("should_load_once"), &GDNativeLibrary::should_load_once); ClassDB::bind_method(D_METHOD("should_load_once"), &GDNativeLibrary::should_load_once);
ClassDB::bind_method(D_METHOD("is_singleton"), &GDNativeLibrary::is_singleton); ClassDB::bind_method(D_METHOD("is_singleton"), &GDNativeLibrary::is_singleton);
@ -119,7 +118,7 @@ bool GDNative::initialize() {
} }
String lib_path = library->get_current_library_path(); String lib_path = library->get_current_library_path();
if (lib_path.empty() && !library->is_current_library_statically_linked()) { if (lib_path.empty()) {
ERR_PRINT("No library set for this platform"); ERR_PRINT("No library set for this platform");
return false; return false;
} }
@ -140,7 +139,7 @@ bool GDNative::initialize() {
} }
Error err = OS::get_singleton()->open_dynamic_library(path, native_handle); Error err = OS::get_singleton()->open_dynamic_library(path, native_handle);
if (err != OK && !library->is_current_library_statically_linked()) { if (err != OK) {
return false; return false;
} }
@ -154,7 +153,6 @@ bool GDNative::initialize() {
initialized = false; initialized = false;
if (err || !library_init) { if (err || !library_init) {
if (!library->is_current_library_statically_linked())
OS::get_singleton()->close_dynamic_library(native_handle); OS::get_singleton()->close_dynamic_library(native_handle);
native_handle = NULL; native_handle = NULL;
ERR_PRINT("Failed to obtain godot_gdnative_init symbol"); ERR_PRINT("Failed to obtain godot_gdnative_init symbol");
@ -374,40 +372,8 @@ RES GDNativeLibraryResourceLoader::load(const String &p_path, const String &p_or
} }
} }
bool is_statically_linked = false;
{
List<String> static_linking_keys;
config->get_section_keys("static_linking", &static_linking_keys);
for (List<String>::Element *E = static_linking_keys.front(); E; E = E->next()) {
String key = E->get();
Vector<String> tags = key.split(".");
bool skip = false;
for (int i = 0; i < tags.size(); i++) {
bool has_feature = OS::get_singleton()->has_feature(tags[i]);
if (!has_feature) {
skip = true;
break;
}
}
if (skip) {
continue;
}
is_statically_linked = config->get_value("static_linking", key);
break;
}
}
lib->current_library_path = entry_lib_path; lib->current_library_path = entry_lib_path;
lib->current_dependencies = dependency_paths; lib->current_dependencies = dependency_paths;
lib->current_library_statically_linked = is_statically_linked;
return lib; return lib;
} }

View File

@ -55,7 +55,6 @@ class GDNativeLibrary : public Resource {
String current_library_path; String current_library_path;
Vector<String> current_dependencies; Vector<String> current_dependencies;
bool current_library_statically_linked;
bool singleton; bool singleton;
bool load_once; bool load_once;
@ -75,9 +74,6 @@ public:
_FORCE_INLINE_ Vector<String> get_current_dependencies() const { _FORCE_INLINE_ Vector<String> get_current_dependencies() const {
return current_dependencies; return current_dependencies;
} }
_FORCE_INLINE_ bool is_current_library_statically_linked() const {
return current_library_statically_linked;
}
// things that are a property of the library itself, not platform specific // things that are a property of the library itself, not platform specific
_FORCE_INLINE_ bool should_load_once() const { _FORCE_INLINE_ bool should_load_once() const {