[PATCH v2 1/3] keyboard: fix to make it work in the presence of multiple seats
Philipp Brüschweiler
blei42 at gmail.com
Mon Aug 13 05:35:05 PDT 2012
Multiple seats imply multiple input methods. Each input method is now
held in a keyboard_input_method struct. On a button click, a commit is
sent to each input method.
---
clients/keyboard.c | 44 +++++++++++++++++++++++++++++++++++---------
1 Datei geändert, 35 Zeilen hinzugefügt(+), 9 Zeilen entfernt(-)
diff --git a/clients/keyboard.c b/clients/keyboard.c
index 9fdd8cc..293c182 100644
--- a/clients/keyboard.c
+++ b/clients/keyboard.c
@@ -33,11 +33,12 @@
struct virtual_keyboard {
struct input_panel *input_panel;
- struct input_method *input_method;
struct display *display;
+
+ struct wl_list input_methods;
};
-struct keyboard {
+struct keyboard_window {
struct virtual_keyboard *keyboard;
struct window *window;
struct widget *widget;
@@ -45,10 +46,17 @@ struct keyboard {
int cy;
};
+struct keyboard_input_method {
+ struct virtual_keyboard *keyboard;
+ struct input_method *input_method;
+
+ struct wl_list link;
+};
+
static void
redraw_handler(struct widget *widget, void *data)
{
- struct keyboard *keyboard = data;
+ struct keyboard_window *keyboard = data;
cairo_surface_t *surface;
struct rectangle allocation;
cairo_t *cr;
@@ -112,7 +120,8 @@ button_handler(struct widget *widget,
uint32_t button,
enum wl_pointer_button_state state, void *data)
{
- struct keyboard *keyboard = data;
+ struct keyboard_window *keyboard = data;
+ struct keyboard_input_method *im;
struct rectangle allocation;
int32_t x, y;
char text[] = { '0', '\0' };
@@ -129,28 +138,43 @@ button_handler(struct widget *widget,
text[0] = y / keyboard->cy * 10 + x / keyboard->cx + '0';
- input_method_commit_string(keyboard->keyboard->input_method, text, -1);
+ wl_list_for_each(im, &keyboard->keyboard->input_methods, link)
+ input_method_commit_string(im->input_method, text, -1);
widget_schedule_redraw(widget);
}
static void
+keyboard_input_method_create(struct virtual_keyboard *keyboard,
+ struct input_method *input_method)
+{
+ struct keyboard_input_method *im = malloc(sizeof *im);
+ im->keyboard = keyboard;
+ im->input_method = input_method;
+
+ wl_list_insert(&keyboard->input_methods, &im->link);
+}
+
+static void
global_handler(struct wl_display *display, uint32_t id,
const char *interface, uint32_t version, void *data)
{
struct virtual_keyboard *keyboard = data;
+ struct input_method *input_method;
if (!strcmp(interface, "input_panel")) {
keyboard->input_panel = wl_display_bind(display, id, &input_panel_interface);
} else if (!strcmp(interface, "input_method")) {
- keyboard->input_method = wl_display_bind(display, id, &input_method_interface);
+ input_method = wl_display_bind(display, id, &input_method_interface);
+ keyboard_input_method_create(keyboard, input_method);
}
}
static void
-keyboard_create(struct output *output, struct virtual_keyboard *virtual_keyboard)
+keyboard_window_create(struct output *output,
+ struct virtual_keyboard *virtual_keyboard)
{
- struct keyboard *keyboard;
+ struct keyboard_window *keyboard;
keyboard = malloc(sizeof *keyboard);
memset(keyboard, 0, sizeof *keyboard);
@@ -187,7 +211,7 @@ handle_output_configure(struct output *output, void *data)
output_set_user_data(output, virtual_keyboard);
- keyboard_create(output, virtual_keyboard);
+ keyboard_window_create(output, virtual_keyboard);
}
int
@@ -201,6 +225,8 @@ main(int argc, char *argv[])
return -1;
}
+ wl_list_init(&virtual_keyboard.input_methods);
+
wl_display_add_global_listener(display_get_display(virtual_keyboard.display),
global_handler, &virtual_keyboard);
--
1.7.11.4
More information about the wayland-devel
mailing list