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>2017-09-01 20:27:55 +0300
committerBastien Montagne <montagne29@wanadoo.fr>2017-09-04 13:59:40 +0300
commit374ddd022c21dd4cb9739a6ec8e13999711ffd5b (patch)
tree8c64eb74289cf44826cef5414be4fb91140eac10
parent8a254b62710ac2efde76716ccf064287777b6905 (diff)
BMesh: use predictable order for remove-doubles
Each qsort implementation may give different results when values match. Now fallback to sorting by index.
-rw-r--r--source/blender/bmesh/operators/bmo_removedoubles.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/source/blender/bmesh/operators/bmo_removedoubles.c b/source/blender/bmesh/operators/bmo_removedoubles.c
index 7d19d90807a..f2f5debe73a 100644
--- a/source/blender/bmesh/operators/bmo_removedoubles.c
+++ b/source/blender/bmesh/operators/bmo_removedoubles.c
@@ -285,6 +285,13 @@ static int vergaverco(const void *e1, const void *e2)
if (x1 > x2) return 1;
else if (x1 < x2) return -1;
+
+ const int i1 = BM_elem_index_get(v1);
+ const int i2 = BM_elem_index_get(v2);
+
+ if (i1 > i2) return 1;
+ else if (i1 < i2) return -1;
+
else return 0;
}
@@ -602,6 +609,12 @@ static void bmesh_find_doubles_common(
/* get the verts as an array we can sort */
verts = BMO_slot_as_arrayN(op->slots_in, "verts", &verts_len);
+ /* Ensure indices are different so we have a predictable order when values match. */
+ for (i = 0; i < verts_len; i++) {
+ BM_elem_index_set(verts[i], i); /* set_dirty! */
+ }
+ bm->elem_index_dirty |= BM_VERT;
+
/* sort by vertex coordinates added together */
qsort(verts, verts_len, sizeof(BMVert *), vergaverco);