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:
authorJeroen Bakker <j.bakker@atmind.nl>2018-04-18 11:43:03 +0300
committerJeroen Bakker <j.bakker@atmind.nl>2018-04-18 11:43:03 +0300
commited72eedd0730f09c0a90b8888bc8f5a872396744 (patch)
treee234bbc02327d0faaa20337dc6f809ff7b41279b
parentd9051c46fd318399b7b321140c024ead3ca1a493 (diff)
Workbench: Fixed SegFault
In more complex models the object color uniform data is freed before rendered. We should copy it to local data. but for now we redirected it to a constant.
-rw-r--r--source/blender/draw/engines/workbench/solid_flat_mode.c5
-rw-r--r--source/blender/draw/engines/workbench/solid_studio_mode.c3
2 files changed, 5 insertions, 3 deletions
diff --git a/source/blender/draw/engines/workbench/solid_flat_mode.c b/source/blender/draw/engines/workbench/solid_flat_mode.c
index cb3ae755609..d601d434292 100644
--- a/source/blender/draw/engines/workbench/solid_flat_mode.c
+++ b/source/blender/draw/engines/workbench/solid_flat_mode.c
@@ -44,6 +44,7 @@ static struct {
struct GPUShader *solid_sh;
} e_data = {NULL};
+const float SOLID_FLAT_DEFAULT_COLOR[3] = {1.0, 1.0, 1.0};
/* Functions */
@@ -94,7 +95,7 @@ static void workbench_solid_flat_cache_populate(void *vedata, Object *ob)
WORKBENCH_StorageList *stl = data->stl;
IDProperty *props = BKE_layer_collection_engine_evaluated_get(ob, COLLECTION_MODE_NONE, RE_engine_id_BLENDER_WORKBENCH);
- const float* color = BKE_collection_engine_property_value_get_float_array(props, "object_color");
+ // const float* color = BKE_collection_engine_property_value_get_float_array(props, "object_color");
if (!DRW_object_is_renderable(ob))
return;
@@ -107,7 +108,7 @@ static void workbench_solid_flat_cache_populate(void *vedata, Object *ob)
/* Solid */
grp = DRW_shgroup_create(e_data.solid_sh, psl->solid_pass);
- DRW_shgroup_uniform_vec3(grp, "color", color, 1);
+ DRW_shgroup_uniform_vec3(grp, "color", SOLID_FLAT_DEFAULT_COLOR, 1);
DRW_shgroup_call_add(grp, geom, ob->obmat);
}
}
diff --git a/source/blender/draw/engines/workbench/solid_studio_mode.c b/source/blender/draw/engines/workbench/solid_studio_mode.c
index 386b5b0c690..210f5b41661 100644
--- a/source/blender/draw/engines/workbench/solid_studio_mode.c
+++ b/source/blender/draw/engines/workbench/solid_studio_mode.c
@@ -44,6 +44,7 @@ static struct {
struct GPUShader *solid_sh;
} e_data = {NULL};
+const float SOLID_STUDIO_DEFAULT_COLOR[3] = {1.0, 1.0, 1.0};
/* Functions */
@@ -107,7 +108,7 @@ static void workbench_solid_studio_cache_populate(void *vedata, Object *ob)
/* Solid */
grp = DRW_shgroup_create(e_data.solid_sh, psl->solid_pass);
- DRW_shgroup_uniform_vec3(grp, "color", color, 1);
+ DRW_shgroup_uniform_vec3(grp, "color", SOLID_STUDIO_DEFAULT_COLOR, 1);
DRW_shgroup_call_add(grp, geom, ob->obmat);
}
}