aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon Ser <contact@emersion.fr>2023-05-10 20:43:25 +0200
committerSimon Ser <contact@emersion.fr>2023-05-17 22:08:34 +0000
commit69aeccddb7b68ba65dacf01578dd91b84321b3dc (patch)
tree5022cbcb113b408501f862b212b3e204daa1ddb0
parent0910fa917981bea48475e37b57b549e11bf0f1b4 (diff)
seat/keyboard: allow no keymap
-rw-r--r--types/seat/wlr_seat_keyboard.c27
1 files changed, 25 insertions, 2 deletions
diff --git a/types/seat/wlr_seat_keyboard.c b/types/seat/wlr_seat_keyboard.c
index 0d5a5145..1dab1b32 100644
--- a/types/seat/wlr_seat_keyboard.c
+++ b/types/seat/wlr_seat_keyboard.c
@@ -1,7 +1,9 @@
#define _POSIX_C_SOURCE 200809L
#include <assert.h>
+#include <fcntl.h>
#include <stdlib.h>
#include <time.h>
+#include <unistd.h>
#include <wayland-server-core.h>
#include <wlr/types/wlr_compositor.h>
#include <wlr/types/wlr_data_device.h>
@@ -340,6 +342,24 @@ static void seat_client_send_keymap(struct wlr_seat_client *client,
return;
}
+ enum wl_keyboard_keymap_format format;
+ int fd, devnull = -1;
+ uint32_t size;
+ if (keyboard->keymap != NULL) {
+ format = WL_KEYBOARD_KEYMAP_FORMAT_XKB_V1;
+ fd = keyboard->keymap_fd;
+ size = keyboard->keymap_size;
+ } else {
+ format = WL_KEYBOARD_KEYMAP_FORMAT_NO_KEYMAP;
+ devnull = open("/dev/null", O_RDONLY | O_CLOEXEC);
+ if (devnull < 0) {
+ wlr_log_errno(WLR_ERROR, "Failed to open /dev/null");
+ return;
+ }
+ fd = devnull;
+ size = 0;
+ }
+
// TODO: We should probably lift all of the keys set by the other
// keyboard
struct wl_resource *resource;
@@ -348,8 +368,11 @@ static void seat_client_send_keymap(struct wlr_seat_client *client,
continue;
}
- wl_keyboard_send_keymap(resource, WL_KEYBOARD_KEYMAP_FORMAT_XKB_V1,
- keyboard->keymap_fd, keyboard->keymap_size);
+ wl_keyboard_send_keymap(resource, format, fd, size);
+ }
+
+ if (devnull >= 0) {
+ close(devnull);
}
}