diff options
author | Campbell Barton <ideasman42@gmail.com> | 2019-10-10 03:08:17 +0300 |
---|---|---|
committer | Campbell Barton <ideasman42@gmail.com> | 2019-10-10 03:16:51 +0300 |
commit | 5910f9f9e914e0e2e99b63a1a329f04655ba866d (patch) | |
tree | f9fe1717801acaf896fcabfc2c20db4f94cec5b8 /release/scripts | |
parent | dc2cd2d0dcfdc2e10ccd1f06039390b6293e46ef (diff) |
Fix T70617: mesh.from_pydata() misses first edge if there are faces
Diffstat (limited to 'release/scripts')
-rw-r--r-- | release/scripts/modules/bpy_types.py | 19 |
1 files changed, 9 insertions, 10 deletions
diff --git a/release/scripts/modules/bpy_types.py b/release/scripts/modules/bpy_types.py index 76c495c078d..6cb9600b9b4 100644 --- a/release/scripts/modules/bpy_types.py +++ b/release/scripts/modules/bpy_types.py @@ -441,11 +441,6 @@ class Mesh(bpy_types.ID): When an empty iterable is passed in, the edges are inferred from the polygons. - When non-emtpy, either: - - - Edges must be provided for all polygons. - - Edges must be calculated afterwards using :class:`Mesh.update` with ``calc_edges=True``. - :type edges: iterable object :arg faces: @@ -481,11 +476,15 @@ class Mesh(bpy_types.ID): self.polygons.foreach_set("loop_start", loop_starts) self.polygons.foreach_set("vertices", vertex_indices) - # if no edges - calculate them - if faces and (not edges): - self.update(calc_edges=True) - elif edges: - self.update(calc_edges_loose=True) + if edges or faces: + self.update( + # Needed to either: + # - Calculate edges that don't exist for polygons. + # - Assign edges to polygon loops. + calc_edges=bool(faces), + # Flag loose edges. + calc_edges_loose=bool(edges), + ) @property def edge_keys(self): |