aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2024-01-26 07:00:25 +0800
committerzeertzjq <zeertzjq@outlook.com>2024-01-26 07:06:43 +0800
commit52d8741c78096a7606bf4f689d7e740372633dc6 (patch)
treebb1bbecbad0ed03133dfbc041218626cacc1bac5
parent83b51b36aa46d4bb25fada6eda22102e0aa5ef19 (diff)
downloadrneovim-52d8741c78096a7606bf4f689d7e740372633dc6.tar.gz
rneovim-52d8741c78096a7606bf4f689d7e740372633dc6.tar.bz2
rneovim-52d8741c78096a7606bf4f689d7e740372633dc6.zip
vim-patch:9.1.0054: 'linebreak' may still apply to leading whitespace
Problem: 'linebreak' may still apply to leading whitespace (VanaIgr) Solution: Compare pointers instead of virtual columns. (zeertzjq) related: #27180 closes: vim/vim#13915 https://github.com/vim/vim/commit/703f9bc943a29d947869b5cb0370be2ac42d5ac9 Co-authored-by: VanaIgr <vanaigranov@gmail.com>
-rw-r--r--src/nvim/plines.c18
-rw-r--r--test/old/testdir/test_listlbr.vim8
2 files changed, 12 insertions, 14 deletions
diff --git a/src/nvim/plines.c b/src/nvim/plines.c
index 678752eae5..f3db2603d2 100644
--- a/src/nvim/plines.c
+++ b/src/nvim/plines.c
@@ -277,22 +277,20 @@ CharSize charsize_regular(CharsizeArg *csarg, char *const cur, colnr_T const vco
size += added;
}
- char *s = cur;
- colnr_T vcol_start = 0; // start from where to consider linebreak
+ bool need_lbr = false;
// If 'linebreak' set check at a blank before a non-blank if the line
- // needs a break here
- if (wp->w_p_lbr && wp->w_p_wrap && wp->w_width_inner != 0) {
+ // needs a break here.
+ if (wp->w_p_lbr && wp->w_p_wrap && wp->w_width_inner != 0
+ && vim_isbreak((uint8_t)cur[0]) && !vim_isbreak((uint8_t)cur[1])) {
char *t = csarg->line;
while (vim_isbreak((uint8_t)t[0])) {
t++;
}
- vcol_start = (colnr_T)(t - csarg->line);
+ // 'linebreak' is only needed when not in leading whitespace.
+ need_lbr = cur >= t;
}
- if (wp->w_p_lbr && vcol_start <= vcol
- && vim_isbreak((uint8_t)s[0])
- && !vim_isbreak((uint8_t)s[1])
- && wp->w_p_wrap
- && wp->w_width_inner != 0) {
+ if (need_lbr) {
+ char *s = cur;
// Count all characters from first non-blank after a blank up to next
// non-blank after a blank.
int numberextra = win_col_off(wp);
diff --git a/test/old/testdir/test_listlbr.vim b/test/old/testdir/test_listlbr.vim
index 6dea94fbf1..e9bf9f3ff2 100644
--- a/test/old/testdir/test_listlbr.vim
+++ b/test/old/testdir/test_listlbr.vim
@@ -375,13 +375,13 @@ endfunc
func Test_linebreak_no_break_after_whitespace_only()
call s:test_windows('setl ts=4 linebreak wrap')
- call setline(1, "\tabcdefghijklmnopqrstuvwxyz" ..
+ call setline(1, "\t abcdefghijklmnopqrstuvwxyz" ..
\ "abcdefghijklmnopqrstuvwxyz")
let lines = s:screen_lines([1, 4], winwidth(0))
let expect = [
-\ " abcdefghijklmnop",
-\ "qrstuvwxyzabcdefghij",
-\ "klmnopqrstuvwxyz ",
+\ " abcdefghijklmn",
+\ "opqrstuvwxyzabcdefgh",
+\ "ijklmnopqrstuvwxyz ",
\ "~ ",
\ ]
call s:compare_lines(expect, lines)