Merge pull request #27201 from zeertzjq/vim-9.1.0054

vim-patch:9.1.{0054,0056}
This commit is contained in:
zeertzjq 2024-01-26 07:37:04 +08:00 committed by GitHub
commit 6116495e6e
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 22 additions and 14 deletions

View File

@ -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);

View File

@ -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)

View File

@ -12,6 +12,16 @@ func Test_put_block()
bwipe!
endfunc
func Test_put_block_unicode()
new
call setreg('a', "À\nÀÀ\naaaaaaaaaaaa", "\<C-V>")
call setline(1, [' 1', ' 2', ' 3'])
exe "norm! \<C-V>jj\"ap"
let expected = ['À 1', 'ÀÀ 2', 'aaaaaaaaaaaa3']
call assert_equal(expected, getline(1, 3))
bw!
endfunc
func Test_put_char_block()
new
call setline(1, ['Line 1', 'Line 2'])