[Bf-blender-cvs] [07747bcd67b] blender2.8: Merge branch 'master' into blender2.8

Campbell Barton noreply at git.blender.org
Wed Sep 26 02:18:16 CEST 2018


Commit: 07747bcd67b6c8a829febeb34b64c47d0ad8a344
Author: Campbell Barton
Date:   Wed Sep 26 10:29:16 2018 +1000
Branches: blender2.8
https://developer.blender.org/rB07747bcd67b6c8a829febeb34b64c47d0ad8a344

Merge branch 'master' into blender2.8

===================================================================



===================================================================

diff --cc source/blender/editors/mesh/editmesh_extrude_spin.c
index 4f9aab165d0,88407576ec0..c1187da38d5
--- a/source/blender/editors/mesh/editmesh_extrude_spin.c
+++ b/source/blender/editors/mesh/editmesh_extrude_spin.c
@@@ -79,35 -79,26 +84,38 @@@ static int edbm_spin_exec(bContext *C, 
  		return OPERATOR_CANCELLED;
  	}
  
 -	/* keep the values in worldspace since we're passing the obmat */
 -	if (!EDBM_op_init(
 -	            em, &spinop, op,
 -	            "spin geom=%hvef cent=%v axis=%v dvec=%v steps=%i angle=%f space=%m4 "
 -	            "use_normal_flip=%b use_duplicate=%b use_merge=%b",
 -	            BM_ELEM_SELECT, cent, axis, d, steps, -angle, obedit->obmat,
 -	            use_normal_flip, dupli, use_auto_merge))
 -	{
 -		return OPERATOR_CANCELLED;
 -	}
 -	BMO_op_exec(bm, &spinop);
 -	if (use_auto_merge == false) {
 -		EDBM_flag_disable_all(em, BM_ELEM_SELECT);
 -		BMO_slot_buffer_hflag_enable(bm, spinop.slots_out, "geom_last.out", BM_ALL_NOLOOP, BM_ELEM_SELECT, true);
 -	}
 -	if (!EDBM_op_finish(em, &spinop, op, true)) {
 -		return OPERATOR_CANCELLED;
 +	uint objects_len = 0;
 +	Object **objects = BKE_view_layer_array_from_objects_in_edit_mode_unique_data(view_layer, &objects_len);
 +
 +	for (uint ob_index = 0; ob_index < objects_len; ob_index++) {
 +		Object *obedit = objects[ob_index];
 +		BMEditMesh *em = BKE_editmesh_from_object(obedit);
 +		BMesh *bm = em->bm;
 +		BMOperator spinop;
 +
 +		/* keep the values in worldspace since we're passing the obmat */
 +		if (!EDBM_op_init(
 +		            em, &spinop, op,
 +		            "spin geom=%hvef cent=%v axis=%v dvec=%v steps=%i angle=%f space=%m4 "
- 		            "use_normal_flip=%b use_duplicate=%b",
- 		            BM_ELEM_SELECT, cent, axis, d, steps, -angle, obedit->obmat, use_normal_flip, dupli))
++		            "use_normal_flip=%b use_duplicate=%b use_merge=%b",
++		            BM_ELEM_SELECT, cent, axis, d, steps, -angle, obedit->obmat,
++		            use_normal_flip, dupli, use_auto_merge))
 +		{
 +			continue;
 +		}
 +		BMO_op_exec(bm, &spinop);
- 		EDBM_flag_disable_all(em, BM_ELEM_SELECT);
- 		BMO_slot_buffer_hflag_enable(bm, spinop.slots_out, "geom_last.out", BM_ALL_NOLOOP, BM_ELEM_SELECT, true);
++		if (use_auto_merge == false) {
++			EDBM_flag_disable_all(em, BM_ELEM_SELECT);
++			BMO_slot_buffer_hflag_enable(bm, spinop.slots_out, "geom_last.out", BM_ALL_NOLOOP, BM_ELEM_SELECT, true);
++		}
 +		if (!EDBM_op_finish(em, &spinop, op, true)) {
 +			continue;
 +		}
 +
 +		EDBM_update_generic(em, true, true);
  	}
  
 -	EDBM_update_generic(em, true, true);
 +	MEM_freeN(objects);
  
  	return OPERATOR_FINISHED;
  }



More information about the Bf-blender-cvs mailing list