diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2023-01-30 10:02:20 +0100 |
---|---|---|
committer | Rémi Verschelde <rverschelde@gmail.com> | 2023-01-30 10:02:20 +0100 |
commit | 2e792431c075d87d711a4ac96c40ea9f135f732c (patch) | |
tree | a8ed8acd89b6866faf8b910b7513e5786091c6f3 | |
parent | 080c795054554c1f27350f28b3811eaf9f4af8fc (diff) | |
parent | df5092904380c10715068a9d1e25e5c2bbb75b9d (diff) |
Merge pull request #72336 from TokageItLab/dupe-animation-name
Tweak the name for duplicated animations in the editor
-rw-r--r-- | editor/plugins/animation_player_editor_plugin.cpp | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/editor/plugins/animation_player_editor_plugin.cpp b/editor/plugins/animation_player_editor_plugin.cpp index 30e06bfcf4..b33ad67f23 100644 --- a/editor/plugins/animation_player_editor_plugin.cpp +++ b/editor/plugins/animation_player_editor_plugin.cpp @@ -1105,9 +1105,24 @@ void AnimationPlayerEditor::_animation_duplicate() { return; } + int count = 2; String new_name = current; - while (player->has_animation(new_name)) { - new_name = new_name + " (copy)"; + PackedStringArray split = new_name.split("_"); + int last_index = split.size() - 1; + if (last_index > 0 && split[last_index].is_valid_int() && split[last_index].to_int() >= 0) { + count = split[last_index].to_int(); + split.remove_at(last_index); + new_name = String("_").join(split); + } + while (true) { + String attempt = new_name; + attempt += vformat("_%d", count); + if (player->has_animation(attempt)) { + count++; + continue; + } + new_name = attempt; + break; } if (new_name.contains("/")) { |