aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/option.c
diff options
context:
space:
mode:
authorLuuk van Baal <luukvbaal@gmail.com>2023-04-19 00:19:26 +0200
committerLuuk van Baal <luukvbaal@gmail.com>2023-04-19 03:22:27 +0200
commit44d4f0357341d661a8fa7bd88c244e0ab196a838 (patch)
treec6c0bd1e80bd9baed4c597c20de658c38d062458 /src/nvim/option.c
parentd799456a6b4d9f3000a4a4adb8b71ddee96351b9 (diff)
downloadrneovim-44d4f0357341d661a8fa7bd88c244e0ab196a838.tar.gz
rneovim-44d4f0357341d661a8fa7bd88c244e0ab196a838.tar.bz2
rneovim-44d4f0357341d661a8fa7bd88c244e0ab196a838.zip
fix(column): rebuild status column when sign column is invalid
Diffstat (limited to 'src/nvim/option.c')
-rw-r--r--src/nvim/option.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/nvim/option.c b/src/nvim/option.c
index 3b674ce726..5466dc97e9 100644
--- a/src/nvim/option.c
+++ b/src/nvim/option.c
@@ -2189,9 +2189,8 @@ static const char *set_bool_option(const int opt_idx, char *const varp, const in
errmsg = did_set_spelllang(curwin);
}
} else if ((int *)varp == &curwin->w_p_nu && *curwin->w_p_stc != NUL) {
- // When 'statuscolumn' is set and 'number' is changed:
- curwin->w_nrwidth_line_count = 0; // make sure width is reset
- curwin->w_statuscol_line_count = 0; // make sure width is re-estimated
+ // When 'number' is changed and 'statuscolumn' is set, make sure width is reset.
+ curwin->w_nrwidth_line_count = 0;
}
if ((int *)varp == &curwin->w_p_arab) {
@@ -5531,6 +5530,13 @@ int win_signcol_configured(win_T *wp, int *is_fixed)
if (*scl == 'n'
&& (*(scl + 1) == 'o' || (*(scl + 1) == 'u'
&& (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) {
buf_signcols(wp->w_buffer, 0);
}