]> granicus.if.org Git - vim/commitdiff
patch 8.2.3723: when using 'linebreak' a text property starts too early v8.2.3723
authorBram Moolenaar <Bram@vim.org>
Thu, 2 Dec 2021 19:46:57 +0000 (19:46 +0000)
committerBram Moolenaar <Bram@vim.org>
Thu, 2 Dec 2021 19:46:57 +0000 (19:46 +0000)
Problem:    When using 'linebreak' a text property starts too early.
Solution:   Decrement "bcol" when looking for property start. (closes #9242)

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

index 7d6d4fd8aa26f7273408fa600733c36d12b7d6f3..3106196e9de46370f2129d39ca55c59829c18474 100644 (file)
@@ -1453,6 +1453,11 @@ win_line(
                    }
                }
 
+# ifdef FEAT_LINEBREAK
+               if (n_extra > 0 && in_linebreak)
+                   // not on the next char yet, don't start another prop
+                   --bcol;
+# endif
                // Add any text property that starts in this column.
                while (text_prop_next < text_prop_count
                           && bcol >= text_props[text_prop_next].tp_col - 1)
diff --git a/src/testdir/dumps/Test_prop_after_linebreak.dump b/src/testdir/dumps/Test_prop_after_linebreak.dump
new file mode 100644 (file)
index 0000000..7387c83
--- /dev/null
@@ -0,0 +1,10 @@
+>x+0&#ffffff0@36|+| @36
+|(+0#ffffff16#e000002|x+0#0000000#ffffff0@36|)| @35
+|~+0#4040ff13&| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+|~| @73
+| +0#0000000&@56|1|,|1| @10|A|l@1| 
index cc5d219ad5a4f90cddebf0d211123c0afc5dda52..036dd71325d4775c4e898d5d61fa0e476a9e2f00 100644 (file)
@@ -1651,6 +1651,24 @@ func Test_prop_after_tab()
   call delete('XscriptPropAfterTab')
 endfunc
 
+func Test_prop_after_linebreak()
+  CheckRunVimInTerminal
+
+  let lines =<< trim END
+      set linebreak wrap
+      call printf('%s+(%s)', 'x'->repeat(&columns / 2), 'x'->repeat(&columns / 2))->setline(1)
+      call prop_type_add('test', #{highlight: 'ErrorMsg'})
+      call prop_add(1, (&columns / 2) + 2, #{length: 1, type: 'test'})
+  END
+  call writefile(lines, 'XscriptPropAfterLinebreak')
+  let buf = RunVimInTerminal('-S XscriptPropAfterLinebreak', #{rows: 10})
+  call TermWait(buf)
+  call VerifyScreenDump(buf, 'Test_prop_after_linebreak', {})
+
+  call StopVimInTerminal(buf)
+  call delete('XscriptPropAfterLinebreak')
+endfunc
+
 " Buffer number of 0 should be ignored, as if the parameter wasn't passed.
 def Test_prop_bufnr_zero()
   new
index 0ae4d63aa9397fd1a40d8da59fc6860067e6007c..1c3f4c222186224cffc956fdbe5ac0e130fa40dc 100644 (file)
@@ -753,6 +753,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    3723,
 /**/
     3722,
 /**/