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:
authorSergey Sharybin <sergey.vfx@gmail.com>2019-01-24 16:23:14 +0300
committerSergey Sharybin <sergey.vfx@gmail.com>2019-01-24 16:25:06 +0300
commitf15a5440a1e10d0a3cc8f6bcb0693f9d3c98807c (patch)
treeefae4ffc17e0520d95c49d4682b078da78023913 /source/blender/blenkernel/intern/multires_reshape.c
parentac316a6526c71ff09468ceb288bf6db98c416fe2 (diff)
Multires reshape: correct grids level allocation
Similar to masking grids, need to also check existing grid level. This is because edit mode might leave allocated grid with 0 levels.
Diffstat (limited to 'source/blender/blenkernel/intern/multires_reshape.c')
-rw-r--r--source/blender/blenkernel/intern/multires_reshape.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/source/blender/blenkernel/intern/multires_reshape.c b/source/blender/blenkernel/intern/multires_reshape.c
index 0c4edf4de9d..0c1b85d8044 100644
--- a/source/blender/blenkernel/intern/multires_reshape.c
+++ b/source/blender/blenkernel/intern/multires_reshape.c
@@ -89,6 +89,9 @@ static void multires_reshape_allocate_displacement_grid(
const int grid_area = grid_size * grid_size;
float (*disps)[3] = MEM_calloc_arrayN(
grid_area, 3 * sizeof(float), "multires disps");
+ if (displacement_grid->disps != NULL) {
+ MEM_freeN(displacement_grid->disps);
+ }
displacement_grid->disps = disps;
displacement_grid->totdisp = grid_area;
displacement_grid->level = level;
@@ -97,7 +100,7 @@ static void multires_reshape_allocate_displacement_grid(
static void multires_reshape_ensure_displacement_grid(
MDisps *displacement_grid, const int level)
{
- if (displacement_grid->disps != NULL) {
+ if (displacement_grid->disps != NULL && displacement_grid->level == level) {
return;
}
multires_reshape_allocate_displacement_grid(