From 0cf4ba0d846831dc2cfc5bcbbe85bc4c048ec3d5 Mon Sep 17 00:00:00 2001 From: David Snopek Date: Fri, 29 Jul 2022 09:30:29 -0500 Subject: [PATCH] Fix locale resource remapping with binary conversion on export --- core/io/resource_loader.cpp | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/core/io/resource_loader.cpp b/core/io/resource_loader.cpp index 03505227204..9560eb4dec8 100644 --- a/core/io/resource_loader.cpp +++ b/core/io/resource_loader.cpp @@ -724,6 +724,8 @@ String ResourceLoader::_path_remap(const String &p_path, bool *r_translation_rem // We also fall back in case of regional locales as done in TranslationServer::translate // (e.g. 'ru_RU' -> 'ru' if the former has no specific mapping). + // An extra remap may still be necessary afterwards due to the text -> binary converter on export. + String locale = TranslationServer::get_singleton()->get_locale(); ERR_FAIL_COND_V_MSG(locale.length() < 2, p_path, "Could not remap path '" + p_path + "' for translation as configured locale '" + locale + "' is invalid."); String lang = TranslationServer::get_language_code(locale); @@ -763,12 +765,10 @@ String ResourceLoader::_path_remap(const String &p_path, bool *r_translation_rem if (path_remaps.has(new_path)) { new_path = path_remaps[new_path]; - } - - if (new_path == p_path) { // Did not remap. + } else { // Try file remap. Error err; - FileAccess *f = FileAccess::open(p_path + ".remap", FileAccess::READ, &err); + FileAccess *f = FileAccess::open(new_path + ".remap", FileAccess::READ, &err); if (f) { VariantParser::StreamFile stream;