Merge pull request #23187 from luukvbaal/statuscolumn

fix(column): rebuild status column when sign column is invalid
This commit is contained in:
Lewis Russell 2023-04-21 11:46:30 +01:00 committed by GitHub
commit 3e41121e86
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 65 additions and 24 deletions

View File

@ -1397,10 +1397,6 @@ static void win_update(win_T *wp, DecorProviders *providers)
if (type >= UPD_NOT_VALID) { if (type >= UPD_NOT_VALID) {
wp->w_redr_status = true; wp->w_redr_status = true;
wp->w_lines_valid = 0; wp->w_lines_valid = 0;
if (*wp->w_p_stc != NUL) {
wp->w_nrwidth_line_count = 0; // make sure width is reset
wp->w_statuscol_line_count = 0; // make sure width is re-estimated
}
} }
// Window is zero-height: Only need to draw the separator // Window is zero-height: Only need to draw the separator
@ -2528,6 +2524,7 @@ int number_width(win_T *wp)
// reset for 'statuscolumn' // reset for 'statuscolumn'
if (*wp->w_p_stc != NUL) { if (*wp->w_p_stc != NUL) {
wp->w_statuscol_line_count = 0; // make sure width is re-estimated
wp->w_nrwidth_width = (wp->w_p_nu || wp->w_p_rnu) * (int)wp->w_p_nuw; wp->w_nrwidth_width = (wp->w_p_nu || wp->w_p_rnu) * (int)wp->w_p_nuw;
return wp->w_nrwidth_width; return wp->w_nrwidth_width;
} }

View File

@ -2189,9 +2189,8 @@ static const char *set_bool_option(const int opt_idx, char *const varp, const in
errmsg = did_set_spelllang(curwin); errmsg = did_set_spelllang(curwin);
} }
} else if ((int *)varp == &curwin->w_p_nu && *curwin->w_p_stc != NUL) { } else if ((int *)varp == &curwin->w_p_nu && *curwin->w_p_stc != NUL) {
// When 'statuscolumn' is set and 'number' is changed: // When 'number' is changed and 'statuscolumn' is set, make sure width is reset.
curwin->w_nrwidth_line_count = 0; // make sure width is reset curwin->w_nrwidth_line_count = 0;
curwin->w_statuscol_line_count = 0; // make sure width is re-estimated
} }
if ((int *)varp == &curwin->w_p_arab) { if ((int *)varp == &curwin->w_p_arab) {
@ -5530,6 +5529,13 @@ int win_signcol_configured(win_T *wp, int *is_fixed)
if (*scl == 'n' if (*scl == 'n'
&& (*(scl + 1) == 'o' || (*(scl + 1) == 'u' && (*(scl + 1) == 'o' || (*(scl + 1) == 'u'
&& (wp->w_p_nu || wp->w_p_rnu)))) { && (wp->w_p_nu || wp->w_p_rnu)))) {
if (!wp->w_buffer->b_signcols.valid) {
FOR_ALL_WINDOWS_IN_TAB(win, curtab) {
if (*win->w_p_stc != NUL) {
win->w_nrwidth_line_count = 0;
}
}
}
if (*wp->w_p_stc != NUL) { if (*wp->w_p_stc != NUL) {
buf_signcols(wp->w_buffer, 0); buf_signcols(wp->w_buffer, 0);
} }

View File

@ -1202,8 +1202,8 @@ static void did_set_statusline(win_T *win, char **varp, char **gvarp, const char
if (varp == &p_ruf) { // reset ru_wid first if (varp == &p_ruf) { // reset ru_wid first
ru_wid = 0; ru_wid = 0;
} else if (varp == &win->w_p_stc) { } else if (varp == &win->w_p_stc) {
win->w_nrwidth_line_count = 0; // make sure width is reset // reset 'statuscolumn' width
win->w_statuscol_line_count = 0; // make sure width is re-estimated win->w_nrwidth_line_count = 0;
} }
char *s = *varp; char *s = *varp;
if (varp == &p_ruf && *s == '%') { if (varp == &p_ruf && *s == '%') {

View File

@ -15,6 +15,7 @@ describe('statuscolumn', function()
clear('--cmd', 'set number nuw=1 | call setline(1, repeat(["aaaaa"], 16)) | norm GM') clear('--cmd', 'set number nuw=1 | call setline(1, repeat(["aaaaa"], 16)) | norm GM')
screen = Screen.new() screen = Screen.new()
screen:attach() screen:attach()
exec_lua('ns = vim.api.nvim_create_namespace("")')
end) end)
it("fails with invalid 'statuscolumn'", function() it("fails with invalid 'statuscolumn'", function()
@ -352,7 +353,6 @@ describe('statuscolumn', function()
]]) ]])
-- Status column is re-evaluated for virt_lines, buffer line, and wrapped line -- Status column is re-evaluated for virt_lines, buffer line, and wrapped line
exec_lua([[ exec_lua([[
local ns = vim.api.nvim_create_namespace("ns")
vim.api.nvim_buf_set_extmark(0, ns, 5, 0, { vim.api.nvim_buf_set_extmark(0, ns, 5, 0, {
virt_lines_above = true, virt_lines = {{{"virt_line above", ""}}} }) virt_lines_above = true, virt_lines = {{{"virt_line above", ""}}} })
vim.api.nvim_buf_set_extmark(0, ns, 4, 0, { virt_lines = {{{"virt_line", ""}}} }) vim.api.nvim_buf_set_extmark(0, ns, 4, 0, { virt_lines = {{{"virt_line", ""}}} })
@ -377,7 +377,6 @@ describe('statuscolumn', function()
]]) ]])
-- Also test virt_lines at the end of buffer -- Also test virt_lines at the end of buffer
exec_lua([[ exec_lua([[
local ns = vim.api.nvim_create_namespace("ns")
vim.api.nvim_buf_set_extmark(0, ns, 15, 0, { virt_lines = {{{"END", ""}}} }) vim.api.nvim_buf_set_extmark(0, ns, 15, 0, { virt_lines = {{{"END", ""}}} })
]]) ]])
feed('Gzz') feed('Gzz')
@ -400,7 +399,6 @@ describe('statuscolumn', function()
-- Also test virt_lines when 'cpoptions' includes "n" -- Also test virt_lines when 'cpoptions' includes "n"
exec_lua([[ exec_lua([[
vim.opt.cpoptions:append("n") vim.opt.cpoptions:append("n")
local ns = vim.api.nvim_create_namespace("ns")
vim.api.nvim_buf_set_extmark(0, ns, 14, 0, { virt_lines = {{{"virt_line1", ""}}} }) vim.api.nvim_buf_set_extmark(0, ns, 14, 0, { virt_lines = {{{"virt_line1", ""}}} })
vim.api.nvim_buf_set_extmark(0, ns, 14, 0, { virt_lines = {{{"virt_line2", ""}}} }) vim.api.nvim_buf_set_extmark(0, ns, 14, 0, { virt_lines = {{{"virt_line2", ""}}} })
]]) ]])
@ -481,7 +479,6 @@ describe('statuscolumn', function()
for _ = 0,8 do command('norm zfjzo') end for _ = 0,8 do command('norm zfjzo') end
-- 'statuscolumn' is not drawn for `virt_lines_leftcol` lines -- 'statuscolumn' is not drawn for `virt_lines_leftcol` lines
exec_lua([[ exec_lua([[
local ns = vim.api.nvim_create_namespace("ns")
vim.api.nvim_buf_set_extmark(0, ns, 6, 0, { vim.api.nvim_buf_set_extmark(0, ns, 6, 0, {
virt_lines_leftcol = true, virt_lines = {{{"virt", ""}}} }) virt_lines_leftcol = true, virt_lines = {{{"virt", ""}}} })
vim.api.nvim_buf_set_extmark(0, ns, 7, 0, { vim.api.nvim_buf_set_extmark(0, ns, 7, 0, {
@ -585,37 +582,78 @@ describe('statuscolumn', function()
end) end)
it("has correct width with custom sign column when (un)placing signs", function() it("has correct width with custom sign column when (un)placing signs", function()
screen:try_resize(screen._width, 6) screen:try_resize(screen._width, 3)
exec_lua([[ exec_lua([[
vim.cmd.norm('gg') vim.cmd.norm('gg')
vim.o.signcolumn = 'no' vim.o.signcolumn = 'no'
vim.fn.sign_define('sign', { text = 'ss' }) vim.fn.sign_define('sign', { text = 'ss' })
_G.StatusCol = function() _G.StatusCol = function()
local s = vim.fn.sign_getplaced(1)[1].signs local s = vim.fn.sign_getplaced(1)[1].signs
local es = vim.api.nvim_buf_get_extmarks(0, ns, 0, -1, {type = "sign"})
local sign = '' local sign = ''
if #s > 0 then local signs = #s + #es
sign = vim.v.lnum == 5 and 'ss' or ' ' if signs > 0 then
sign = (vim.v.lnum == 2 and 'ss' or ' '):rep(signs)
end end
return vim.v.lnum .. '%=' .. sign return vim.v.lnum .. '%=' .. sign
end end
vim.o.statuscolumn = "%!v:lua.StatusCol()" vim.o.statuscolumn = "%!v:lua.StatusCol()"
vim.fn.sign_place(0, '', 'sign', 1, { lnum = 5 })
]]) ]])
command('sign place 1 line=2 name=sign')
screen:expect([[ screen:expect([[
1 ^aaaaa | 1 ^aaaaa |
2 aaaaa | 2 ssaaaaa |
3 aaaaa | |
4 aaaaa | ]])
5 ssaaaaa | command('sign place 2 line=2 name=sign')
screen:expect([[
1 ^aaaaa |
2 ssssaaaaa |
|
]])
command('sign unplace 2')
screen:expect([[
1 ^aaaaa |
2 ssaaaaa |
| |
]]) ]])
command('sign unplace 1') command('sign unplace 1')
screen:expect([[ screen:expect([[
1 ^aaaaa | 1 ^aaaaa |
2 aaaaa | 2 aaaaa |
3 aaaaa | |
4 aaaaa | ]])
5 aaaaa | -- Also for extmark signs
exec_lua('id1 = vim.api.nvim_buf_set_extmark(0, ns, 1, 0, {sign_text = "ss"})')
screen:expect([[
1 ^aaaaa |
2 ssaaaaa |
|
]])
exec_lua('id2 = vim.api.nvim_buf_set_extmark(0, ns, 1, 0, {sign_text = "ss"})')
screen:expect([[
1 ^aaaaa |
2 ssssaaaaa |
|
]])
exec_lua("vim.api.nvim_buf_del_extmark(0, ns, id1)")
screen:expect([[
1 ^aaaaa |
2 ssaaaaa |
|
]])
exec_lua("vim.api.nvim_buf_del_extmark(0, ns, id2)")
screen:expect([[
1 ^aaaaa |
2 aaaaa |
|
]])
-- In all windows
command('wincmd v | set ls=0')
command('sign place 1 line=2 name=sign')
screen:expect([[
1 ^aaaaa 1 aaaaa |
2 ssaaaaa 2 ssaaaaa |
| |
]]) ]])
end) end)