[Bf-blender-cvs] [d33b564] master: Fix T44591: Set PBone Group operator did not handled predifined group index in its invoke func.
Bastien Montagne
noreply at git.blender.org
Sun May 3 16:54:44 CEST 2015
Commit: d33b564f9178d324349d3a21eef4d6bf9dde1f1b
Author: Bastien Montagne
Date: Sun May 3 16:51:16 2015 +0200
Branches: master
https://developer.blender.org/rBd33b564f9178d324349d3a21eef4d6bf9dde1f1b
Fix T44591: Set PBone Group operator did not handled predifined group index in its invoke func.
===================================================================
M source/blender/editors/armature/pose_group.c
===================================================================
diff --git a/source/blender/editors/armature/pose_group.c b/source/blender/editors/armature/pose_group.c
index 413a74d..4d9df06 100644
--- a/source/blender/editors/armature/pose_group.c
+++ b/source/blender/editors/armature/pose_group.c
@@ -130,6 +130,7 @@ static int pose_groups_menu_invoke(bContext *C, wmOperator *op, const wmEvent *U
{
Object *ob = ED_pose_object_from_context(C);
bPose *pose;
+ PropertyRNA *prop = RNA_struct_find_property(op->ptr, "type");
uiPopupMenu *pup;
uiLayout *layout;
@@ -140,6 +141,17 @@ static int pose_groups_menu_invoke(bContext *C, wmOperator *op, const wmEvent *U
if (ELEM(NULL, ob, ob->pose))
return OPERATOR_CANCELLED;
pose = ob->pose;
+
+ /* If group index is set, try to use it! */
+ if (RNA_property_is_set(op->ptr, prop)) {
+ const int num_groups = BLI_listbase_count(&pose->agroups);
+ const int group = RNA_property_int_get(op->ptr, prop);
+
+ /* just use the active group index, and call the exec callback for the calling operator */
+ if (group > 0 && group <= num_groups) {
+ return op->type->exec(C, op);
+ }
+ }
/* if there's no active group (or active is invalid), create a new menu to find it */
if (pose->active_group <= 0) {
More information about the Bf-blender-cvs
mailing list