]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.0815: "above" virtual text causes wrong 'colorcolumn' position v9.1.0815
authorzeertzjq <zeertzjq@outlook.com>
Sun, 27 Oct 2024 18:23:34 +0000 (19:23 +0100)
committerChristian Brabandt <cb@256bit.org>
Sun, 27 Oct 2024 18:24:53 +0000 (19:24 +0100)
Problem:  "above" virtual text causes wrong 'colorcolumn' position.
          (@matrdr)
Solution: Use the number of cells instead of bytes for vcol_off_tp.
          (zeertzjq)

fixes: #15946
closes: #15948

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
src/drawline.c
src/testdir/dumps/Test_prop_multibyte_above_1.dump [new file with mode: 0644]
src/testdir/test_textprop.vim
src/version.c

index fd5d56b43e50889400d813c24b271055c23e0c10..b49e6531332f4fd40b5d63598994380be2ea7638 100644 (file)
@@ -2263,7 +2263,7 @@ win_line(
                                }
 
                                if (above)
-                                   wlv.vcol_off_tp = wlv.n_extra;
+                                   wlv.vcol_off_tp = vim_strsize(wlv.p_extra);
 
                                if (lcs_eol_one < 0
                                        && wp->w_p_wrap
diff --git a/src/testdir/dumps/Test_prop_multibyte_above_1.dump b/src/testdir/dumps/Test_prop_multibyte_above_1.dump
new file mode 100644 (file)
index 0000000..d1e1d76
--- /dev/null
@@ -0,0 +1,16 @@
+| +0#af5f00255#ffffff0@3|…+0#0000001#ffff4012| +0#0000000#ffffff0@54
+| +0#af5f00255&@1|1| |1+0#0000000&@7| | +0&#ffd7d7255| +0&#ffffff0@45
+| +0#af5f00255&@3|…+0#0000001#ffff4012| +0#0000000#ffffff0@54
+| +0#af5f00255&@1|2| | +0#0000000&@8| +0&#ffd7d7255| +0&#ffffff0@45
+| +0#af5f00255&@3|…+0#0000001#ffff4012| +0#0000000#ffffff0@54
+| +0#af5f00255&@1|3| |3+0#0000000&@8| +0&#ffd7d7255| +0&#ffffff0@45
+| +0#af5f00255&@3|…+0#0000001#ffff4012| +0#0000000#ffffff0@54
+| +0#af5f00255&@1|4| | +0#0000000&@8| +0&#ffd7d7255| +0&#ffffff0@45
+| +0#af5f00255&@3|…+0#0000001#ffff4012| +0#0000000#ffffff0@54
+| +0#af5f00255&@1|5| >5+0#0000000&@8|5+0&#ffd7d7255|5+0&#ffffff0| @44
+|~+0#4040ff13&| @58
+|~| @58
+|~| @58
+|~| @58
+|~| @58
+| +0#0000000&@41|5|,|1|-|5|7| @7|A|l@1| 
index bbb911f959305b2cacf54f7de9bf5f136ef765fd..bf561cae35c83946ff47b90779f622e7bbcdc8b1 100644 (file)
@@ -3203,6 +3203,27 @@ func Test_prop_with_text_above_below_empty()
   call StopVimInTerminal(buf)
 endfunc
 
+func Test_prop_with_multibyte_above()
+  CheckRunVimInTerminal
+
+  let lines =<< trim END
+      setlocal number colorcolumn=10
+      call setline(1, ['11111111', '', '333333333', '', '55555555555'])
+
+      let vt = 'test'
+      call prop_type_add(vt, {'highlight': 'ToDo'})
+      for ln in range(1, line('$'))
+        call prop_add(ln, 0, {'type': vt, 'text': '…', 'text_align': 'above'})
+      endfor
+      normal G
+  END
+  call writefile(lines, 'XscriptPropMultibyteAbove', 'D')
+  let buf = RunVimInTerminal('-S XscriptPropMultibyteAbove', #{rows: 16, cols: 60})
+  call VerifyScreenDump(buf, 'Test_prop_multibyte_above_1', {})
+
+  call StopVimInTerminal(buf)
+endfunc
+
 func Test_prop_with_multibyte_below()
   CheckRunVimInTerminal
 
index aa05ea2c3528e24cdae400ed5b989185056bbd5c..39310671545749ed1194bfe869a7b4523effa041 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    815,
 /**/
     814,
 /**/