mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
vim-patch:8.2.4501: with 'showbreak' set cursor displayed in wrong position
Problem: With 'showbreak' set and after the end of the line the cursor
may be displayed in the wrong position.
Solution: Do not apply 'showbreak' after the end of the line. (closes vim/vim#9884)
21efafe4c2
Co-authored-by: Bram Moolenaar <Bram@vim.org>
This commit is contained in:
parent
8b43091392
commit
6374120558
@ -444,9 +444,9 @@ int win_lbr_chartabsize(chartabsize_T *cts, int *headp)
|
|||||||
// May have to add something for 'breakindent' and/or 'showbreak'
|
// May have to add something for 'breakindent' and/or 'showbreak'
|
||||||
// string at start of line.
|
// string at start of line.
|
||||||
// Set *headp to the size of what we add.
|
// Set *headp to the size of what we add.
|
||||||
|
// Do not use 'showbreak' at the NUL after the text.
|
||||||
added = 0;
|
added = 0;
|
||||||
|
char *const sbr = c == NUL ? empty_option : (char *)get_showbreak_value(wp);
|
||||||
char *const sbr = (char *)get_showbreak_value(wp);
|
|
||||||
if ((*sbr != NUL || wp->w_p_bri) && wp->w_p_wrap && vcol != 0) {
|
if ((*sbr != NUL || wp->w_p_bri) && wp->w_p_wrap && vcol != 0) {
|
||||||
colnr_T sbrlen = 0;
|
colnr_T sbrlen = 0;
|
||||||
int numberwidth = win_col_off(wp);
|
int numberwidth = win_col_off(wp);
|
||||||
|
@ -8,6 +8,7 @@ source check.vim
|
|||||||
CheckOption breakindent
|
CheckOption breakindent
|
||||||
|
|
||||||
source view_util.vim
|
source view_util.vim
|
||||||
|
source screendump.vim
|
||||||
|
|
||||||
let s:input ="\tabcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOP"
|
let s:input ="\tabcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOP"
|
||||||
|
|
||||||
@ -889,6 +890,27 @@ func Test_window_resize_with_linebreak()
|
|||||||
%bw!
|
%bw!
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_cursor_position_with_showbreak()
|
||||||
|
CheckScreendump
|
||||||
|
|
||||||
|
let lines =<< trim END
|
||||||
|
vim9script
|
||||||
|
&signcolumn = 'yes'
|
||||||
|
&showbreak = '+ '
|
||||||
|
var leftcol: number = win_getid()->getwininfo()->get(0, {})->get('textoff')
|
||||||
|
repeat('x', &columns - leftcol - 1)->setline(1)
|
||||||
|
'second line'->setline(2)
|
||||||
|
END
|
||||||
|
call writefile(lines, 'XscriptShowbreak')
|
||||||
|
let buf = RunVimInTerminal('-S XscriptShowbreak', #{rows: 6})
|
||||||
|
|
||||||
|
call term_sendkeys(buf, "AX")
|
||||||
|
call VerifyScreenDump(buf, 'Test_cursor_position_with_showbreak', {})
|
||||||
|
|
||||||
|
call StopVimInTerminal(buf)
|
||||||
|
call delete('XscriptShowbreak')
|
||||||
|
endfunc
|
||||||
|
|
||||||
func Test_no_spurious_match()
|
func Test_no_spurious_match()
|
||||||
let s:input = printf('- y %s y %s', repeat('x', 50), repeat('x', 50))
|
let s:input = printf('- y %s y %s', repeat('x', 50), repeat('x', 50))
|
||||||
call s:test_windows('setl breakindent breakindentopt=list:-1 formatlistpat=^- hls')
|
call s:test_windows('setl breakindent breakindentopt=list:-1 formatlistpat=^- hls')
|
||||||
|
44
test/functional/legacy/breakindent_spec.lua
Normal file
44
test/functional/legacy/breakindent_spec.lua
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
local helpers = require('test.functional.helpers')(after_each)
|
||||||
|
local Screen = require('test.functional.ui.screen')
|
||||||
|
local clear = helpers.clear
|
||||||
|
local exec = helpers.exec
|
||||||
|
local feed = helpers.feed
|
||||||
|
|
||||||
|
before_each(clear)
|
||||||
|
|
||||||
|
describe('breakindent', function()
|
||||||
|
-- oldtest: Test_cursor_position_with_showbreak()
|
||||||
|
it('cursor shown at correct position with showbreak', function()
|
||||||
|
local screen = Screen.new(75, 6)
|
||||||
|
screen:set_default_attr_ids({
|
||||||
|
[0] = {bold = true, foreground = Screen.colors.Blue}, -- NonText
|
||||||
|
[1] = {background = Screen.colors.Grey, foreground = Screen.colors.DarkBlue}, -- SignColumn
|
||||||
|
[2] = {bold = true}, -- ModeMsg
|
||||||
|
})
|
||||||
|
screen:attach()
|
||||||
|
exec([[
|
||||||
|
let &signcolumn = 'yes'
|
||||||
|
let &showbreak = '+'
|
||||||
|
let leftcol = win_getid()->getwininfo()->get(0, {})->get('textoff')
|
||||||
|
eval repeat('x', &columns - leftcol - 1)->setline(1)
|
||||||
|
eval 'second line'->setline(2)
|
||||||
|
]])
|
||||||
|
screen:expect([[
|
||||||
|
{1: }^xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx |
|
||||||
|
{1: }second line |
|
||||||
|
{0:~ }|
|
||||||
|
{0:~ }|
|
||||||
|
{0:~ }|
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
feed('AX')
|
||||||
|
screen:expect([[
|
||||||
|
{1: }xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX|
|
||||||
|
{1: }^second line |
|
||||||
|
{0:~ }|
|
||||||
|
{0:~ }|
|
||||||
|
{0:~ }|
|
||||||
|
{2:-- INSERT --} |
|
||||||
|
]])
|
||||||
|
end)
|
||||||
|
end)
|
Loading…
Reference in New Issue
Block a user