text: Make editable signals work again

Since the big editable reorg, GtkText was not emitting
::insert-text and ::delete-text, as is expected of
editables. We want to use those signals for a11y
change notification, so make them work again.
This commit is contained in:
Matthias Clasen 2020-10-13 00:49:10 -04:00
parent 81440675af
commit a02c50e72f

View File

@ -3377,7 +3377,7 @@ gtk_text_delete_selection (GtkText *self)
int start_pos = MIN (priv->selection_bound, priv->current_pos); int start_pos = MIN (priv->selection_bound, priv->current_pos);
int end_pos = MAX (priv->selection_bound, priv->current_pos); int end_pos = MAX (priv->selection_bound, priv->current_pos);
gtk_text_delete_text (self, start_pos, end_pos); gtk_editable_delete_text (self, start_pos, end_pos);
} }
static void static void
@ -3872,7 +3872,7 @@ gtk_text_insert_at_cursor (GtkText *self,
if (priv->editable) if (priv->editable)
{ {
gtk_text_reset_im_context (self); gtk_text_reset_im_context (self);
gtk_text_insert_text (self, str, -1, &pos); gtk_editable_insert_text (GTK_EDITABLE (self), str, -1, &pos);
gtk_text_set_selection_bounds (self, pos, pos); gtk_text_set_selection_bounds (self, pos, pos);
} }
} }
@ -3905,7 +3905,7 @@ gtk_text_delete_from_cursor (GtkText *self,
{ {
case GTK_DELETE_CHARS: case GTK_DELETE_CHARS:
end_pos = gtk_text_move_logically (self, priv->current_pos, count); end_pos = gtk_text_move_logically (self, priv->current_pos, count);
gtk_text_delete_text (self, MIN (start_pos, end_pos), MAX (start_pos, end_pos)); gtk_editable_delete_text (GTK_EDITABLE (self), MIN (start_pos, end_pos), MAX (start_pos, end_pos));
break; break;
case GTK_DELETE_WORDS: case GTK_DELETE_WORDS:
@ -3935,21 +3935,21 @@ gtk_text_delete_from_cursor (GtkText *self,
count--; count--;
} }
gtk_text_delete_text (self, start_pos, end_pos); gtk_editable_delete_text (self, start_pos, end_pos);
break; break;
case GTK_DELETE_DISPLAY_LINE_ENDS: case GTK_DELETE_DISPLAY_LINE_ENDS:
case GTK_DELETE_PARAGRAPH_ENDS: case GTK_DELETE_PARAGRAPH_ENDS:
if (count < 0) if (count < 0)
gtk_text_delete_text (self, 0, priv->current_pos); gtk_editable_delete_text (self, 0, priv->current_pos);
else else
gtk_text_delete_text (self, priv->current_pos, -1); gtk_editable_delete_text (self, priv->current_pos, -1);
break; break;
case GTK_DELETE_DISPLAY_LINES: case GTK_DELETE_DISPLAY_LINES:
case GTK_DELETE_PARAGRAPHS: case GTK_DELETE_PARAGRAPHS:
gtk_text_delete_text (self, 0, -1); gtk_editable_delete_text (self, 0, -1);
break; break;
case GTK_DELETE_WHITESPACE: case GTK_DELETE_WHITESPACE:
@ -4009,12 +4009,12 @@ gtk_text_backspace (GtkText *self)
G_NORMALIZE_NFD); G_NORMALIZE_NFD);
len = g_utf8_strlen (normalized_text, -1); len = g_utf8_strlen (normalized_text, -1);
gtk_text_delete_text (self, prev_pos, priv->current_pos); gtk_editable_delete_text (self, prev_pos, priv->current_pos);
if (len > 1) if (len > 1)
{ {
int pos = priv->current_pos; int pos = priv->current_pos;
gtk_text_insert_text (self, normalized_text, gtk_editable_insert_text (self, normalized_text,
g_utf8_offset_to_pointer (normalized_text, len - 1) - normalized_text, g_utf8_offset_to_pointer (normalized_text, len - 1) - normalized_text,
&pos); &pos);
gtk_text_set_selection_bounds (self, pos, pos); gtk_text_set_selection_bounds (self, pos, pos);
@ -4025,7 +4025,7 @@ gtk_text_backspace (GtkText *self)
} }
else else
{ {
gtk_text_delete_text (self, prev_pos, priv->current_pos); gtk_editable_delete_text (self, prev_pos, priv->current_pos);
} }
} }
else else
@ -4239,9 +4239,9 @@ gtk_text_delete_surrounding_cb (GtkIMContext *context,
GtkTextPrivate *priv = gtk_text_get_instance_private (self); GtkTextPrivate *priv = gtk_text_get_instance_private (self);
if (priv->editable) if (priv->editable)
gtk_text_delete_text (self, gtk_editable_delete_text (self,
priv->current_pos + offset, priv->current_pos + offset,
priv->current_pos + offset + n_chars); priv->current_pos + offset + n_chars);
return TRUE; return TRUE;
} }
@ -4275,7 +4275,7 @@ gtk_text_enter_text (GtkText *self,
} }
tmp_pos = priv->current_pos; tmp_pos = priv->current_pos;
gtk_text_insert_text (self, str, strlen (str), &tmp_pos); gtk_editable_insert_text (self, str, strlen (str), &tmp_pos);
gtk_text_set_selection_bounds (self, tmp_pos, tmp_pos); gtk_text_set_selection_bounds (self, tmp_pos, tmp_pos);
priv->need_im_reset = old_need_im_reset; priv->need_im_reset = old_need_im_reset;
@ -5166,7 +5166,7 @@ gtk_text_delete_whitespace (GtkText *self)
end++; end++;
if (start != end) if (start != end)
gtk_text_delete_text (self, start, end); gtk_editable_delete_text (self, start, end);
} }
@ -5234,7 +5234,7 @@ paste_received (GObject *clipboard,
gtk_text_delete_selection (self); gtk_text_delete_selection (self);
pos = priv->current_pos; pos = priv->current_pos;
gtk_text_insert_text (self, text, length, &pos); gtk_editable_insert_text (self, text, length, &pos);
gtk_text_set_selection_bounds (self, pos, pos); gtk_text_set_selection_bounds (self, pos, pos);
end_change (self); end_change (self);
@ -5459,9 +5459,9 @@ gtk_text_set_text (GtkText *self,
begin_change (self); begin_change (self);
g_object_freeze_notify (G_OBJECT (self)); g_object_freeze_notify (G_OBJECT (self));
gtk_text_delete_text (self, 0, -1); gtk_editable_delete_text (self, 0, -1);
tmp_pos = 0; tmp_pos = 0;
gtk_text_insert_text (self, text, strlen (text), &tmp_pos); gtk_editable_insert_text (self, text, strlen (text), &tmp_pos);
g_object_thaw_notify (G_OBJECT (self)); g_object_thaw_notify (G_OBJECT (self));
end_change (self); end_change (self);
@ -6245,7 +6245,7 @@ gtk_text_drag_drop (GtkDropTarget *dest,
drop_position < priv->selection_bound || drop_position < priv->selection_bound ||
drop_position > priv->current_pos) drop_position > priv->current_pos)
{ {
gtk_text_insert_text (self, str, length, &drop_position); gtk_editable_insert_text (self, str, length, &drop_position);
} }
else else
{ {
@ -6254,7 +6254,7 @@ gtk_text_drag_drop (GtkDropTarget *dest,
begin_change (self); begin_change (self);
gtk_text_delete_selection (self); gtk_text_delete_selection (self);
pos = MIN (priv->selection_bound, priv->current_pos); pos = MIN (priv->selection_bound, priv->current_pos);
gtk_text_insert_text (self, str, length, &pos); gtk_editable_insert_text (self, str, length, &pos);
end_change (self); end_change (self);
} }
@ -6816,7 +6816,7 @@ emoji_picked (GtkEmojiChooser *chooser,
gtk_text_delete_selection (self); gtk_text_delete_selection (self);
pos = priv->current_pos; pos = priv->current_pos;
gtk_text_insert_text (self, text, -1, &pos); gtk_editable_insert_text (self, text, -1, &pos);
gtk_text_set_selection_bounds (self, pos, pos); gtk_text_set_selection_bounds (self, pos, pos);
end_change (self); end_change (self);
} }