commit 8ecffded9bf606e80ce8b2ad3d2ed929aea4f374
parent 960ffdf57dbd67d563b56fce86bdbbd7c20f4326
Author: Leon Plickat <leonhenrik.plickat@stud.uni-goettingen.de>
Date:   Sat, 15 Jun 2019 04:20:24 +0200
`Esc` stops current action / event
Diffstat:
1 file changed, 20 insertions(+), 0 deletions(-)
diff --git a/input.c b/input.c
@@ -23,6 +23,7 @@ static void keyboard_handle_modifiers(
 		&keyboard->device->keyboard->modifiers);
 }
 
+static void view_end_interactive(struct wio_server *server);
 static void keyboard_handle_key(
 		struct wl_listener *listener, void *data) {
 	struct wio_keyboard *keyboard =
@@ -30,6 +31,25 @@ static void keyboard_handle_key(
 	struct wio_server *server = keyboard->server;
 	struct wlr_event_keyboard_key *event = data;
 	struct wlr_seat *seat = server->seat;
+	xkb_keycode_t keycode = event->keycode + 8;
+	const xkb_keysym_t *syms;
+	int nsyms = xkb_state_key_get_syms(
+		keyboard->device->keyboard->xkb_state,
+		keycode, &syms);
+
+	for (int i = 0; i < nsyms; i++) {
+		if (syms[i] == XKB_KEY_Escape) {
+			switch (server->input_state) {
+			case INPUT_STATE_NONE:
+			case INPUT_STATE_MENU:
+				break;
+			default:
+				view_end_interactive(server);
+				return;
+			}
+		}
+	}
+
 	wlr_seat_set_keyboard(seat, keyboard->device);
 	wlr_seat_keyboard_notify_key(seat, event->time_msec,
 		event->keycode, event->state);