forked from aniani/vim
patch 8.1.0425: ml_get error and crash with appendbufline()
Problem: ml_get error and crash with appendbufline(). (Masashi Iizuka) Solution: Set per-window buffer info. (Hirohito Higashi, closes #3455)
This commit is contained in:
parent
e76d7a63df
commit
9cea87c577
@ -428,7 +428,10 @@ can_unload_buffer(buf_T *buf)
|
|||||||
|
|
||||||
FOR_ALL_WINDOWS(wp)
|
FOR_ALL_WINDOWS(wp)
|
||||||
if (wp->w_buffer == buf)
|
if (wp->w_buffer == buf)
|
||||||
|
{
|
||||||
can_unload = FALSE;
|
can_unload = FALSE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (!can_unload)
|
if (!can_unload)
|
||||||
EMSG(_("E937: Attempt to delete a buffer that is in use"));
|
EMSG(_("E937: Attempt to delete a buffer that is in use"));
|
||||||
@ -1742,6 +1745,9 @@ enter_buffer(buf_T *buf)
|
|||||||
/* mark cursor position as being invalid */
|
/* mark cursor position as being invalid */
|
||||||
curwin->w_valid = 0;
|
curwin->w_valid = 0;
|
||||||
|
|
||||||
|
buflist_setfpos(curbuf, curwin, curbuf->b_last_cursor.lnum,
|
||||||
|
curbuf->b_last_cursor.col, TRUE);
|
||||||
|
|
||||||
/* Make sure the buffer is loaded. */
|
/* Make sure the buffer is loaded. */
|
||||||
if (curbuf->b_ml.ml_mfp == NULL) /* need to load the file */
|
if (curbuf->b_ml.ml_mfp == NULL) /* need to load the file */
|
||||||
{
|
{
|
||||||
|
@ -91,6 +91,33 @@ func Test_appendbufline()
|
|||||||
exe "bwipe! " . b
|
exe "bwipe! " . b
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_appendbufline_no_E315()
|
||||||
|
let after = [
|
||||||
|
\ 'set stl=%f ls=2',
|
||||||
|
\ 'new',
|
||||||
|
\ 'let buf = bufnr("%")',
|
||||||
|
\ 'quit',
|
||||||
|
\ 'vsp',
|
||||||
|
\ 'exec "buffer" buf',
|
||||||
|
\ 'wincmd w',
|
||||||
|
\ 'call appendbufline(buf, 0, "abc")',
|
||||||
|
\ 'redraw',
|
||||||
|
\ 'while getbufline(buf, 1)[0] =~ "^\\s*$"',
|
||||||
|
\ ' sleep 10m',
|
||||||
|
\ 'endwhile',
|
||||||
|
\ 'au VimLeavePre * call writefile([v:errmsg], "Xerror")',
|
||||||
|
\ 'au VimLeavePre * call writefile(["done"], "Xdone")',
|
||||||
|
\ 'qall!',
|
||||||
|
\ ]
|
||||||
|
if !RunVim([], after, '--clean')
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
call assert_notmatch("^E315:", readfile("Xerror")[0])
|
||||||
|
call assert_equal("done", readfile("Xdone")[0])
|
||||||
|
call delete("Xerror")
|
||||||
|
call delete("Xdone")
|
||||||
|
endfunc
|
||||||
|
|
||||||
func Test_deletebufline()
|
func Test_deletebufline()
|
||||||
new
|
new
|
||||||
let b = bufnr('%')
|
let b = bufnr('%')
|
||||||
|
@ -794,6 +794,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 */
|
||||||
|
/**/
|
||||||
|
425,
|
||||||
/**/
|
/**/
|
||||||
424,
|
424,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user