You've already forked godot
mirror of
https://github.com/godotengine/godot.git
synced 2025-11-08 12:40:44 +00:00
GDScript: Fix GDScriptCache::get_full_script() uses non-remapped path
This commit is contained in:
@@ -297,6 +297,7 @@ Vector<uint8_t> GDScriptCache::get_binary_tokens(const String &p_path) {
|
|||||||
|
|
||||||
Ref<GDScript> GDScriptCache::get_shallow_script(const String &p_path, Error &r_error, const String &p_owner) {
|
Ref<GDScript> GDScriptCache::get_shallow_script(const String &p_path, Error &r_error, const String &p_owner) {
|
||||||
MutexLock lock(singleton->mutex);
|
MutexLock lock(singleton->mutex);
|
||||||
|
|
||||||
if (!p_owner.is_empty()) {
|
if (!p_owner.is_empty()) {
|
||||||
singleton->dependencies[p_owner].insert(p_path);
|
singleton->dependencies[p_owner].insert(p_path);
|
||||||
}
|
}
|
||||||
@@ -307,7 +308,7 @@ Ref<GDScript> GDScriptCache::get_shallow_script(const String &p_path, Error &r_e
|
|||||||
return singleton->shallow_gdscript_cache[p_path];
|
return singleton->shallow_gdscript_cache[p_path];
|
||||||
}
|
}
|
||||||
|
|
||||||
String remapped_path = ResourceLoader::path_remap(p_path);
|
const String remapped_path = ResourceLoader::path_remap(p_path);
|
||||||
|
|
||||||
Ref<GDScript> script;
|
Ref<GDScript> script;
|
||||||
script.instantiate();
|
script.instantiate();
|
||||||
@@ -332,6 +333,7 @@ Ref<GDScript> GDScriptCache::get_shallow_script(const String &p_path, Error &r_e
|
|||||||
}
|
}
|
||||||
|
|
||||||
singleton->shallow_gdscript_cache[p_path] = script;
|
singleton->shallow_gdscript_cache[p_path] = script;
|
||||||
|
|
||||||
return script;
|
return script;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -359,16 +361,18 @@ Ref<GDScript> GDScriptCache::get_full_script(const String &p_path, Error &r_erro
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const String remapped_path = ResourceLoader::path_remap(p_path);
|
||||||
|
|
||||||
if (p_update_from_disk) {
|
if (p_update_from_disk) {
|
||||||
if (p_path.get_extension().to_lower() == "gdc") {
|
if (remapped_path.get_extension().to_lower() == "gdc") {
|
||||||
Vector<uint8_t> buffer = get_binary_tokens(p_path);
|
Vector<uint8_t> buffer = get_binary_tokens(remapped_path);
|
||||||
if (buffer.is_empty()) {
|
if (buffer.is_empty()) {
|
||||||
r_error = ERR_FILE_CANT_READ;
|
r_error = ERR_FILE_CANT_READ;
|
||||||
return script;
|
return script;
|
||||||
}
|
}
|
||||||
script->set_binary_tokens_source(buffer);
|
script->set_binary_tokens_source(buffer);
|
||||||
} else {
|
} else {
|
||||||
r_error = script->load_source_code(p_path);
|
r_error = script->load_source_code(remapped_path);
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
return script;
|
return script;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user