mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-16 07:04:29 +00:00
Merge branch 'wip/carlosg/im-fixes' into 'main'
gtkimcontextwayland: Refactor handling of client updates Closes #5106 and #5105 See merge request GNOME/gtk!4962
This commit is contained in:
commit
08de13e9d2
@ -98,6 +98,11 @@ struct _GtkIMContextWayland
|
|||||||
|
|
||||||
static void gtk_im_context_wayland_focus_out (GtkIMContext *context);
|
static void gtk_im_context_wayland_focus_out (GtkIMContext *context);
|
||||||
|
|
||||||
|
static void commit_state (GtkIMContextWayland *context);
|
||||||
|
static void notify_surrounding_text (GtkIMContextWayland *context);
|
||||||
|
static void notify_cursor_location (GtkIMContextWayland *context);
|
||||||
|
static void notify_content_type (GtkIMContextWayland *context);
|
||||||
|
|
||||||
G_DEFINE_TYPE_WITH_CODE (GtkIMContextWayland, gtk_im_context_wayland, GTK_TYPE_IM_CONTEXT_SIMPLE,
|
G_DEFINE_TYPE_WITH_CODE (GtkIMContextWayland, gtk_im_context_wayland, GTK_TYPE_IM_CONTEXT_SIMPLE,
|
||||||
gtk_im_module_ensure_extension_point ();
|
gtk_im_module_ensure_extension_point ();
|
||||||
g_io_extension_point_implement (GTK_IM_MODULE_EXTENSION_POINT_NAME,
|
g_io_extension_point_implement (GTK_IM_MODULE_EXTENSION_POINT_NAME,
|
||||||
@ -128,7 +133,8 @@ gtk_im_context_wayland_get_global (GtkIMContextWayland *self)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
notify_external_change (GtkIMContextWayland *context)
|
notify_im_change (GtkIMContextWayland *context,
|
||||||
|
enum zwp_text_input_v3_change_cause cause)
|
||||||
{
|
{
|
||||||
GtkIMContextWaylandGlobal *global;
|
GtkIMContextWaylandGlobal *global;
|
||||||
gboolean result;
|
gboolean result;
|
||||||
@ -137,9 +143,13 @@ notify_external_change (GtkIMContextWayland *context)
|
|||||||
if (global == NULL)
|
if (global == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
context->surrounding_change = ZWP_TEXT_INPUT_V3_CHANGE_CAUSE_OTHER;
|
context->surrounding_change = cause;
|
||||||
|
|
||||||
g_signal_emit_by_name (global->current, "retrieve-surrounding", &result);
|
g_signal_emit_by_name (global->current, "retrieve-surrounding", &result);
|
||||||
|
notify_surrounding_text (context);
|
||||||
|
notify_content_type (context);
|
||||||
|
notify_cursor_location (context);
|
||||||
|
commit_state (context);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -265,17 +275,25 @@ text_input_done (void *data,
|
|||||||
uint32_t serial)
|
uint32_t serial)
|
||||||
{
|
{
|
||||||
GtkIMContextWaylandGlobal *global = data;
|
GtkIMContextWaylandGlobal *global = data;
|
||||||
gboolean result;
|
GtkIMContextWayland *context;
|
||||||
|
gboolean update_im;
|
||||||
|
|
||||||
global->done_serial = serial;
|
global->done_serial = serial;
|
||||||
|
|
||||||
if (!global->current)
|
if (!global->current)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
context = GTK_IM_CONTEXT_WAYLAND (global->current);
|
||||||
|
update_im = (context->pending_commit != NULL ||
|
||||||
|
g_strcmp0 (context->pending_preedit.text,
|
||||||
|
context->current_preedit.text) != 0);
|
||||||
|
|
||||||
text_input_delete_surrounding_text_apply (global);
|
text_input_delete_surrounding_text_apply (global);
|
||||||
text_input_commit_apply (global);
|
text_input_commit_apply (global);
|
||||||
g_signal_emit_by_name (global->current, "retrieve-surrounding", &result);
|
|
||||||
text_input_preedit_apply (global);
|
text_input_preedit_apply (global);
|
||||||
|
|
||||||
|
if (update_im && global->serial == serial)
|
||||||
|
notify_im_change (context, ZWP_TEXT_INPUT_V3_CHANGE_CAUSE_INPUT_METHOD);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -292,8 +310,6 @@ notify_surrounding_text (GtkIMContextWayland *context)
|
|||||||
global = gtk_im_context_wayland_get_global (context);
|
global = gtk_im_context_wayland_get_global (context);
|
||||||
if (global == NULL)
|
if (global == NULL)
|
||||||
return;
|
return;
|
||||||
if (global->done_serial != global->serial)
|
|
||||||
return;
|
|
||||||
|
|
||||||
len = strlen (context->surrounding.text);
|
len = strlen (context->surrounding.text);
|
||||||
cursor = context->surrounding.cursor_idx;
|
cursor = context->surrounding.cursor_idx;
|
||||||
@ -368,8 +384,6 @@ notify_cursor_location (GtkIMContextWayland *context)
|
|||||||
global = gtk_im_context_wayland_get_global (context);
|
global = gtk_im_context_wayland_get_global (context);
|
||||||
if (global == NULL)
|
if (global == NULL)
|
||||||
return;
|
return;
|
||||||
if (global->done_serial != global->serial)
|
|
||||||
return;
|
|
||||||
|
|
||||||
rect = context->cursor_rect;
|
rect = context->cursor_rect;
|
||||||
gtk_widget_translate_coordinates (context->widget,
|
gtk_widget_translate_coordinates (context->widget,
|
||||||
@ -460,8 +474,6 @@ notify_content_type (GtkIMContextWayland *context)
|
|||||||
global = gtk_im_context_wayland_get_global (context);
|
global = gtk_im_context_wayland_get_global (context);
|
||||||
if (global == NULL)
|
if (global == NULL)
|
||||||
return;
|
return;
|
||||||
if (global->done_serial != global->serial)
|
|
||||||
return;
|
|
||||||
|
|
||||||
g_object_get (context,
|
g_object_get (context,
|
||||||
"input-hints", &hints,
|
"input-hints", &hints,
|
||||||
@ -527,7 +539,6 @@ released_cb (GtkGestureClick *gesture,
|
|||||||
{
|
{
|
||||||
GtkIMContextWaylandGlobal *global;
|
GtkIMContextWaylandGlobal *global;
|
||||||
GtkInputHints hints;
|
GtkInputHints hints;
|
||||||
gboolean result;
|
|
||||||
|
|
||||||
global = gtk_im_context_wayland_get_global (context);
|
global = gtk_im_context_wayland_get_global (context);
|
||||||
if (global == NULL)
|
if (global == NULL)
|
||||||
@ -544,8 +555,8 @@ released_cb (GtkGestureClick *gesture,
|
|||||||
x, y))
|
x, y))
|
||||||
{
|
{
|
||||||
zwp_text_input_v3_enable (global->text_input);
|
zwp_text_input_v3_enable (global->text_input);
|
||||||
g_signal_emit_by_name (global->current, "retrieve-surrounding", &result);
|
notify_im_change (GTK_IM_CONTEXT_WAYLAND (context),
|
||||||
commit_state (context);
|
ZWP_TEXT_INPUT_V3_CHANGE_CAUSE_OTHER);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -677,12 +688,9 @@ static void
|
|||||||
enable (GtkIMContextWayland *context_wayland,
|
enable (GtkIMContextWayland *context_wayland,
|
||||||
GtkIMContextWaylandGlobal *global)
|
GtkIMContextWaylandGlobal *global)
|
||||||
{
|
{
|
||||||
gboolean result;
|
|
||||||
zwp_text_input_v3_enable (global->text_input);
|
zwp_text_input_v3_enable (global->text_input);
|
||||||
g_signal_emit_by_name (global->current, "retrieve-surrounding", &result);
|
notify_im_change (context_wayland,
|
||||||
notify_content_type (context_wayland);
|
ZWP_TEXT_INPUT_V3_CHANGE_CAUSE_OTHER);
|
||||||
notify_cursor_location (context_wayland);
|
|
||||||
commit_state (context_wayland);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -692,6 +700,12 @@ disable (GtkIMContextWayland *context_wayland,
|
|||||||
zwp_text_input_v3_disable (global->text_input);
|
zwp_text_input_v3_disable (global->text_input);
|
||||||
commit_state (context_wayland);
|
commit_state (context_wayland);
|
||||||
|
|
||||||
|
/* The commit above will still count in the .done event accounting,
|
||||||
|
* we should account for it, lest the serial gets out of sync after
|
||||||
|
* a future focus_in/enable.
|
||||||
|
*/
|
||||||
|
global->done_serial++;
|
||||||
|
|
||||||
/* after disable, incoming state changes won't take effect anyway */
|
/* after disable, incoming state changes won't take effect anyway */
|
||||||
if (context_wayland->current_preedit.text)
|
if (context_wayland->current_preedit.text)
|
||||||
{
|
{
|
||||||
@ -854,7 +868,8 @@ gtk_im_context_wayland_focus_out (GtkIMContext *context)
|
|||||||
static void
|
static void
|
||||||
gtk_im_context_wayland_reset (GtkIMContext *context)
|
gtk_im_context_wayland_reset (GtkIMContext *context)
|
||||||
{
|
{
|
||||||
notify_external_change (GTK_IM_CONTEXT_WAYLAND (context));
|
notify_im_change (GTK_IM_CONTEXT_WAYLAND (context),
|
||||||
|
ZWP_TEXT_INPUT_V3_CHANGE_CAUSE_OTHER);
|
||||||
|
|
||||||
GTK_IM_CONTEXT_CLASS (gtk_im_context_wayland_parent_class)->reset (context);
|
GTK_IM_CONTEXT_CLASS (gtk_im_context_wayland_parent_class)->reset (context);
|
||||||
}
|
}
|
||||||
@ -889,8 +904,6 @@ gtk_im_context_wayland_set_cursor_location (GtkIMContext *context,
|
|||||||
gtk_event_controller_reset (GTK_EVENT_CONTROLLER (context_wayland->gesture));
|
gtk_event_controller_reset (GTK_EVENT_CONTROLLER (context_wayland->gesture));
|
||||||
|
|
||||||
context_wayland->cursor_rect = *rect;
|
context_wayland->cursor_rect = *rect;
|
||||||
notify_cursor_location (context_wayland);
|
|
||||||
commit_state (context_wayland);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -924,9 +937,6 @@ gtk_im_context_wayland_set_surrounding (GtkIMContext *context,
|
|||||||
context_wayland->surrounding.text = g_strndup (text, len);
|
context_wayland->surrounding.text = g_strndup (text, len);
|
||||||
context_wayland->surrounding.cursor_idx = cursor_index;
|
context_wayland->surrounding.cursor_idx = cursor_index;
|
||||||
context_wayland->surrounding.anchor_idx = selection_bound;
|
context_wayland->surrounding.anchor_idx = selection_bound;
|
||||||
|
|
||||||
notify_surrounding_text (context_wayland);
|
|
||||||
commit_state (context_wayland);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
|
@ -1910,7 +1910,7 @@ gtk_text_init (GtkText *self)
|
|||||||
g_signal_connect (priv->key_controller, "key-pressed",
|
g_signal_connect (priv->key_controller, "key-pressed",
|
||||||
G_CALLBACK (gtk_text_key_controller_key_pressed), self);
|
G_CALLBACK (gtk_text_key_controller_key_pressed), self);
|
||||||
g_signal_connect_swapped (priv->key_controller, "im-update",
|
g_signal_connect_swapped (priv->key_controller, "im-update",
|
||||||
G_CALLBACK (gtk_text_schedule_im_reset), self);
|
G_CALLBACK (gtk_im_context_reset), priv->im_context);
|
||||||
gtk_event_controller_key_set_im_context (GTK_EVENT_CONTROLLER_KEY (priv->key_controller),
|
gtk_event_controller_key_set_im_context (GTK_EVENT_CONTROLLER_KEY (priv->key_controller),
|
||||||
priv->im_context);
|
priv->im_context);
|
||||||
gtk_widget_add_controller (GTK_WIDGET (self), priv->key_controller);
|
gtk_widget_add_controller (GTK_WIDGET (self), priv->key_controller);
|
||||||
@ -3773,8 +3773,6 @@ gtk_text_move_cursor (GtkText *self,
|
|||||||
GtkTextPrivate *priv = gtk_text_get_instance_private (self);
|
GtkTextPrivate *priv = gtk_text_get_instance_private (self);
|
||||||
int new_pos = priv->current_pos;
|
int new_pos = priv->current_pos;
|
||||||
|
|
||||||
gtk_text_reset_im_context (self);
|
|
||||||
|
|
||||||
if (priv->current_pos != priv->selection_bound && !extend_selection)
|
if (priv->current_pos != priv->selection_bound && !extend_selection)
|
||||||
{
|
{
|
||||||
/* If we have a current selection and aren't extending it, move to the
|
/* If we have a current selection and aren't extending it, move to the
|
||||||
@ -3901,6 +3899,9 @@ gtk_text_move_cursor (GtkText *self,
|
|||||||
gtk_text_set_selection_bounds (self, new_pos, new_pos);
|
gtk_text_set_selection_bounds (self, new_pos, new_pos);
|
||||||
|
|
||||||
gtk_text_pend_cursor_blink (self);
|
gtk_text_pend_cursor_blink (self);
|
||||||
|
|
||||||
|
priv->need_im_reset = TRUE;
|
||||||
|
gtk_text_reset_im_context (self);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -3928,8 +3929,6 @@ gtk_text_delete_from_cursor (GtkText *self,
|
|||||||
int end_pos = priv->current_pos;
|
int end_pos = priv->current_pos;
|
||||||
int old_n_bytes = gtk_entry_buffer_get_bytes (get_buffer (self));
|
int old_n_bytes = gtk_entry_buffer_get_bytes (get_buffer (self));
|
||||||
|
|
||||||
gtk_text_reset_im_context (self);
|
|
||||||
|
|
||||||
if (!priv->editable)
|
if (!priv->editable)
|
||||||
{
|
{
|
||||||
gtk_widget_error_bell (GTK_WIDGET (self));
|
gtk_widget_error_bell (GTK_WIDGET (self));
|
||||||
@ -3939,6 +3938,8 @@ gtk_text_delete_from_cursor (GtkText *self,
|
|||||||
if (priv->selection_bound != priv->current_pos)
|
if (priv->selection_bound != priv->current_pos)
|
||||||
{
|
{
|
||||||
gtk_text_delete_selection (self);
|
gtk_text_delete_selection (self);
|
||||||
|
gtk_text_schedule_im_reset (self);
|
||||||
|
gtk_text_reset_im_context (self);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4003,6 +4004,11 @@ gtk_text_delete_from_cursor (GtkText *self,
|
|||||||
|
|
||||||
if (gtk_entry_buffer_get_bytes (get_buffer (self)) == old_n_bytes)
|
if (gtk_entry_buffer_get_bytes (get_buffer (self)) == old_n_bytes)
|
||||||
gtk_widget_error_bell (GTK_WIDGET (self));
|
gtk_widget_error_bell (GTK_WIDGET (self));
|
||||||
|
else
|
||||||
|
{
|
||||||
|
gtk_text_schedule_im_reset (self);
|
||||||
|
gtk_text_reset_im_context (self);
|
||||||
|
}
|
||||||
|
|
||||||
gtk_text_pend_cursor_blink (self);
|
gtk_text_pend_cursor_blink (self);
|
||||||
}
|
}
|
||||||
@ -4013,8 +4019,6 @@ gtk_text_backspace (GtkText *self)
|
|||||||
GtkTextPrivate *priv = gtk_text_get_instance_private (self);
|
GtkTextPrivate *priv = gtk_text_get_instance_private (self);
|
||||||
int prev_pos;
|
int prev_pos;
|
||||||
|
|
||||||
gtk_text_reset_im_context (self);
|
|
||||||
|
|
||||||
if (!priv->editable)
|
if (!priv->editable)
|
||||||
{
|
{
|
||||||
gtk_widget_error_bell (GTK_WIDGET (self));
|
gtk_widget_error_bell (GTK_WIDGET (self));
|
||||||
@ -4024,6 +4028,8 @@ gtk_text_backspace (GtkText *self)
|
|||||||
if (priv->selection_bound != priv->current_pos)
|
if (priv->selection_bound != priv->current_pos)
|
||||||
{
|
{
|
||||||
gtk_text_delete_selection (self);
|
gtk_text_delete_selection (self);
|
||||||
|
gtk_text_schedule_im_reset (self);
|
||||||
|
gtk_text_reset_im_context (self);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4068,6 +4074,9 @@ gtk_text_backspace (GtkText *self)
|
|||||||
{
|
{
|
||||||
gtk_editable_delete_text (GTK_EDITABLE (self), prev_pos, priv->current_pos);
|
gtk_editable_delete_text (GTK_EDITABLE (self), prev_pos, priv->current_pos);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gtk_text_schedule_im_reset (self);
|
||||||
|
gtk_text_reset_im_context (self);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -5533,7 +5533,7 @@ gtk_text_view_key_controller_im_update (GtkEventControllerKey *controller,
|
|||||||
can_insert = gtk_text_iter_can_insert (&iter, priv->editable);
|
can_insert = gtk_text_iter_can_insert (&iter, priv->editable);
|
||||||
|
|
||||||
priv->need_im_reset = TRUE;
|
priv->need_im_reset = TRUE;
|
||||||
if (!can_insert)
|
if (can_insert)
|
||||||
gtk_text_view_reset_im_context (text_view);
|
gtk_text_view_reset_im_context (text_view);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -6366,8 +6366,6 @@ gtk_text_view_move_cursor (GtkTextView *text_view,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
gtk_text_view_reset_im_context (text_view);
|
|
||||||
|
|
||||||
if (step == GTK_MOVEMENT_PAGES)
|
if (step == GTK_MOVEMENT_PAGES)
|
||||||
{
|
{
|
||||||
if (!gtk_text_view_scroll_pages (text_view, count, extend_selection))
|
if (!gtk_text_view_scroll_pages (text_view, count, extend_selection))
|
||||||
@ -6551,6 +6549,9 @@ gtk_text_view_move_cursor (GtkTextView *text_view,
|
|||||||
|
|
||||||
gtk_text_view_check_cursor_blink (text_view);
|
gtk_text_view_check_cursor_blink (text_view);
|
||||||
gtk_text_view_pend_cursor_blink (text_view);
|
gtk_text_view_pend_cursor_blink (text_view);
|
||||||
|
|
||||||
|
priv->need_im_reset = TRUE;
|
||||||
|
gtk_text_view_reset_im_context (text_view);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -6841,14 +6842,16 @@ gtk_text_view_delete_from_cursor (GtkTextView *text_view,
|
|||||||
|
|
||||||
priv = text_view->priv;
|
priv = text_view->priv;
|
||||||
|
|
||||||
gtk_text_view_reset_im_context (text_view);
|
|
||||||
|
|
||||||
if (type == GTK_DELETE_CHARS)
|
if (type == GTK_DELETE_CHARS)
|
||||||
{
|
{
|
||||||
/* Char delete deletes the selection, if one exists */
|
/* Char delete deletes the selection, if one exists */
|
||||||
if (gtk_text_buffer_delete_selection (get_buffer (text_view), TRUE,
|
if (gtk_text_buffer_delete_selection (get_buffer (text_view), TRUE,
|
||||||
priv->editable))
|
priv->editable))
|
||||||
return;
|
{
|
||||||
|
priv->need_im_reset = TRUE;
|
||||||
|
gtk_text_view_reset_im_context (text_view);
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
gtk_text_buffer_get_iter_at_mark (get_buffer (text_view), &insert,
|
gtk_text_buffer_get_iter_at_mark (get_buffer (text_view), &insert,
|
||||||
@ -6975,6 +6978,9 @@ gtk_text_view_delete_from_cursor (GtkTextView *text_view,
|
|||||||
{
|
{
|
||||||
gtk_widget_error_bell (GTK_WIDGET (text_view));
|
gtk_widget_error_bell (GTK_WIDGET (text_view));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
priv->need_im_reset = TRUE;
|
||||||
|
gtk_text_view_reset_im_context (text_view);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -6985,12 +6991,14 @@ gtk_text_view_backspace (GtkTextView *text_view)
|
|||||||
|
|
||||||
priv = text_view->priv;
|
priv = text_view->priv;
|
||||||
|
|
||||||
gtk_text_view_reset_im_context (text_view);
|
|
||||||
|
|
||||||
/* Backspace deletes the selection, if one exists */
|
/* Backspace deletes the selection, if one exists */
|
||||||
if (gtk_text_buffer_delete_selection (get_buffer (text_view), TRUE,
|
if (gtk_text_buffer_delete_selection (get_buffer (text_view), TRUE,
|
||||||
priv->editable))
|
priv->editable))
|
||||||
return;
|
{
|
||||||
|
priv->need_im_reset = TRUE;
|
||||||
|
gtk_text_view_reset_im_context (text_view);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
gtk_text_buffer_get_iter_at_mark (get_buffer (text_view),
|
gtk_text_buffer_get_iter_at_mark (get_buffer (text_view),
|
||||||
&insert,
|
&insert,
|
||||||
@ -7003,6 +7011,9 @@ gtk_text_view_backspace (GtkTextView *text_view)
|
|||||||
DV(g_print (G_STRLOC": scrolling onscreen\n"));
|
DV(g_print (G_STRLOC": scrolling onscreen\n"));
|
||||||
gtk_text_view_scroll_mark_onscreen (text_view,
|
gtk_text_view_scroll_mark_onscreen (text_view,
|
||||||
gtk_text_buffer_get_insert (get_buffer (text_view)));
|
gtk_text_buffer_get_insert (get_buffer (text_view)));
|
||||||
|
|
||||||
|
priv->need_im_reset = TRUE;
|
||||||
|
gtk_text_view_reset_im_context (text_view);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user