[gtksourceview/wip/chergert/vim] more sentence work
- From: Christian Hergert <chergert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtksourceview/wip/chergert/vim] more sentence work
- Date: Sun, 24 Oct 2021 19:17:47 +0000 (UTC)
commit c158c24e621b059b63da5fba592ccf8632939a31
Author: Christian Hergert <chergert redhat com>
Date: Sun Oct 24 12:17:43 2021 -0700
more sentence work
gtksourceview/vim/gtk-source-vim-motion.c | 206 +++++++-----------------------
1 file changed, 43 insertions(+), 163 deletions(-)
---
diff --git a/gtksourceview/vim/gtk-source-vim-motion.c b/gtksourceview/vim/gtk-source-vim-motion.c
index 2821ea5b..ca2bdbb3 100644
--- a/gtksourceview/vim/gtk-source-vim-motion.c
+++ b/gtksourceview/vim/gtk-source-vim-motion.c
@@ -799,188 +799,69 @@ motion_backward_paragraph_start (GtkTextIter *iter,
return !gtk_text_iter_equal (&before, iter);
}
-typedef enum
-{
- SENTENCE_OK,
- SENTENCE_PARA,
- SENTENCE_FAILED,
-} SentenceStatus;
-
static gboolean
-sentence_end_chars (gunichar ch,
- gpointer user_data)
-{
- switch (ch)
- {
- case '!':
- case '.':
- case '?':
- return TRUE;
-
- default:
- return FALSE;
- }
-}
-
-static SentenceStatus
-backward_sentence_end (GtkTextIter *iter,
- GtkSourceVimMotion *state)
+motion_backward_sentence_start (GtkTextIter *iter,
+ GtkSourceVimMotion *state)
{
- GtkTextIter end_bounds;
- GtkTextIter start_bounds;
- gboolean found_para;
-
- end_bounds = *iter;
- start_bounds = *iter;
- found_para = motion_backward_paragraph_start (&start_bounds, state);
-
- if (!found_para)
- {
- gtk_text_buffer_get_start_iter (gtk_text_iter_get_buffer (iter),
- &start_bounds);
- }
-
- while ((gtk_text_iter_compare (iter, &start_bounds) > 0) &&
- gtk_text_iter_backward_char (iter))
- {
- if (gtk_text_iter_backward_find_char (iter, sentence_end_chars, NULL, &end_bounds))
- {
- GtkTextIter copy = *iter;
-
- while (gtk_text_iter_forward_char (©) &&
- gtk_text_iter_compare (©, &end_bounds) < 0)
- {
- gunichar ch = gtk_text_iter_get_char (©);
-
- switch (ch)
- {
- case ']':
- case ')':
- case '"':
- case '\'':
- continue;
-
- case ' ':
- case '\n':
- *iter = copy;
- return SENTENCE_OK;
-
- default:
- break;
- }
- }
- }
- }
-
- *iter = start_bounds;
-
- if (found_para)
- return SENTENCE_PARA;
-
- return SENTENCE_FAILED;
+ return gtk_text_iter_backward_sentence_start (iter);
}
static gboolean
-motion_forward_sentence_end (GtkTextIter *iter,
- GtkSourceVimMotion *state)
+motion_forward_sentence_start (GtkTextIter *iter,
+ GtkSourceVimMotion *state)
{
- GtkTextIter end_bounds;
- gboolean found_para;
-
- end_bounds = *iter;
- found_para = motion_forward_paragraph_end (&end_bounds, state);
+ GtkTextIter before = *iter;
+ gboolean last_was_newline = FALSE;
- if (!found_para)
+ do
{
- gtk_text_buffer_get_end_iter (gtk_text_iter_get_buffer (iter),
- &end_bounds);
- }
+ if (!gtk_text_iter_forward_char (iter))
+ break;
- while ((gtk_text_iter_compare (iter, &end_bounds) < 0) &&
- gtk_text_iter_forward_char (iter))
- {
- if (gtk_text_iter_forward_find_char (iter, sentence_end_chars, NULL, &end_bounds))
+ switch (gtk_text_iter_get_char (iter))
{
- GtkTextIter copy = *iter;
-
- while (gtk_text_iter_forward_char (©) &&
- gtk_text_iter_compare (©, &end_bounds) < 0)
- {
- gunichar ch = gtk_text_iter_get_char (©);
- gboolean invalid = FALSE;
-
- switch (ch)
+ case '\n':
+ /* \n\n or more is a paragraph break */
+ if (last_was_newline)
{
- case ']':
- case ')':
- case '"':
- case '\'':
- continue;
+ while (gtk_text_iter_ends_line (iter) &&
+ gtk_text_iter_forward_char (iter)) { /* do nothing */ }
- case ' ':
- case '\n':
- *iter = copy;
- return SENTENCE_OK;
+ while (!gtk_text_iter_ends_line (iter) &&
+ g_unichar_isspace (gtk_text_iter_get_char (iter)))
+ {
+ if (!gtk_text_iter_forward_char (iter))
+ break;
+ }
- default:
- invalid = TRUE;
- break;
+ return TRUE;
}
- if (invalid)
- break;
- }
- }
- }
-
- *iter = end_bounds;
-
- if (found_para)
- return SENTENCE_PARA;
-
- return SENTENCE_FAILED;
-}
-
-static gboolean
-motion_backward_sentence_start (GtkTextIter *iter,
- GtkSourceVimMotion *state)
-{
- GtkTextIter tmp;
- SentenceStatus status;
-
- tmp = *iter;
- status = backward_sentence_end (&tmp, state);
-
- switch (status)
- {
- case SENTENCE_PARA:
- case SENTENCE_OK:
- {
- GtkTextIter copy = tmp;
+ last_was_newline = TRUE;
+ break;
- /*
- * try to work forward to first non-whitespace char.
- * if we land where we started, discard the walk.
- */
- while (g_unichar_isspace (gtk_text_iter_get_char (©)))
- {
- if (!gtk_text_iter_forward_char (©))
- break;
- }
+ case '.':
+ case '!':
+ case '?':
+ do
+ {
+ if (!gtk_text_iter_forward_char (iter))
+ return TRUE;
- if (gtk_text_iter_compare (©, iter) < 0)
- tmp = copy;
+ if (g_unichar_isspace (gtk_text_iter_get_char (iter)))
+ continue;
- *iter = tmp;
+ return TRUE;
+ } while (TRUE);
+ break;
- return TRUE;
+ default:
+ last_was_newline = FALSE;
+ break;
}
+ } while (TRUE);
- case SENTENCE_FAILED:
- default:
- gtk_text_buffer_get_start_iter (gtk_text_iter_get_buffer (iter), iter);
- return FALSE;
- }
+ return !gtk_text_iter_equal (&before, iter);
}
GtkSourceVimState *
@@ -1167,8 +1048,7 @@ gtk_source_vim_motion_handle_keypress (GtkSourceVimState *state,
return gtk_source_vim_motion_complete (self, motion_backward_sentence_start);
case GDK_KEY_parenright:
- /* this needs to be chagned to sentence start */
- return gtk_source_vim_motion_complete (self, motion_forward_sentence_end);
+ return gtk_source_vim_motion_complete (self, motion_forward_sentence_start);
case GDK_KEY_braceleft:
return gtk_source_vim_motion_complete (self, motion_backward_paragraph_start);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]