]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.0543: Behavior of CursorMovedC is strange v9.1.0543
authorzeertzjq <zeertzjq@outlook.com>
Sun, 7 Jul 2024 18:48:25 +0000 (20:48 +0200)
committerChristian Brabandt <cb@256bit.org>
Sun, 7 Jul 2024 18:48:25 +0000 (20:48 +0200)
Problem:  Behavior of CursorMovedC is strange.
Solution: Also trigger when the cmdline has changed.
          (zeertzjq)

fixes: #15069
closes: #15071

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
runtime/doc/autocmd.txt
src/ex_getln.c
src/testdir/test_autocmd.vim
src/version.c

index 34e9535db9bd4c8c69d1beb6c88818438086ccb1..a5dce7db8f5379d73d70defda3c37d1c35118570 100644 (file)
@@ -1,4 +1,4 @@
-*autocmd.txt*   For Vim version 9.1.  Last change: 2024 Jul 06
+*autocmd.txt*   For Vim version 9.1.  Last change: 2024 Jul 07
 
 
                  VIM REFERENCE MANUAL    by Bram Moolenaar
@@ -751,9 +751,8 @@ CursorMoved                 After the cursor was moved in Normal or Visual
                                that is slow.
                                                        *CursorMovedC*
 CursorMovedC                   After the cursor was moved in the command
-                               line while the text in the command line hasn't
-                               changed.  Be careful not to mess up the
-                               command line, it may cause Vim to lock up.
+                               line.  Be careful not to mess up the command
+                               line, it may cause Vim to lock up.
                                <afile> is set to a single character,
                                indicating the type of command-line.
                                |cmdwin-char|
index 51a38e583e11fc7f3b0ec8eac127f854c8cf132a..1b3a699a21eab1ba44ebd1f7f36714efffcdcf25 100644 (file)
@@ -2480,13 +2480,13 @@ cmdline_not_changed:
            trigger_cmd_autocmd(cmdline_type, EVENT_CURSORMOVEDC);
            prev_cmdpos = ccline.cmdpos;
        }
+
 #ifdef FEAT_SEARCH_EXTRA
        if (!is_state.incsearch_postponed)
            continue;
 #endif
 
 cmdline_changed:
-       prev_cmdpos = ccline.cmdpos;
 #ifdef FEAT_SEARCH_EXTRA
        // If the window changed incremental search state is not valid.
        if (is_state.winid != curwin->w_id)
@@ -2496,6 +2496,13 @@ cmdline_changed:
        if (trigger_cmdlinechanged)
            trigger_cmd_autocmd(cmdline_type, EVENT_CMDLINECHANGED);
 
+       // Trigger CursorMovedC autocommands.
+       if (ccline.cmdpos != prev_cmdpos)
+       {
+           trigger_cmd_autocmd(cmdline_type, EVENT_CURSORMOVEDC);
+           prev_cmdpos = ccline.cmdpos;
+       }
+
 #ifdef FEAT_SEARCH_EXTRA
        if (xpc.xp_context == EXPAND_NOTHING && (KeyTyped || vpeekc() == NUL))
            may_do_incsearch_highlighting(firstc, count, &is_state);
index 371abcbd752e33a711156a9f066daf8a7d49efce..bcbddf9789213f185d032d73d53f0a57e6213b8d 100644 (file)
@@ -2099,21 +2099,30 @@ func Test_Cmdline()
 
   au! CursorMovedC : let g:pos += [getcmdpos()]
   let g:pos = []
+  call feedkeys(":foo bar baz\<C-W>\<C-W>\<C-W>\<Esc>", 'xt')
+  call assert_equal([2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 9, 5, 1], g:pos)
+  let g:pos = []
+  call feedkeys(":hello\<C-B>\<Esc>", 'xt')
+  call assert_equal([2, 3, 4, 5, 6, 1], g:pos)
+  let g:pos = []
+  call feedkeys(":hello\<C-U>\<Esc>", 'xt')
+  call assert_equal([2, 3, 4, 5, 6, 1], g:pos)
+  let g:pos = []
   call feedkeys(":hello\<Left>\<C-R>=''\<CR>\<Left>\<Right>\<Esc>", 'xt')
-  call assert_equal([5, 4, 5], g:pos)
+  call assert_equal([2, 3, 4, 5, 6, 5, 4, 5], g:pos)
   let g:pos = []
   call feedkeys(":12345678\<C-R>=setcmdpos(3)??''\<CR>\<Esc>", 'xt')
-  call assert_equal([3], g:pos)
+  call assert_equal([2, 3, 4, 5, 6, 7, 8, 9, 3], g:pos)
   let g:pos = []
   call feedkeys(":12345678\<C-R>=setcmdpos(3)??''\<CR>\<Left>\<Esc>", 'xt')
-  call assert_equal([3, 2], g:pos)
+  call assert_equal([2, 3, 4, 5, 6, 7, 8, 9, 3, 2], g:pos)
   au! CursorMovedC
 
   " setcmdpos() is no-op inside an autocommand
   au! CursorMovedC : let g:pos += [getcmdpos()] | call setcmdpos(1)
   let g:pos = []
   call feedkeys(":hello\<Left>\<Left>\<Esc>", 'xt')
-  call assert_equal([5, 4], g:pos)
+  call assert_equal([2, 3, 4, 5, 6, 5, 4], g:pos)
   au! CursorMovedC
 
   unlet g:entered
index dffc63c1f41abf8019edd9677a2da94436447314..6f7c2c05ffcc0cc6b37042e365129615d43cc4fd 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    543,
 /**/
     542,
 /**/