summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPedro J. Estébanez <pedrojrulez@gmail.com>2024-07-10 13:51:02 +0200
committerPedro J. Estébanez <pedrojrulez@gmail.com>2024-09-05 13:29:38 +0200
commit8a78f5c323d5d6e6471c2a0182732744e47ea637 (patch)
tree3a764f59f74924ffdaa722fe2b0765b6f8a069b1
parentea28ac510de3cef098a7624986072ff44546e87f (diff)
downloadredot-engine-8a78f5c323d5d6e6471c2a0182732744e47ea637.tar.gz
ResourceLoader: Optimize remap check by deferring until a non-mutex zone
(cherry picked from commit 5c970db2e49af93139d15d3fe090db44b4bd3317)
-rw-r--r--core/io/resource_loader.cpp9
-rw-r--r--core/io/resource_loader.h2
2 files changed, 5 insertions, 6 deletions
diff --git a/core/io/resource_loader.cpp b/core/io/resource_loader.cpp
index f21d1e92dd..9938b0ac5d 100644
--- a/core/io/resource_loader.cpp
+++ b/core/io/resource_loader.cpp
@@ -338,8 +338,10 @@ void ResourceLoader::_run_load_task(void *p_userdata) {
}
// --
+ bool xl_remapped = false;
+ const String &remapped_path = _path_remap(load_task.local_path, &xl_remapped);
Error load_err = OK;
- Ref<Resource> res = _load(load_task.remapped_path, load_task.remapped_path != load_task.local_path ? load_task.local_path : String(), load_task.type_hint, load_task.cache_mode, &load_err, load_task.use_sub_threads, &load_task.progress);
+ Ref<Resource> res = _load(remapped_path, remapped_path != load_task.local_path ? load_task.local_path : String(), load_task.type_hint, load_task.cache_mode, &load_err, load_task.use_sub_threads, &load_task.progress);
if (MessageQueue::get_singleton() != MessageQueue::get_main_singleton()) {
MessageQueue::get_singleton()->flush();
}
@@ -398,14 +400,14 @@ void ResourceLoader::_run_load_task(void *p_userdata) {
load_task.resource->set_path_cache(load_task.local_path);
}
- if (load_task.xl_remapped) {
+ if (xl_remapped) {
load_task.resource->set_as_translation_remapped(true);
}
#ifdef TOOLS_ENABLED
load_task.resource->set_edited(false);
if (timestamp_on_load) {
- uint64_t mt = FileAccess::get_modified_time(load_task.remapped_path);
+ uint64_t mt = FileAccess::get_modified_time(remapped_path);
//printf("mt %s: %lli\n",remapped_path.utf8().get_data(),mt);
load_task.resource->set_last_modified_time(mt);
}
@@ -527,7 +529,6 @@ Ref<ResourceLoader::LoadToken> ResourceLoader::_load_start(const String &p_path,
{
ThreadLoadTask load_task;
- load_task.remapped_path = _path_remap(local_path, &load_task.xl_remapped);
load_task.load_token = load_token.ptr();
load_task.local_path = local_path;
load_task.type_hint = p_type_hint;
diff --git a/core/io/resource_loader.h b/core/io/resource_loader.h
index 511bea1e16..f00a5cf117 100644
--- a/core/io/resource_loader.h
+++ b/core/io/resource_loader.h
@@ -173,7 +173,6 @@ private:
bool need_wait = true;
LoadToken *load_token = nullptr;
String local_path;
- String remapped_path;
String type_hint;
float progress = 0.0f;
float max_reported_progress = 0.0f;
@@ -182,7 +181,6 @@ private:
ResourceFormatLoader::CacheMode cache_mode = ResourceFormatLoader::CACHE_MODE_REUSE;
Error error = OK;
Ref<Resource> resource;
- bool xl_remapped = false;
bool use_sub_threads = false;
HashSet<String> sub_tasks;
};