diff options
author | Tony Crisci <tony@dubstepdish.com> | 2017-10-21 09:37:58 -0400 |
---|---|---|
committer | Tony Crisci <tony@dubstepdish.com> | 2017-10-21 09:37:58 -0400 |
commit | a87b60e31e5288c1c3e8c8f94c9a7ccb29e38b54 (patch) | |
tree | e9d1daaa8fc5a2ee1103ec19855b958f47932145 /rootston/touch.c | |
parent | 39308cb8688560607cb1d024123d32a7905c6369 (diff) | |
parent | 1782d5e7b7dc5e494cfee72b758d5fa8114aecc8 (diff) |
Merge branch 'master' into feature/data-device-selection
Diffstat (limited to 'rootston/touch.c')
-rw-r--r-- | rootston/touch.c | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/rootston/touch.c b/rootston/touch.c new file mode 100644 index 00000000..f6d9b11a --- /dev/null +++ b/rootston/touch.c @@ -0,0 +1,26 @@ +#include <stdlib.h> +#include <wayland-server.h> +#include <wlr/types/wlr_input_device.h> +#include <wlr/types/wlr_pointer.h> +#include "rootston/input.h" + +// TODO: we'll likely want touch events to both control the cursor *and* be +// submitted directly to the seat. + +void touch_add(struct wlr_input_device *device, struct roots_input *input) { + struct roots_touch *touch = calloc(sizeof(struct roots_touch), 1); + device->data = touch; + touch->device = device; + touch->input = input; + wl_list_insert(&input->touch, &touch->link); + wlr_cursor_attach_input_device(input->cursor, device); + cursor_load_config(input->server->config, input->cursor, + input, input->server->desktop); +} + +void touch_remove(struct wlr_input_device *device, struct roots_input *input) { + struct roots_touch *touch = device->data; + wlr_cursor_detach_input_device(input->cursor, device); + wl_list_remove(&touch->link); + free(touch); +} |