fix for own error in normal-recalc r58077, initial face flipping wasn't checking...
[blender.git] / source / blender / bmesh / operators / bmo_normals.c
index c4200a377480eb9afbb55b2fb2c97479083d4e65..4291fc22793e840d8c2820151fa9f741a20db294 100644 (file)
@@ -56,7 +56,7 @@ static bool bmo_recalc_normal_edge_filter_cb(BMEdge *e, void *UNUSED(user_data))
  */
 static void bmo_recalc_face_normals_array(BMesh *bm, BMFace **faces, const int faces_len, const short oflag)
 {
-       float cent[3];
+       float cent[3], tvec[3];
        float (*faces_center)[3] = MEM_mallocN(sizeof(*faces_center) * faces_len, __func__);
        const float cent_fac = 1.0f / (float)faces_len;
        int i, f_start_index;
@@ -91,7 +91,8 @@ static void bmo_recalc_face_normals_array(BMesh *bm, BMFace **faces, const int f
        }
 
        /* make sure the starting face has the correct winding */
-       if (dot_v3v3(faces_center[f_start_index], faces[f_start_index]->no) < 0.0f) {
+       sub_v3_v3v3(tvec, faces_center[f_start_index], cent);
+       if (dot_v3v3(tvec, faces[f_start_index]->no) < 0.0f) {
                BMO_elem_flag_enable(bm, faces[f_start_index], FACE_FLIP);
        }