diff options
Diffstat (limited to 'backend/x11')
| -rw-r--r-- | backend/x11/output.c | 11 | 
1 files changed, 6 insertions, 5 deletions
diff --git a/backend/x11/output.c b/backend/x11/output.c index 835df3b7..440e26de 100644 --- a/backend/x11/output.c +++ b/backend/x11/output.c @@ -16,11 +16,11 @@  #include <wlr/interfaces/wlr_output.h>  #include <wlr/interfaces/wlr_pointer.h>  #include <wlr/interfaces/wlr_touch.h> +#include <wlr/render/wlr_renderer.h>  #include <wlr/types/wlr_matrix.h>  #include <wlr/util/log.h>  #include "backend/x11.h" -#include "render/wlr_renderer.h"  #include "types/wlr_buffer.h"  #include "util/signal.h"  #include "util/time.h" @@ -390,12 +390,13 @@ static bool output_cursor_to_picture(struct wlr_x11_output *output,  	int depth = 32;  	int stride = buffer->width * 4; -	if (!wlr_renderer_bind_buffer(renderer, buffer)) { +	uint8_t *data = malloc(buffer->height * stride); +	if (data == NULL) {  		return false;  	} -	uint8_t *data = malloc(buffer->height * stride); -	if (data == NULL) { +	if (!wlr_renderer_begin_with_buffer(renderer, buffer)) { +		free(data);  		return false;  	} @@ -404,7 +405,7 @@ static bool output_cursor_to_picture(struct wlr_x11_output *output,  		stride, buffer->width, buffer->height, 0, 0, 0, 0,  		data); -	wlr_renderer_bind_buffer(renderer, NULL); +	wlr_renderer_end(renderer);  	if (!result) {  		free(data);  | 
