aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexander Orzechowski <orzechowski.alexander@gmail.com>2022-04-06 07:59:54 -0400
committerAlexander Orzechowski <orzechowski.alexander@gmail.com>2022-05-19 14:17:51 -0400
commit7e383c6a6ae0c794a0e52148d237e90e9e0d5dff (patch)
tree3eed05425c068e54f7c264460b6ccbbda16bde38
parent933ff0e60c423721403b55295bd3d309b010bd8c (diff)
wlr_scene: Make wlr_scene_render_output private
This function sidesteps damage tracking and output awareness on buffers/surfaces. This function isn't a great fit for the API. Let's also inline the function and simplify it.
-rw-r--r--include/wlr/types/wlr_scene.h8
-rw-r--r--types/scene/wlr_scene.c36
2 files changed, 9 insertions, 35 deletions
diff --git a/include/wlr/types/wlr_scene.h b/include/wlr/types/wlr_scene.h
index b48aeff8..c4b171e3 100644
--- a/include/wlr/types/wlr_scene.h
+++ b/include/wlr/types/wlr_scene.h
@@ -226,14 +226,6 @@ struct wlr_scene_node *wlr_scene_node_at(struct wlr_scene_node *node,
*/
struct wlr_scene *wlr_scene_create(void);
/**
- * Manually render the scene-graph on an output. The compositor needs to call
- * wlr_renderer_begin before and wlr_renderer_end after calling this function.
- * Damage is given in output-buffer-local coordinates and can be set to NULL to
- * disable damage tracking.
- */
-void wlr_scene_render_output(struct wlr_scene *scene, struct wlr_output *output,
- int lx, int ly, pixman_region32_t *damage);
-/**
* Handle presentation feedback for all surfaces in the scene, assuming that
* scene outputs and the scene rendering functions are used.
*
diff --git a/types/scene/wlr_scene.c b/types/scene/wlr_scene.c
index 52d8d00b..3de721f7 100644
--- a/types/scene/wlr_scene.c
+++ b/types/scene/wlr_scene.c
@@ -945,31 +945,6 @@ static void scene_node_for_each_node(struct wlr_scene_node *node,
}
}
-void wlr_scene_render_output(struct wlr_scene *scene, struct wlr_output *output,
- int lx, int ly, pixman_region32_t *damage) {
- pixman_region32_t full_region;
- pixman_region32_init_rect(&full_region, 0, 0, output->width, output->height);
- if (damage == NULL) {
- damage = &full_region;
- }
-
- struct wlr_renderer *renderer = output->renderer;
- assert(renderer);
-
- if (output->enabled && pixman_region32_not_empty(damage)) {
- struct render_data data = {
- .output = output,
- .damage = damage,
- .presentation = scene->presentation,
- };
- scene_node_for_each_node(&scene->node, -lx, -ly,
- render_node_iterator, &data);
- wlr_renderer_scissor(renderer, NULL);
- }
-
- pixman_region32_fini(&full_region);
-}
-
static void scene_handle_presentation_destroy(struct wl_listener *listener,
void *data) {
struct wlr_scene *scene =
@@ -1254,8 +1229,15 @@ bool wlr_scene_output_commit(struct wlr_scene_output *scene_output) {
wlr_renderer_clear(renderer, (float[4]){ 0.0, 0.0, 0.0, 1.0 });
}
- wlr_scene_render_output(scene_output->scene, output,
- scene_output->x, scene_output->y, &damage);
+ struct render_data data = {
+ .output = output,
+ .damage = &damage,
+ .presentation = scene_output->scene->presentation,
+ };
+ scene_node_for_each_node(&scene_output->scene->node,
+ -scene_output->x, -scene_output->y,
+ render_node_iterator, &data);
+ wlr_renderer_scissor(renderer, NULL);
wlr_output_render_software_cursors(output, &damage);
wlr_renderer_end(renderer);