]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.1381: completion: cannot return to original text v9.1.1381
authorglepnir <glephunter@gmail.com>
Sun, 11 May 2025 11:48:33 +0000 (13:48 +0200)
committerChristian Brabandt <cb@256bit.org>
Sun, 11 May 2025 11:48:33 +0000 (13:48 +0200)
Problem:  Cannot return to the original text after selecting the next
          item when the currently selected item is the last one.
Solution: When continuing to move down past the last item, locate the
          original completion at the head/tail nodes of the completed
          linked list (glepnir).

closes: #17300

Signed-off-by: glepnir <glephunter@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
src/insexpand.c
src/testdir/test_ins_complete.vim
src/version.c

index 7bbff4ecb4fccff850dbf5eb8c5ec4acb13602f4..bb280fa4659b8ae98f27d51b4e1b1c968f10d1d4 100644 (file)
@@ -5236,9 +5236,8 @@ find_comp_when_fuzzy(void)
 
     if ((is_forward && compl_selected_item == compl_match_arraysize - 1)
            || (is_backward && compl_selected_item == 0))
-       return compl_first_match != compl_shown_match ?
-           (is_forward ? compl_shown_match->cp_next : compl_first_match) :
-           (compl_first_match->cp_prev ? compl_first_match->cp_prev : NULL);
+       return match_at_original_text(compl_first_match)
+                           ? compl_first_match : compl_first_match->cp_prev;
 
     if (is_forward)
        target_idx = compl_selected_item + 1;
index 6f342ae46695ce4987c3e81a9ef6cfa9f65e60e1..f7292ea34c0e8bac4c2cbc3ca0ca80526f9cfd01 100644 (file)
@@ -3387,11 +3387,15 @@ func Test_complete_opt_fuzzy()
     autocmd CompleteChanged * :call OnPumChange()
   augroup END
 
+  let g:change = 0
   func Omni_test(findstart, base)
     if a:findstart
       return col(".")
     endif
-    return [#{word: "foo"}, #{word: "foobar"}, #{word: "fooBaz"}, #{word: "foobala"}, #{word: "你好吗"}, #{word: "我好"}]
+    if g:change == 0
+      return [#{word: "foo"}, #{word: "foobar"}, #{word: "fooBaz"}, #{word: "foobala"}, #{word: "你好吗"}, #{word: "我好"}]
+    endif
+    return [#{word: "for i = .."}, #{word: "bar"}, #{word: "foo"}, #{word: "for .. ipairs"}, #{word: "for .. pairs"}]
   endfunc
 
   new
@@ -3488,6 +3492,15 @@ func Test_complete_opt_fuzzy()
   call feedkeys("Salpha bravio charlie\<CR>alpha\<C-X>\<C-N>\<C-X>\<C-N>\<C-X>\<C-N>\<ESC>", 'tx')
   call assert_equal('alpha bravio charlie', getline('.'))
 
+  set cot=fuzzy,menu,noinsert
+  call feedkeys(":let g:change=1\<CR>")
+  call feedkeys("S\<C-X>\<C-O>for\<C-N>\<C-N>\<C-N>", 'tx')
+  call assert_equal('for', getline('.'))
+  call feedkeys("S\<C-X>\<C-O>for\<C-P>", 'tx')
+  call assert_equal('for', getline('.'))
+  call feedkeys("S\<C-X>\<C-O>for\<C-P>\<C-P>", 'tx')
+  call assert_equal('for .. ipairs', getline('.'))
+
   " clean up
   set omnifunc=
   bw!
index aa4bc198e0032eb2ed5aeb7603a2ac1c2a1ab3e8..449a358b6b4681358190a890ea9eb331c6ec9560 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1381,
 /**/
     1380,
 /**/