aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorbfredl <bjorn.linse@gmail.com>2023-11-22 12:19:30 +0100
committerGitHub <noreply@github.com>2023-11-22 12:19:30 +0100
commit34fa1e1ca4ddee0429f098a3ac885a716138fb6c (patch)
tree7e06eb69dc6829c0534533276a3326674298629f /src
parent2e722da44d3807698374043ecdd9952bd0772a40 (diff)
parentfba17d5b882e2903ba7a40eabc6f557e3cf24658 (diff)
downloadrneovim-34fa1e1ca4ddee0429f098a3ac885a716138fb6c.tar.gz
rneovim-34fa1e1ca4ddee0429f098a3ac885a716138fb6c.tar.bz2
rneovim-34fa1e1ca4ddee0429f098a3ac885a716138fb6c.zip
Merge pull request #26151 from bfredl/signcount
fix(decorations): fix imbalanced sign count
Diffstat (limited to 'src')
-rw-r--r--src/nvim/decoration.c14
1 files changed, 10 insertions, 4 deletions
diff --git a/src/nvim/decoration.c b/src/nvim/decoration.c
index 91d5bfcc54..2ef689680d 100644
--- a/src/nvim/decoration.c
+++ b/src/nvim/decoration.c
@@ -179,11 +179,17 @@ DecorSignHighlight decor_sh_from_inline(DecorHighlightInline item, String concea
void buf_put_decor(buf_T *buf, DecorInline decor, int row)
{
if (decor.ext) {
- if (decor.data.ext.vt) {
- buf_put_decor_virt(buf, decor.data.ext.vt);
+ DecorVirtText *vt = decor.data.ext.vt;
+ while (vt) {
+ buf_put_decor_virt(buf, vt);
+ vt = vt->next;
}
- if (decor.data.ext.sh_idx != DECOR_ID_INVALID) {
- buf_put_decor_sh(buf, &kv_A(decor_items, decor.data.ext.sh_idx), row);
+
+ uint32_t idx = decor.data.ext.sh_idx;
+ while (idx != DECOR_ID_INVALID) {
+ DecorSignHighlight *sh = &kv_A(decor_items, idx);
+ buf_put_decor_sh(buf, sh, row);
+ idx = sh->next;
}
}
}