Commit: 729bd7ddd98d7bad98bb8479f4e03ed1536b20c8
Author: Sergey Sharybin
Date: Mon Jun 17 15:10:28 2019 +0200
Branches: master
https://developer.blender.org/rB729bd7ddd98d7bad98bb8479f4e03ed1536b20c8
Fix T65693: Crash removing higher on special multires objects
===================================================================
M source/blender/blenkernel/intern/multires.c
===================================================================
diff --git a/source/blender/blenkernel/intern/multires.c
b/source/blender/blenkernel/intern/multires.c
index 7fefabd1c12..17d6b623b33 100644
--- a/source/blender/blenkernel/intern/multires.c
+++ b/source/blender/blenkernel/intern/multires.c
@@ -634,20 +634,20 @@ static void multires_del_higher(MultiresModifierData
*mmd, Object *ob, int lvl)
disps = MEM_calloc_arrayN(totdisp, 3 * sizeof(float), "multires
disps");
- ndisps = disps;
- hdisps = mdisp->disps;
-
- multires_copy_grid(ndisps, hdisps, nsize, hsize);
- if (mdisp->hidden) {
- BLI_bitmap *gh = multires_mdisps_downsample_hidden(mdisp->hidden,
mdisp->level, lvl);
- MEM_freeN(mdisp->hidden);
- mdisp->hidden = gh;
- }
+ if (mdisp->disps != NULL) {
+ ndisps = disps;
+ hdisps = mdisp->disps;
+
+ multires_copy_grid(ndisps, hdisps, nsize, hsize);
+ if (mdisp->hidden) {
+ BLI_bitmap *gh =
multires_mdisps_downsample_hidden(mdisp->hidden, mdisp->level, lvl);
+ MEM_freeN(mdisp->hidden);
+ mdisp->hidden = gh;
+ }
- ndisps += nsize * nsize;
- hdisps += hsize * hsize;
+ MEM_freeN(mdisp->disps);
+ }
- MEM_freeN(mdisp->disps);
mdisp->disps = disps;
mdisp->totdisp = totdisp;
mdisp->level = lvl;
_______________________________________________
Bf-blender-cvs mailing list
[email protected]
https://lists.blender.org/mailman/listinfo/bf-blender-cvs