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>2018-05-22 18:24:32 +0300
committerCampbell Barton <ideasman42@gmail.com>2018-05-22 18:24:32 +0300
commit66d18d93c484e36f7ca0e70220adad19cbe2abc3 (patch)
tree9c091479483353faa3ec201e5a88fb0852c38d18 /source/blender/bmesh
parentf5d911f8b0deb28d04737451adf355da80c792c3 (diff)
parent76ece90d4a441a366614ef3dec6575f9b687384c (diff)
Merge branch 'master' into blender2.8
Diffstat (limited to 'source/blender/bmesh')
-rw-r--r--source/blender/bmesh/operators/bmo_triangulate.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/source/blender/bmesh/operators/bmo_triangulate.c b/source/blender/bmesh/operators/bmo_triangulate.c
index 2cdc2646649..163a9ef599c 100644
--- a/source/blender/bmesh/operators/bmo_triangulate.c
+++ b/source/blender/bmesh/operators/bmo_triangulate.c
@@ -252,7 +252,7 @@ void bmo_triangle_fill_exec(BMesh *bm, BMOperator *op)
BM_ITER_MESH_MUTABLE (e, e_next, &iter, bm, BM_EDGES_OF_MESH) {
if (BMO_edge_flag_test(bm, e, ELE_NEW)) {
/* in rare cases the edges face will have already been removed from the edge */
- if (LIKELY(e->l)) {
+ if (LIKELY(BM_edge_is_manifold(e))) {
BMFace *f_new = BM_faces_join_pair(bm, e->l, e->l->radial_next, false);
if (f_new) {
BMO_face_flag_enable(bm, f_new, ELE_NEW);
@@ -262,9 +262,13 @@ void bmo_triangle_fill_exec(BMesh *bm, BMOperator *op)
BMO_error_clear(bm);
}
}
- else {
+ else if (e->l == NULL) {
BM_edge_kill(bm, e);
}
+ else {
+ /* Edges with 1 or 3+ faces attached,
+ * most likely caused by a degeneratge mesh. */
+ }
}
}
}