diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2018-10-18 08:40:18 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-10-18 08:40:18 +0200 |
commit | ad47ec3952c34e2cfb64b8d65f1ed5614c73222f (patch) | |
tree | 6bfdbd5523145f1937d2b3ae9c2e264eaf49a78d /editor/filesystem_dock.cpp | |
parent | b550f93cfd7862fdf9bf4fc838f2ad04ef89a131 (diff) | |
parent | ee74c7808b99db69fd34fbff8d86ef232f349a1e (diff) |
Merge pull request #23000 from voithos/move-autoload
Update autoload references when moving files.
Diffstat (limited to 'editor/filesystem_dock.cpp')
-rw-r--r-- | editor/filesystem_dock.cpp | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/editor/filesystem_dock.cpp b/editor/filesystem_dock.cpp index 4d386c1af6..5d155c3014 100644 --- a/editor/filesystem_dock.cpp +++ b/editor/filesystem_dock.cpp @@ -1172,6 +1172,23 @@ void FileSystemDock::_update_project_settings_after_move(const Map<String, Strin } }; } + + // Also search for the file in autoload, as they are stored differently from normal files. + List<PropertyInfo> property_list; + ProjectSettings::get_singleton()->get_property_list(&property_list); + for (const List<PropertyInfo>::Element *E = property_list.front(); E; E = E->next()) { + if (E->get().name.begins_with("autoload/")) { + // If the autoload resource paths has a leading "*", it indicates that it is a Singleton, + // so we have to handle both cases when updating. + String autoload = GLOBAL_GET(E->get().name); + String autoload_singleton = autoload.substr(1, autoload.length()); + if (p_renames.has(autoload)) { + ProjectSettings::get_singleton()->set_setting(E->get().name, p_renames[autoload]); + } else if (autoload.begins_with("*") && p_renames.has(autoload_singleton)) { + ProjectSettings::get_singleton()->set_setting(E->get().name, "*" + p_renames[autoload_singleton]); + } + } + } ProjectSettings::get_singleton()->save(); } |