Cache feature list in OS.has_feature()

This commit is contained in:
kobewi 2023-05-05 15:23:25 +02:00
parent f6bf51ca49
commit 30d0dd43c5
2 changed files with 10 additions and 1 deletions

View file

@ -423,7 +423,14 @@ Error OS::set_thread_name(const String &p_name) {
};
bool OS::has_feature(const String &p_feature) const {
return ::OS::get_singleton()->has_feature(p_feature);
const bool *value_ptr = feature_cache.getptr(p_feature);
if (value_ptr) {
return *value_ptr;
} else {
const bool has = ::OS::get_singleton()->has_feature(p_feature);
feature_cache[p_feature] = has;
return has;
}
}
uint64_t OS::get_static_memory_usage() const {

View file

@ -119,6 +119,8 @@ public:
class OS : public Object {
GDCLASS(OS, Object);
mutable HashMap<String, bool> feature_cache;
protected:
static void _bind_methods();
static OS *singleton;