diff options
author | PucklaMotzer09 <jonaas.pucher000000@gmail.com> | 2022-01-04 17:23:35 +0100 |
---|---|---|
committer | PucklaMotzer09 <jonaas.pucher000000@gmail.com> | 2022-08-02 12:40:11 +0200 |
commit | 0f9086e131923e09e97a2ef2f0e9f39565be0c27 (patch) | |
tree | 34260a81167720a535add8f3f5793c6a0b05ed63 /editor/localization_editor.cpp | |
parent | e6b049641572f9df332196aab219d7d6280740bd (diff) | |
download | redot-engine-0f9086e131923e09e97a2ef2f0e9f39565be0c27.tar.gz |
Update remaps in "file_removed" signal
Diffstat (limited to 'editor/localization_editor.cpp')
-rw-r--r-- | editor/localization_editor.cpp | 37 |
1 files changed, 35 insertions, 2 deletions
diff --git a/editor/localization_editor.cpp b/editor/localization_editor.cpp index bd486b1930..5d944956f6 100644 --- a/editor/localization_editor.cpp +++ b/editor/localization_editor.cpp @@ -382,6 +382,7 @@ void LocalizationEditor::_update_pot_file_extensions() { void LocalizationEditor::connect_filesystem_dock_signals(FileSystemDock *p_fs_dock) { p_fs_dock->connect("files_moved", callable_mp(this, &LocalizationEditor::_filesystem_files_moved)); + p_fs_dock->connect("file_removed", callable_mp(this, &LocalizationEditor::_filesystem_file_removed)); } void LocalizationEditor::_filesystem_files_moved(const String &p_old_file, const String &p_new_file) { @@ -409,8 +410,7 @@ void LocalizationEditor::_filesystem_files_moved(const String &p_old_file, const bool remapped_files_updated = false; for (int j = 0; j < remapped_files.size(); j++) { - // Find the first ':' after 'res://'. - int splitter_pos = remapped_files[j].find(":", remapped_files[j].find("/")); + int splitter_pos = remapped_files[j].rfind(":"); String res_path = remapped_files[j].substr(0, splitter_pos); if (res_path == p_old_file) { @@ -436,6 +436,39 @@ void LocalizationEditor::_filesystem_files_moved(const String &p_old_file, const } } +void LocalizationEditor::_filesystem_file_removed(const String &p_file) { + // Check if the remaps are affected. + Dictionary remaps; + + if (ProjectSettings::get_singleton()->has_setting("internationalization/locale/translation_remaps")) { + remaps = ProjectSettings::get_singleton()->get("internationalization/locale/translation_remaps"); + } + + bool remaps_changed = remaps.has(p_file); + + if (!remaps_changed) { + Array remap_keys = remaps.keys(); + for (int i = 0; i < remap_keys.size() && !remaps_changed; i++) { + PackedStringArray remapped_files = remaps[remap_keys[i]]; + for (int j = 0; j < remapped_files.size() && !remaps_changed; j++) { + int splitter_pos = remapped_files[j].rfind(":"); + String res_path = remapped_files[j].substr(0, splitter_pos); + remaps_changed = p_file == res_path; + if (remaps_changed) { + print_verbose(vformat("Remap value \"%s\" of key \"%s\" has been removed from the file system.", remapped_files[j], remap_keys[i])); + } + } + } + } else { + print_verbose(vformat("Remap key \"%s\" has been removed from the file system.", p_file)); + } + + if (remaps_changed) { + update_translations(); + emit_signal("localization_changed"); + } +} + void LocalizationEditor::update_translations() { if (updating_translations) { return; |