mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
vim-patch:8.2.5023: substitute overwrites allocated buffer
Problem: Substitute overwrites allocated buffer.
Solution: Disallow undo when in a substitute command.
338f1fc0ee
This commit is contained in:
parent
4ffe5d0189
commit
df4c634d06
@ -432,6 +432,18 @@ static int find_command(int cmdchar)
|
||||
return idx;
|
||||
}
|
||||
|
||||
/// If currently editing a cmdline or text is locked: beep and give an error
|
||||
/// message, return true.
|
||||
static bool check_text_locked(oparg_T *oap)
|
||||
{
|
||||
if (text_locked()) {
|
||||
clearopbeep(oap);
|
||||
text_locked_msg();
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
/// Normal state entry point. This is called on:
|
||||
///
|
||||
/// - Startup, In this case the function never returns.
|
||||
@ -1079,15 +1091,9 @@ static int normal_execute(VimState *state, int key)
|
||||
goto finish;
|
||||
}
|
||||
|
||||
if (text_locked() && (nv_cmds[s->idx].cmd_flags & NV_NCW)) {
|
||||
// This command is not allowed while editing a cmdline: beep.
|
||||
clearopbeep(&s->oa);
|
||||
text_locked_msg();
|
||||
s->command_finished = true;
|
||||
goto finish;
|
||||
}
|
||||
|
||||
if ((nv_cmds[s->idx].cmd_flags & NV_NCW) && curbuf_locked()) {
|
||||
if ((nv_cmds[s->idx].cmd_flags & NV_NCW)
|
||||
&& (check_text_locked(&s->oa) || curbuf_locked())) {
|
||||
// this command is not allowed now
|
||||
s->command_finished = true;
|
||||
goto finish;
|
||||
}
|
||||
@ -4704,9 +4710,7 @@ static void nv_gotofile(cmdarg_T *cap)
|
||||
char_u *ptr;
|
||||
linenr_T lnum = -1;
|
||||
|
||||
if (text_locked()) {
|
||||
clearopbeep(cap->oap);
|
||||
text_locked_msg();
|
||||
if (check_text_locked(cap->oap)) {
|
||||
return;
|
||||
}
|
||||
if (curbuf_locked()) {
|
||||
@ -6433,13 +6437,7 @@ static void nv_g_cmd(cmdarg_T *cap)
|
||||
|
||||
// "gQ": improved Ex mode
|
||||
case 'Q':
|
||||
if (text_locked()) {
|
||||
clearopbeep(cap->oap);
|
||||
text_locked_msg();
|
||||
break;
|
||||
}
|
||||
|
||||
if (!checkclearopq(oap)) {
|
||||
if (!check_text_locked(cap->oap) && !checkclearopq(oap)) {
|
||||
do_exmode();
|
||||
}
|
||||
break;
|
||||
|
@ -851,6 +851,28 @@ func Test_sub_change_window()
|
||||
delfunc Repl
|
||||
endfunc
|
||||
|
||||
" This was undoign a change in between computing the length and using it.
|
||||
func Do_Test_sub_undo_change()
|
||||
new
|
||||
norm o0000000000000000000000000000000000000000000000000000
|
||||
silent! s/\%')/\=Repl()
|
||||
bwipe!
|
||||
endfunc
|
||||
|
||||
func Test_sub_undo_change()
|
||||
func Repl()
|
||||
silent! norm g-
|
||||
endfunc
|
||||
call Do_Test_sub_undo_change()
|
||||
|
||||
func! Repl()
|
||||
silent earlier
|
||||
endfunc
|
||||
call Do_Test_sub_undo_change()
|
||||
|
||||
delfunc Repl
|
||||
endfunc
|
||||
|
||||
" Test for the 2-letter and 3-letter :substitute commands
|
||||
func Test_substitute_short_cmd()
|
||||
new
|
||||
|
@ -89,6 +89,7 @@
|
||||
#include "nvim/change.h"
|
||||
#include "nvim/cursor.h"
|
||||
#include "nvim/edit.h"
|
||||
#include "nvim/ex_getln.h"
|
||||
#include "nvim/extmark.h"
|
||||
#include "nvim/fileio.h"
|
||||
#include "nvim/fold.h"
|
||||
@ -1954,6 +1955,11 @@ void undo_time(long step, bool sec, bool file, bool absolute)
|
||||
bool above = false;
|
||||
bool did_undo = true;
|
||||
|
||||
if (text_locked()) {
|
||||
text_locked_msg();
|
||||
return;
|
||||
}
|
||||
|
||||
// First make sure the current undoable change is synced.
|
||||
if (curbuf->b_u_synced == false) {
|
||||
u_sync(true);
|
||||
|
Loading…
Reference in New Issue
Block a user