patch 8.2.4944: text properties are wrong after "cc"

Problem:    Text properties are wrong after "cc". (Axel Forsman)
Solution:   Pass the deleted byte count to inserted_bytes(). (closes #10412,
            closes #7737, closes #5763)
This commit is contained in:
LemonBoy
2022-05-12 18:45:18 +01:00
committed by Bram Moolenaar
parent 39c46b4378
commit d0b1a09f44
3 changed files with 26 additions and 2 deletions

View File

@ -2349,11 +2349,15 @@ truncate_line(int fixpos)
char_u *newp; char_u *newp;
linenr_T lnum = curwin->w_cursor.lnum; linenr_T lnum = curwin->w_cursor.lnum;
colnr_T col = curwin->w_cursor.col; colnr_T col = curwin->w_cursor.col;
char_u *old_line;
int deleted;
old_line = ml_get(lnum);
if (col == 0) if (col == 0)
newp = vim_strsave((char_u *)""); newp = vim_strsave((char_u *)"");
else else
newp = vim_strnsave(ml_get(lnum), col); newp = vim_strnsave(old_line, col);
deleted = (int)STRLEN(old_line) - col;
if (newp == NULL) if (newp == NULL)
return FAIL; return FAIL;
@ -2361,7 +2365,7 @@ truncate_line(int fixpos)
ml_replace(lnum, newp, FALSE); ml_replace(lnum, newp, FALSE);
// mark the buffer as changed and prepare for displaying // mark the buffer as changed and prepare for displaying
changed_bytes(lnum, curwin->w_cursor.col); inserted_bytes(lnum, curwin->w_cursor.col, -deleted);
// If "fixpos" is TRUE we don't want to end up positioned at the NUL. // If "fixpos" is TRUE we don't want to end up positioned at the NUL.
if (fixpos && curwin->w_cursor.col > 0) if (fixpos && curwin->w_cursor.col > 0)

View File

@ -534,6 +534,24 @@ func Test_prop_backspace()
set bs& set bs&
endfunc endfunc
func Test_prop_change()
new
let expected = SetupOneLine() " 'xonex xtwoxx'
" Characterwise.
exe "normal 7|c$\<Esc>"
call assert_equal('xonex ', getline(1))
call assert_equal(expected[:0], prop_list(1))
" Linewise.
exe "normal cc\<Esc>"
call assert_equal('', getline(1))
call assert_equal([], prop_list(1))
call DeletePropTypes()
bwipe!
set bs&
endfunc
func Test_prop_replace() func Test_prop_replace()
new new
set bs=2 set bs=2

View File

@ -746,6 +746,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
4944,
/**/ /**/
4943, 4943,
/**/ /**/