mirror of
https://github.com/vim/vim.git
synced 2025-07-26 11:04:33 -04:00
patch 8.1.1395: saving for undo may access invalid memory
Problem: Saving for undo may access invalid memory. (Dominique Pelle) Solution: Set ml_line_len also when returning a constant string.
This commit is contained in:
parent
a5e44600eb
commit
adfde115d5
@ -2573,13 +2573,17 @@ ml_get_buf(
|
||||
}
|
||||
errorret:
|
||||
STRCPY(IObuff, "???");
|
||||
buf->b_ml.ml_line_len = 4;
|
||||
return IObuff;
|
||||
}
|
||||
if (lnum <= 0) /* pretend line 0 is line 1 */
|
||||
if (lnum <= 0) // pretend line 0 is line 1
|
||||
lnum = 1;
|
||||
|
||||
if (buf->b_ml.ml_mfp == NULL) /* there are no lines */
|
||||
if (buf->b_ml.ml_mfp == NULL) // there are no lines
|
||||
{
|
||||
buf->b_ml.ml_line_len = 1;
|
||||
return (char_u *)"";
|
||||
}
|
||||
|
||||
/*
|
||||
* See if it is the same line as requested last time.
|
||||
|
@ -766,6 +766,15 @@ func Test_textprop_empty_buffer()
|
||||
new
|
||||
call prop_add(1, 1, {'type': 'comment'})
|
||||
close
|
||||
call prop_type_delete('comment')
|
||||
endfunc
|
||||
|
||||
" Adding a text property to an empty buffer and then editing another
|
||||
func Test_textprop_empty_buffer_next()
|
||||
call prop_type_add("xxx", {})
|
||||
call prop_add(1, 1, {"type": "xxx"})
|
||||
next X
|
||||
call prop_type_delete('xxx')
|
||||
endfunc
|
||||
|
||||
func Test_textprop_remove_from_buf()
|
||||
|
@ -767,6 +767,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
1395,
|
||||
/**/
|
||||
1394,
|
||||
/**/
|
||||
|
Loading…
x
Reference in New Issue
Block a user