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:
authorClément Foucault <foucault.clem@gmail.com>2019-05-11 20:16:46 +0300
committerClément Foucault <foucault.clem@gmail.com>2019-05-14 11:57:03 +0300
commit0e5da91f0aa534c3dfdb6a650cfb067fa84099da (patch)
tree8d0595c149a3acdfa066e488ae7db6c7e0549a0a /source/blender/draw/intern/draw_manager_exec.c
parented3f05aca9a9cb66c166d3f9531268b389386cdf (diff)
Cleanup: Remove DRWCallType
This simplify the rendering logic.
Diffstat (limited to 'source/blender/draw/intern/draw_manager_exec.c')
-rw-r--r--source/blender/draw/intern/draw_manager_exec.c23
1 files changed, 6 insertions, 17 deletions
diff --git a/source/blender/draw/intern/draw_manager_exec.c b/source/blender/draw/intern/draw_manager_exec.c
index b9d49df7947..0a4df550044 100644
--- a/source/blender/draw/intern/draw_manager_exec.c
+++ b/source/blender/draw/intern/draw_manager_exec.c
@@ -1265,23 +1265,12 @@ static void draw_shgroup(DRWShadingGroup *shgroup, DRWState pass_state)
GPU_SELECT_LOAD_IF_PICKSEL_CALL(call);
draw_geometry_prepare(shgroup, call);
- switch (call->type) {
- case DRW_CALL_SINGLE:
- draw_geometry_execute(shgroup, call->single.geometry, 0, 0, false);
- break;
- case DRW_CALL_RANGE:
- draw_geometry_execute(
- shgroup, call->range.geometry, call->range.start, call->range.count, false);
- break;
- case DRW_CALL_INSTANCES:
- draw_geometry_execute(shgroup, call->instances.geometry, 0, call->instances.count, true);
- break;
- case DRW_CALL_PROCEDURAL:
- draw_geometry_execute(
- shgroup, call->procedural.geometry, 0, call->procedural.vert_count, false);
- break;
- default:
- BLI_assert(0);
+ /* TODO revisit when DRW_SHG_INSTANCE and the like is gone. */
+ if (call->inst_count == 0) {
+ draw_geometry_execute(shgroup, call->batch, call->vert_first, call->vert_count, false);
+ }
+ else {
+ draw_geometry_execute(shgroup, call->batch, 0, call->inst_count, true);
}
}
/* Reset state */