forked from aniani/vim
patch 9.0.0702: incomplete testing cursor position with 'linebreak' set
Problem: Incomplete testing cursor position after change with 'linebreak' set. Solution: Add a test and move test cases together. (closes #11313)
This commit is contained in:
parent
8cf3459878
commit
30c0c467d6
@ -5,4 +5,4 @@
|
||||
|~| @73
|
||||
|~| @73
|
||||
|~| @73
|
||||
| +0#0000000&@56|1|,|7|8|-|8|7| @6|A|l@1|
|
||||
|E+0#ffffff16#e000002|4|9|0|:| |N|o| |f|o|l|d| |f|o|u|n|d| +0#0000000#ffffff0@37|1|,|7|8|-|8|7| @6|A|l@1|
|
||||
|
@ -134,22 +134,41 @@ func Test_linebreak_with_visual_operations()
|
||||
call s:close_windows()
|
||||
endfunc
|
||||
|
||||
" Test that cursor is drawn at correct position after an operator when
|
||||
" 'linebreak' is enabled.
|
||||
func Test_linebreak_reset_restore()
|
||||
CheckScreendump
|
||||
|
||||
" f_wincol() calls validate_cursor()
|
||||
let lines =<< trim END
|
||||
vim9script
|
||||
&linebreak = true
|
||||
&showcmd = true
|
||||
&showmode = false
|
||||
('a'->repeat(&columns - 10) .. ' ' .. 'b'->repeat(10) .. ' c')->setline(1)
|
||||
set linebreak showcmd noshowmode formatexpr=wincol()-wincol()
|
||||
call setline(1, repeat('a', &columns - 10) .. ' bbbbbbbbbb c')
|
||||
END
|
||||
call writefile(lines, 'XlbrResetRestore', 'D')
|
||||
let buf = RunVimInTerminal('-S XlbrResetRestore', {'rows': 8})
|
||||
|
||||
call term_sendkeys(buf, '$v$s')
|
||||
call term_sendkeys(buf, '$v$')
|
||||
call WaitForAssert({-> assert_equal(13, term_getcursor(buf)[1])})
|
||||
call term_sendkeys(buf, 'zo')
|
||||
call WaitForAssert({-> assert_equal(12, term_getcursor(buf)[1])})
|
||||
|
||||
call term_sendkeys(buf, '$v$')
|
||||
call WaitForAssert({-> assert_equal(13, term_getcursor(buf)[1])})
|
||||
call term_sendkeys(buf, 'gq')
|
||||
call WaitForAssert({-> assert_equal(12, term_getcursor(buf)[1])})
|
||||
|
||||
call term_sendkeys(buf, "$\<C-V>$")
|
||||
call WaitForAssert({-> assert_equal(13, term_getcursor(buf)[1])})
|
||||
call term_sendkeys(buf, 'I')
|
||||
call WaitForAssert({-> assert_equal(12, term_getcursor(buf)[1])})
|
||||
|
||||
call term_sendkeys(buf, "\<Esc>$v$")
|
||||
call WaitForAssert({-> assert_equal(13, term_getcursor(buf)[1])})
|
||||
call term_sendkeys(buf, 's')
|
||||
call WaitForAssert({-> assert_equal(12, term_getcursor(buf)[1])})
|
||||
call VerifyScreenDump(buf, 'Test_linebreak_reset_restore_1', {})
|
||||
|
||||
" clean up
|
||||
call term_sendkeys(buf, "\<Esc>")
|
||||
call StopVimInTerminal(buf)
|
||||
endfunc
|
||||
|
@ -1501,37 +1501,4 @@ func Test_switch_buffer_ends_visual_mode()
|
||||
exe 'bwipe!' buf2
|
||||
endfunc
|
||||
|
||||
" Test that cursor is drawn at correct position after an operator in Visual
|
||||
" mode when 'linebreak' and 'showcmd' are enabled.
|
||||
func Test_visual_operator_with_linebreak()
|
||||
CheckRunVimInTerminal
|
||||
|
||||
let lines =<< trim END
|
||||
set linebreak showcmd noshowmode
|
||||
call setline(1, repeat('a', &columns - 10) .. ' bbbbbbbbbb c')
|
||||
END
|
||||
call writefile(lines, 'XTest_visual_op_linebreak', 'D')
|
||||
|
||||
let buf = RunVimInTerminal('-S XTest_visual_op_linebreak', {'rows': 6})
|
||||
|
||||
call term_sendkeys(buf, '$v$')
|
||||
call WaitForAssert({-> assert_equal(13, term_getcursor(buf)[1])})
|
||||
call term_sendkeys(buf, 'zo')
|
||||
call WaitForAssert({-> assert_equal(12, term_getcursor(buf)[1])})
|
||||
|
||||
call term_sendkeys(buf, "$\<C-V>$")
|
||||
call WaitForAssert({-> assert_equal(13, term_getcursor(buf)[1])})
|
||||
call term_sendkeys(buf, 'I')
|
||||
call WaitForAssert({-> assert_equal(12, term_getcursor(buf)[1])})
|
||||
|
||||
call term_sendkeys(buf, "\<Esc>$v$")
|
||||
call WaitForAssert({-> assert_equal(13, term_getcursor(buf)[1])})
|
||||
call term_sendkeys(buf, 's')
|
||||
call WaitForAssert({-> assert_equal(12, term_getcursor(buf)[1])})
|
||||
|
||||
" clean up
|
||||
call term_sendkeys(buf, "\<Esc>")
|
||||
call StopVimInTerminal(buf)
|
||||
endfunc
|
||||
|
||||
" vim: shiftwidth=2 sts=2 expandtab
|
||||
|
@ -699,6 +699,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
702,
|
||||
/**/
|
||||
701,
|
||||
/**/
|
||||
|
Loading…
x
Reference in New Issue
Block a user