summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2023-01-30 10:02:20 +0100
committerRémi Verschelde <rverschelde@gmail.com>2023-01-30 10:02:20 +0100
commit2e792431c075d87d711a4ac96c40ea9f135f732c (patch)
treea8ed8acd89b6866faf8b910b7513e5786091c6f3
parent080c795054554c1f27350f28b3811eaf9f4af8fc (diff)
parentdf5092904380c10715068a9d1e25e5c2bbb75b9d (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.cpp19
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("/")) {