Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCampbell Barton <ideasman42@gmail.com>2019-12-09 22:12:08 +0300
committerCampbell Barton <ideasman42@gmail.com>2019-12-09 22:56:35 +0300
commit8bf7ca9fe31c438c68e6765666ce890a192ad765 (patch)
tree18b724adb2dae3942750939e43f491d63571352f /source/blender/editors/armature/armature_relations.c
parent62ef59aa0cca736b09192b67cc924180d9c2f9f9 (diff)
Fix T72310: Separate bones creates empty armatures
Armatures that didn't contain any selected bones were still creating armatures.
Diffstat (limited to 'source/blender/editors/armature/armature_relations.c')
-rw-r--r--source/blender/editors/armature/armature_relations.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/source/blender/editors/armature/armature_relations.c b/source/blender/editors/armature/armature_relations.c
index b60c8ce4592..e98deeb970e 100644
--- a/source/blender/editors/armature/armature_relations.c
+++ b/source/blender/editors/armature/armature_relations.c
@@ -631,6 +631,31 @@ static int separate_armature_exec(bContext *C, wmOperator *op)
Base *base_iter = bases[base_index];
Object *obedit = base_iter->object;
+ {
+ bArmature *arm_old = obedit->data;
+ bool has_selected_bone = false;
+ bool has_selected_any = false;
+ for (EditBone *ebone = arm_old->edbo->first; ebone; ebone = ebone->next) {
+ if (EBONE_VISIBLE(arm_old, ebone)) {
+ if (ebone->flag & BONE_SELECTED) {
+ has_selected_bone = true;
+ break;
+ }
+ else if (ebone->flag & (BONE_TIPSEL | BONE_ROOTSEL)) {
+ has_selected_any = true;
+ }
+ }
+ if (has_selected_bone == false) {
+ if (has_selected_any) {
+ /* Without this, we may leave head/tail selected
+ * which isn't expected after separating. */
+ ED_armature_edit_deselect_all(obedit);
+ }
+ continue;
+ }
+ }
+ }
+
Object *oldob, *newob;
Base *oldbase, *newbase;