aboutsummaryrefslogtreecommitdiff
path: root/include/sway/input
diff options
context:
space:
mode:
authorTony Crisci <tony@dubstepdish.com>2017-12-14 11:11:56 -0500
committerTony Crisci <tony@dubstepdish.com>2017-12-14 11:11:56 -0500
commit92fef27eaa0b52c9d37bdabff14ae21cd6660f46 (patch)
tree7a923bbbc233079006597d82721117bae88b6ac6 /include/sway/input
parentc173d30b9203520c274f34eb72fc787aa33ca211 (diff)
downloadsway-92fef27eaa0b52c9d37bdabff14ae21cd6660f46.tar.xz
basic configuration
Diffstat (limited to 'include/sway/input')
-rw-r--r--include/sway/input/input-manager.h9
-rw-r--r--include/sway/input/keyboard.h9
-rw-r--r--include/sway/input/seat.h20
3 files changed, 29 insertions, 9 deletions
diff --git a/include/sway/input/input-manager.h b/include/sway/input/input-manager.h
index 7d7c463f..cdcffab6 100644
--- a/include/sway/input/input-manager.h
+++ b/include/sway/input/input-manager.h
@@ -6,6 +6,7 @@
#include "list.h"
extern struct input_config *current_input_config;
+extern struct seat_config *current_seat_config;
/**
* The global singleton input manager
@@ -17,7 +18,6 @@ struct sway_input_device {
char *identifier;
struct wlr_input_device *wlr_device;
struct input_config *config;
- struct sway_keyboard *keyboard; // managed by the seat
struct wl_list link;
};
@@ -40,7 +40,10 @@ void sway_input_manager_set_focus(struct sway_input_manager *input,
void sway_input_manager_configure_xcursor(struct sway_input_manager *input);
-void sway_input_manager_apply_config(struct sway_input_manager *input,
- struct input_config *config);
+void sway_input_manager_apply_input_config(struct sway_input_manager *input,
+ struct input_config *input_config);
+
+void sway_input_manager_apply_seat_config(struct sway_input_manager *input,
+ struct seat_config *seat_config);
#endif
diff --git a/include/sway/input/keyboard.h b/include/sway/input/keyboard.h
index 881805b4..89cde3fa 100644
--- a/include/sway/input/keyboard.h
+++ b/include/sway/input/keyboard.h
@@ -1,15 +1,18 @@
#include "sway/input/seat.h"
struct sway_keyboard {
- struct sway_seat *seat;
- struct sway_input_device *device;
+ struct sway_seat_device *seat_device;
struct wl_list link; // sway_seat::keyboards
+ struct xkb_keymap *keymap;
+
struct wl_listener keyboard_key;
struct wl_listener keyboard_modifiers;
};
struct sway_keyboard *sway_keyboard_create(struct sway_seat *seat,
- struct sway_input_device *device);
+ struct sway_seat_device *device);
+
+void sway_keyboard_configure(struct sway_keyboard *keyboard);
void sway_keyboard_destroy(struct sway_keyboard *keyboard);
diff --git a/include/sway/input/seat.h b/include/sway/input/seat.h
index bd94a357..db69f83e 100644
--- a/include/sway/input/seat.h
+++ b/include/sway/input/seat.h
@@ -4,16 +4,25 @@
#include <wlr/types/wlr_seat.h>
#include "sway/input/input-manager.h"
+struct sway_seat_device {
+ struct sway_seat *sway_seat;
+ struct sway_input_device *input_device;
+ struct sway_keyboard *keyboard;
+ struct seat_attachment_config *attachment_config;
+ struct wl_list link; // sway_seat::devices
+};
+
struct sway_seat {
- struct wlr_seat *seat;
+ struct wlr_seat *wlr_seat;
+ struct seat_config *config;
struct sway_cursor *cursor;
struct sway_input_manager *input;
swayc_t *focus;
- list_t *devices;
-
struct wl_listener focus_destroy;
+ struct wl_list devices; // sway_seat_device::link
+
struct wl_list link; // input_manager::seats
};
@@ -23,6 +32,9 @@ struct sway_seat *sway_seat_create(struct sway_input_manager *input,
void sway_seat_add_device(struct sway_seat *seat,
struct sway_input_device *device);
+void sway_seat_configure_device(struct sway_seat *seat,
+ struct sway_input_device *device);
+
void sway_seat_remove_device(struct sway_seat *seat,
struct sway_input_device *device);
@@ -30,4 +42,6 @@ void sway_seat_configure_xcursor(struct sway_seat *seat);
void sway_seat_set_focus(struct sway_seat *seat, swayc_t *container);
+void sway_seat_set_config(struct sway_seat *seat, struct seat_config *seat_config);
+
#endif