aboutsummaryrefslogtreecommitdiff
path: root/include/backend
diff options
context:
space:
mode:
authoremersion <contact@emersion.fr>2018-04-29 12:16:31 +0100
committeremersion <contact@emersion.fr>2018-04-29 14:30:13 +0100
commit9f8a7c8fc4bbcbdd149c2892b13f06ba21931907 (patch)
tree203d6f697ac3a7bdb6f59f9a85b54751f27b25d6 /include/backend
parent2551ef8871d78a43acbbbac765919ea4f48821f9 (diff)
backend/wayland: create one virtual pointer per output
Diffstat (limited to 'include/backend')
-rw-r--r--include/backend/wayland.h21
1 files changed, 12 insertions, 9 deletions
diff --git a/include/backend/wayland.h b/include/backend/wayland.h
index d1af954c..6d4e3f54 100644
--- a/include/backend/wayland.h
+++ b/include/backend/wayland.h
@@ -35,7 +35,7 @@ struct wlr_wl_backend {
char *seat_name;
};
-struct wlr_wl_backend_output {
+struct wlr_wl_output {
struct wlr_output wlr_output;
struct wlr_wl_backend *backend;
@@ -47,7 +47,7 @@ struct wlr_wl_backend_output {
struct {
struct wl_shm_pool *pool;
- void *buffer; // actually a (client-side) struct wl_buffer*
+ void *buffer; // actually a (client-side) struct wl_buffer *
uint32_t buf_size;
uint8_t *data;
struct wl_surface *surface;
@@ -69,17 +69,20 @@ struct wlr_wl_input_device {
struct wlr_wl_pointer {
struct wlr_pointer wlr_pointer;
+
+ struct wlr_wl_input_device *input_device;
+ struct wl_pointer *wl_pointer;
enum wlr_axis_source axis_source;
- struct wlr_wl_backend_output *current_output;
- struct wl_listener output_destroy_listener;
+ struct wlr_wl_output *output;
+
+ struct wl_listener output_destroy;
};
void poll_wl_registry(struct wlr_wl_backend *backend);
-void update_wl_output_cursor(struct wlr_wl_backend_output *output);
-struct wlr_wl_backend_output *get_wl_output_for_surface(
- struct wlr_wl_backend *backend, struct wl_surface *surface);
-void get_wl_output_layout_box(struct wlr_wl_backend *backend,
- struct wlr_box *box);
+void update_wl_output_cursor(struct wlr_wl_output *output);
+struct wlr_wl_pointer *pointer_get_wl(struct wlr_pointer *wlr_pointer);
+void create_wl_pointer(struct wl_pointer *wl_pointer,
+ struct wlr_wl_output *output);
extern const struct wl_seat_listener seat_listener;