} handlers;
};
-void tablet_setup_handlers(struct seat *seat, struct wlr_input_device *wlr_input_device);
+uint32_t tablet_get_mapped_button(uint32_t src_button);
+void tablet_init(struct seat *seat, struct wlr_input_device *wlr_input_device);
#endif /* LABWC_TABLET_H */
--- /dev/null
+/* SPDX-License-Identifier: GPL-2.0-only */
+#ifndef LABWC_TABLET_PAD_H
+#define LABWC_TABLET_PAD_H
+
+#include <wayland-server-core.h>
+struct seat;
+struct wlr_device;
+struct wlr_input_device;
+
+struct drawing_tablet_pad {
+ struct seat *seat;
+ struct wlr_tablet_pad *tablet;
+ struct {
+ struct wl_listener button;
+ struct wl_listener destroy;
+ } handlers;
+};
+
+void tablet_pad_init(struct seat *seat, struct wlr_input_device *wlr_input_device);
+
+#endif /* LABWC_TABLET_PAD_H */
labwc_sources += files(
'cursor.c',
'tablet.c',
+ 'tablet_pad.c',
'gestures.c',
'input.c',
'keyboard.c',
// Ignore other events
}
-static uint32_t
-get_mapped_button(uint32_t src_button)
+uint32_t
+tablet_get_mapped_button(uint32_t src_button)
{
struct button_map_entry *map_entry;
for (size_t i = 0; i < rc.tablet.button_map_count; i++) {
struct wlr_tablet_tool_tip_event *ev = data;
struct drawing_tablet *tablet = ev->tablet->data;
- uint32_t button = get_mapped_button(BTN_TOOL_PEN);
+ uint32_t button = tablet_get_mapped_button(BTN_TOOL_PEN);
if (!button) {
return;
}
struct wlr_tablet_tool_button_event *ev = data;
struct drawing_tablet *tablet = ev->tablet->data;
- uint32_t button = get_mapped_button(ev->button);
+ uint32_t button = tablet_get_mapped_button(ev->button);
if (!button) {
return;
}
free(tablet);
}
-static void
-setup_pad(struct seat *seat, struct wlr_input_device *wlr_device)
-{
- wlr_log(WLR_INFO, "not setting up pad");
-}
-
-static void
-setup_pen(struct seat *seat, struct wlr_input_device *wlr_device)
+void
+tablet_init(struct seat *seat, struct wlr_input_device *wlr_device)
{
wlr_log(WLR_DEBUG, "setting up tablet");
struct drawing_tablet *tablet = znew(*tablet);
CONNECT_SIGNAL(tablet->tablet, &tablet->handlers, button);
CONNECT_SIGNAL(wlr_device, &tablet->handlers, destroy);
}
-
-void
-tablet_setup_handlers(struct seat *seat, struct wlr_input_device *device)
-{
- switch (device->type) {
- case WLR_INPUT_DEVICE_TABLET_PAD:
- setup_pad(seat, device);
- break;
- case WLR_INPUT_DEVICE_TABLET_TOOL:
- setup_pen(seat, device);
- break;
- default:
- assert(false && "tried to add non-tablet as tablet");
- }
-}
--- /dev/null
+// SPDX-License-Identifier: GPL-2.0-only
+#include <assert.h>
+#include <stdlib.h>
+#include <wlr/types/wlr_tablet_pad.h>
+#include <wlr/util/log.h>
+#include "common/macros.h"
+#include "common/mem.h"
+#include "config/rcxml.h"
+#include "input/cursor.h"
+#include "input/tablet.h"
+#include "input/tablet_pad.h"
+
+static void
+handle_button(struct wl_listener *listener, void *data)
+{
+ struct drawing_tablet_pad *tablet_pad =
+ wl_container_of(listener, tablet_pad, handlers.button);
+ struct wlr_tablet_pad_button_event *ev = data;
+
+ uint32_t button = tablet_get_mapped_button(ev->button);
+ if (!button) {
+ return;
+ }
+
+ cursor_emulate_button(tablet_pad->seat, button, ev->state, ev->time_msec);
+}
+
+static void
+handle_destroy(struct wl_listener *listener, void *data)
+{
+ struct drawing_tablet_pad *tablet =
+ wl_container_of(listener, tablet, handlers.destroy);
+ free(tablet);
+}
+
+void
+tablet_pad_init(struct seat *seat, struct wlr_input_device *wlr_device)
+{
+ wlr_log(WLR_DEBUG, "setting up tablet pad");
+ struct drawing_tablet_pad *tablet = znew(*tablet);
+ tablet->seat = seat;
+ tablet->tablet = wlr_tablet_pad_from_input_device(wlr_device);
+ tablet->tablet->data = tablet;
+ CONNECT_SIGNAL(tablet->tablet, &tablet->handlers, button);
+ CONNECT_SIGNAL(wlr_device, &tablet->handlers, destroy);
+}
#include <wlr/util/log.h>
#include "common/mem.h"
#include "input/tablet.h"
+#include "input/tablet_pad.h"
#include "input/input.h"
#include "input/keyboard.h"
#include "input/key-state.h"
{
struct input *input = znew(*input);
input->wlr_input_device = dev;
- tablet_setup_handlers(seat, dev);
+ tablet_init(seat, dev);
+
+ return input;
+}
+
+static struct input *
+new_tablet_pad(struct seat *seat, struct wlr_input_device *dev)
+{
+ struct input *input = znew(*input);
+ input->wlr_input_device = dev;
+ tablet_pad_init(seat, dev);
return input;
}
input = new_touch(seat, device);
break;
case WLR_INPUT_DEVICE_TABLET_PAD:
+ input = new_tablet_pad(seat, device);
+ break;
case WLR_INPUT_DEVICE_TABLET_TOOL:
input = new_tablet(seat, device);
break;