uint32_t serial;
uint32_t content_hint;
uint32_t content_purpose;
+ char *surrounding_text;
struct window *window;
struct widget *widget;
};
uint32_t anchor)
{
struct virtual_keyboard *keyboard = data;
- const struct layout *layout;
-
- layout = get_current_layout(keyboard);
-
- fprintf(stderr, "Surrounding text updated: %s\n", text);
-
- window_schedule_resize(keyboard->window,
- layout->columns * key_width,
- layout->rows * key_height);
- widget_schedule_redraw(keyboard->widget);
+ free(keyboard->surrounding_text);
+ keyboard->surrounding_text = strdup(text);
}
static void
virtual_keyboard_send_preedit(keyboard, index);
}
+static void
+input_method_context_commit(void *data,
+ struct input_method_context *context)
+{
+ struct virtual_keyboard *keyboard = data;
+ const struct layout *layout;
+
+ layout = get_current_layout(keyboard);
+
+ if (keyboard->surrounding_text)
+ fprintf(stderr, "Surrounding text updated: %s\n", keyboard->surrounding_text);
+
+ window_schedule_resize(keyboard->window,
+ layout->columns * key_width,
+ layout->rows * key_height);
+
+ widget_schedule_redraw(keyboard->widget);
+}
+
static const struct input_method_context_listener input_method_context_listener = {
input_method_context_surrounding_text,
input_method_context_reset,
input_method_context_content_type,
- input_method_context_invoke_action
+ input_method_context_invoke_action,
+ input_method_context_commit
};
static void
{
}
+static void
+input_method_context_commit(void *data,
+ struct input_method_context *context)
+{
+}
+
static const struct input_method_context_listener input_method_context_listener = {
input_method_context_surrounding_text,
input_method_context_reset,
input_method_context_content_type,
- input_method_context_invoke_action
+ input_method_context_invoke_action,
+ input_method_context_commit
};
static void
}
}
+static void
+text_model_commit(struct wl_client *client,
+ struct wl_resource *resource)
+{
+ struct text_model *text_model = resource->data;
+ struct input_method *input_method, *next;
+
+ wl_list_for_each_safe(input_method, next, &text_model->input_methods, link) {
+ if (!input_method->context)
+ continue;
+ input_method_context_send_commit(&input_method->context->resource);
+ }
+}
+
static const struct text_model_interface text_model_implementation = {
text_model_set_surrounding_text,
text_model_activate,
text_model_reset,
text_model_set_micro_focus,
text_model_set_content_type,
- text_model_invoke_action
+ text_model_invoke_action,
+ text_model_commit
};
static void text_model_factory_create_text_model(struct wl_client *client,