]> granicus.if.org Git - vim/commitdiff
patch 8.2.3706: text property highlighting is used on Tab v8.2.3706
authorBram Moolenaar <Bram@vim.org>
Tue, 30 Nov 2021 20:22:49 +0000 (20:22 +0000)
committerBram Moolenaar <Bram@vim.org>
Tue, 30 Nov 2021 20:22:49 +0000 (20:22 +0000)
Problem:    Text property highlighting is used on Tab.
Solution:   Only set in_linebreak when not on a Tab. (closes #9242)

src/drawline.c
src/testdir/dumps/Test_prop_after_tab.dump [new file with mode: 0644]
src/testdir/test_textprop.vim
src/version.c

index 109b8b35ca8d546ca5b0049f30dc470d6b2d4788..ae62be8f374ce624d1b265b2c8ec461db7ad4d4e 100644 (file)
@@ -2046,7 +2046,7 @@ win_line(
 
                    c_extra = mb_off > 0 ? MB_FILLER_CHAR : ' ';
                    c_final = NUL;
-                   if (n_extra > 0)
+                   if (n_extra > 0 && c != TAB)
                        in_linebreak = TRUE;
                    if (VIM_ISWHITE(c))
                    {
diff --git a/src/testdir/dumps/Test_prop_after_tab.dump b/src/testdir/dumps/Test_prop_after_tab.dump
new file mode 100644 (file)
index 0000000..fd63d5e
--- /dev/null
@@ -0,0 +1,10 @@
+| +0&#ffffff0@6> |[+0#ffffff16#e000002|x+0#0000000#ffffff0@2|]| @61
+|~+0#4040ff13&| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+| +0#0000000&@56|1|,|1|-|8| @8|A|l@1| 
index 546e2d6943248ebb63a0479dad0b42980ae4a6d8..cc5d219ad5a4f90cddebf0d211123c0afc5dda52 100644 (file)
@@ -1633,6 +1633,24 @@ func Test_prop_in_linebreak()
   call delete('XscriptPropLinebreak')
 endfunc
 
+func Test_prop_after_tab()
+  CheckRunVimInTerminal
+
+  let lines =<< trim END
+    set breakindent linebreak breakat+=]
+    call setline(1, "\t[xxx]")
+    call prop_type_add('test', #{highlight: 'ErrorMsg'})
+    call prop_add(1, 2, #{length: 1, type: 'test'})
+  END
+  call writefile(lines, 'XscriptPropAfterTab')
+  let buf = RunVimInTerminal('-S XscriptPropAfterTab', #{rows: 10})
+  call TermWait(buf)
+  call VerifyScreenDump(buf, 'Test_prop_after_tab', {})
+
+  call StopVimInTerminal(buf)
+  call delete('XscriptPropAfterTab')
+endfunc
+
 " Buffer number of 0 should be ignored, as if the parameter wasn't passed.
 def Test_prop_bufnr_zero()
   new
index 570cd2174ce8c5cb3d5047599a9bd5dbd30d84b0..601055a0e5b7c5649494f382ed5183faa1b9fac9 100644 (file)
@@ -753,6 +753,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    3706,
 /**/
     3705,
 /**/