aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/buffer.c
diff options
context:
space:
mode:
authorBjörn Linse <bjorn.linse@gmail.com>2021-07-04 23:16:49 +0200
committerGitHub <noreply@github.com>2021-07-04 23:16:49 +0200
commitc6226bd6c9068fae3afc1e7a31ff3fdd9ed3649a (patch)
tree404cd0aeff9437f63b277328d91ae158dd4d8521 /src/nvim/buffer.c
parent18bfcfe77f007f146a7251aa3cc6129891390c30 (diff)
parent65b0918c243ab052d6134d7270ff9f1a3b591260 (diff)
downloadrneovim-c6226bd6c9068fae3afc1e7a31ff3fdd9ed3649a.tar.gz
rneovim-c6226bd6c9068fae3afc1e7a31ff3fdd9ed3649a.tar.bz2
rneovim-c6226bd6c9068fae3afc1e7a31ff3fdd9ed3649a.zip
Merge pull request #14391 from lewis6991/signs
signs: Change b_signcols_max -> b_signcols_valid
Diffstat (limited to 'src/nvim/buffer.c')
-rw-r--r--src/nvim/buffer.c20
1 files changed, 11 insertions, 9 deletions
diff --git a/src/nvim/buffer.c b/src/nvim/buffer.c
index 8decd02b3a..09bb230ff5 100644
--- a/src/nvim/buffer.c
+++ b/src/nvim/buffer.c
@@ -1786,7 +1786,7 @@ buf_T *buflist_new(char_u *ffname_arg, char_u *sfname_arg, linenr_T lnum,
buf = xcalloc(1, sizeof(buf_T));
// init b: variables
buf->b_vars = tv_dict_alloc();
- buf->b_signcols_max = -1;
+ buf->b_signcols_valid = false;
init_var_dict(buf->b_vars, &buf->b_bufvar, VAR_SCOPE);
buf_init_changedtick(buf);
}
@@ -5547,16 +5547,16 @@ bool find_win_for_buf(buf_T *buf, win_T **wp, tabpage_T **tp)
int buf_signcols(buf_T *buf)
{
- if (buf->b_signcols_max == -1) {
+ if (!buf->b_signcols_valid) {
sign_entry_T *sign; // a sign in the sign list
- buf->b_signcols_max = 0;
+ int signcols = 0;
int linesum = 0;
linenr_T curline = 0;
FOR_ALL_SIGNS_IN_BUF(buf, sign) {
if (sign->se_lnum > curline) {
- if (linesum > buf->b_signcols_max) {
- buf->b_signcols_max = linesum;
+ if (linesum > signcols) {
+ signcols = linesum;
}
curline = sign->se_lnum;
linesum = 0;
@@ -5565,15 +5565,17 @@ int buf_signcols(buf_T *buf)
linesum++;
}
}
- if (linesum > buf->b_signcols_max) {
- buf->b_signcols_max = linesum;
+ if (linesum > signcols) {
+ signcols = linesum;
}
// Check if we need to redraw
- if (buf->b_signcols_max != buf->b_signcols) {
- buf->b_signcols = buf->b_signcols_max;
+ if (signcols != buf->b_signcols) {
+ buf->b_signcols = signcols;
redraw_buf_later(buf, NOT_VALID);
}
+
+ buf->b_signcols_valid = true;
}
return buf->b_signcols;