0
0
mirror of https://github.com/vim/vim.git synced 2025-09-23 03:43:49 -04:00

patch 9.0.0947: invalid memory access in substitute with function

Problem:    Invalid memory access in substitute with function that goes to
            another file.
Solution:   Check for text locked in CTRL-W gf.
This commit is contained in:
Bram Moolenaar
2022-11-25 13:03:31 +00:00
parent ad85af5b38
commit cc762a48d4
5 changed files with 49 additions and 10 deletions

View File

@@ -188,13 +188,33 @@ check_text_locked(oparg_T *oap)
{
if (text_locked())
{
clearopbeep(oap);
if (oap != NULL)
clearopbeep(oap);
text_locked_msg();
return TRUE;
}
return FALSE;
}
/*
* If text is locked, "curbuf_lock" or "allbuf_lock" is set:
* Give an error message, possibly beep and return TRUE.
* "oap" may be NULL.
*/
int
check_text_or_curbuf_locked(oparg_T *oap)
{
if (check_text_locked(oap))
return TRUE;
if (curbuf_locked())
{
if (oap != NULL)
clearop(oap);
return TRUE;
}
return FALSE;
}
/*
* Handle the count before a normal command and set cap->count0.
*/
@@ -798,8 +818,7 @@ normal_cmd(
goto normal_end;
}
if ((nv_cmds[idx].cmd_flags & NV_NCW)
&& (check_text_locked(oap) || curbuf_locked()))
if ((nv_cmds[idx].cmd_flags & NV_NCW) && check_text_or_curbuf_locked(oap))
// this command is not allowed now
goto normal_end;
@@ -4026,13 +4045,9 @@ nv_gotofile(cmdarg_T *cap)
char_u *ptr;
linenr_T lnum = -1;
if (check_text_locked(cap->oap))
if (check_text_or_curbuf_locked(cap->oap))
return;
if (curbuf_locked())
{
clearop(cap->oap);
return;
}
#ifdef FEAT_PROP_POPUP
if (ERROR_IF_TERM_POPUP_WINDOW)
return;