patch 9.1.0940: Wrong cursor shape with "gq" and 'indentexpr' executes :normal
Problem: Wrong cursor shape with "gq" and 'indentexpr' executes :normal
Solution: Update cursor and mouse shape after restoring old_State.
(zeertzjq)
closes: #16241
Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
Solution: Update cursor and mouse shape after restoring old_State.
This commit is contained in:
committed by
Christian Brabandt
parent
9c3330de28
commit
6c3027744e
@ -1,5 +1,8 @@
|
|||||||
" Test for various indent options
|
" Test for various indent options
|
||||||
|
|
||||||
|
source shared.vim
|
||||||
|
source check.vim
|
||||||
|
|
||||||
func Test_preserveindent()
|
func Test_preserveindent()
|
||||||
new
|
new
|
||||||
" Test for autoindent copying indent from the previous line
|
" Test for autoindent copying indent from the previous line
|
||||||
@ -300,4 +303,50 @@ func Test_indent_overflow_count2()
|
|||||||
close!
|
close!
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
" Test that mouse shape is restored to Normal mode after using "gq" when
|
||||||
|
" 'indentexpr' executes :normal.
|
||||||
|
func Test_indent_norm_with_gq()
|
||||||
|
CheckFeature mouseshape
|
||||||
|
CheckCanRunGui
|
||||||
|
|
||||||
|
let lines =<< trim END
|
||||||
|
func Indent()
|
||||||
|
exe "normal! \<Ignore>"
|
||||||
|
return 0
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
setlocal indentexpr=Indent()
|
||||||
|
END
|
||||||
|
call writefile(lines, 'Xindentexpr.vim', 'D')
|
||||||
|
|
||||||
|
let lines =<< trim END
|
||||||
|
vim9script
|
||||||
|
var mouse_shapes = []
|
||||||
|
|
||||||
|
setline(1, [repeat('a', 80), repeat('b', 80)])
|
||||||
|
|
||||||
|
feedkeys('ggVG')
|
||||||
|
timer_start(50, (_) => {
|
||||||
|
mouse_shapes += [getmouseshape()]
|
||||||
|
timer_start(50, (_) => {
|
||||||
|
feedkeys('gq')
|
||||||
|
timer_start(50, (_) => {
|
||||||
|
mouse_shapes += [getmouseshape()]
|
||||||
|
timer_start(50, (_) => {
|
||||||
|
writefile(mouse_shapes, 'Xmouseshapes')
|
||||||
|
quit!
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
END
|
||||||
|
call writefile(lines, 'Xmouseshape.vim', 'D')
|
||||||
|
|
||||||
|
call RunVim([], [], "-g -S Xindentexpr.vim -S Xmouseshape.vim")
|
||||||
|
call WaitForAssert({-> assert_equal(['rightup-arrow', 'arrow'],
|
||||||
|
\ readfile('Xmouseshapes'))}, 300)
|
||||||
|
|
||||||
|
call delete('Xmouseshapes')
|
||||||
|
endfunc
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
|||||||
@ -1163,13 +1163,24 @@ format_lines(
|
|||||||
State = MODE_INSERT; // for open_line()
|
State = MODE_INSERT; // for open_line()
|
||||||
smd_save = p_smd;
|
smd_save = p_smd;
|
||||||
p_smd = FALSE;
|
p_smd = FALSE;
|
||||||
|
|
||||||
insertchar(NUL, INSCHAR_FORMAT
|
insertchar(NUL, INSCHAR_FORMAT
|
||||||
+ (do_comments ? INSCHAR_DO_COM : 0)
|
+ (do_comments ? INSCHAR_DO_COM : 0)
|
||||||
+ (do_comments && do_comments_list
|
+ (do_comments && do_comments_list
|
||||||
? INSCHAR_COM_LIST : 0)
|
? INSCHAR_COM_LIST : 0)
|
||||||
+ (avoid_fex ? INSCHAR_NO_FEX : 0), second_indent);
|
+ (avoid_fex ? INSCHAR_NO_FEX : 0), second_indent);
|
||||||
|
|
||||||
State = old_State;
|
State = old_State;
|
||||||
p_smd = smd_save;
|
p_smd = smd_save;
|
||||||
|
// Cursor and mouse shape shapes may have been updated (e.g. by
|
||||||
|
// :normal) in insertchar(), so they need to be updated here.
|
||||||
|
#ifdef CURSOR_SHAPE
|
||||||
|
ui_cursor_shape();
|
||||||
|
#endif
|
||||||
|
#ifdef FEAT_MOUSESHAPE
|
||||||
|
update_mouseshape(-1);
|
||||||
|
#endif
|
||||||
|
|
||||||
second_indent = -1;
|
second_indent = -1;
|
||||||
// at end of par.: need to set indent of next par.
|
// at end of par.: need to set indent of next par.
|
||||||
need_set_indent = is_end_par;
|
need_set_indent = is_end_par;
|
||||||
|
|||||||
@ -704,6 +704,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
940,
|
||||||
/**/
|
/**/
|
||||||
939,
|
939,
|
||||||
/**/
|
/**/
|
||||||
|
|||||||
Reference in New Issue
Block a user