aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/eval/funcs.c
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2022-05-23 07:27:26 +0800
committerGitHub <noreply@github.com>2022-05-23 07:27:26 +0800
commita7e0a02031c7b4a192cb9c0e4eb13a714d5b0dbb (patch)
tree39fa589222180be4e84c6aa4dfe4cb00d2c90e21 /src/nvim/eval/funcs.c
parent39fb97b2a5bb7ecd69cd7955fba045f7b002df6d (diff)
parentbcfc97e8d85df38ce7bea16c02cf8f89c9c96cdc (diff)
downloadrneovim-a7e0a02031c7b4a192cb9c0e4eb13a714d5b0dbb.tar.gz
rneovim-a7e0a02031c7b4a192cb9c0e4eb13a714d5b0dbb.tar.bz2
rneovim-a7e0a02031c7b4a192cb9c0e4eb13a714d5b0dbb.zip
Merge pull request #18691 from zeertzjq/vim-8.2.4996
vim-patch:8.2.{4996.5002}: setbufline(), deletebufline() may change Visual selection
Diffstat (limited to 'src/nvim/eval/funcs.c')
-rw-r--r--src/nvim/eval/funcs.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/src/nvim/eval/funcs.c b/src/nvim/eval/funcs.c
index 6fa5aac2d6..59c290a5b1 100644
--- a/src/nvim/eval/funcs.c
+++ b/src/nvim/eval/funcs.c
@@ -1636,6 +1636,7 @@ static void f_deletebufline(typval_T *argvars, typval_T *rettv, FunPtr fptr)
return;
}
const bool is_curbuf = buf == curbuf;
+ const bool save_VIsual_active = VIsual_active;
const linenr_T first = tv_get_lnum_buf(&argvars[1], buf);
if (argvars[2].v_type != VAR_UNKNOWN) {
@@ -1651,6 +1652,7 @@ static void f_deletebufline(typval_T *argvars, typval_T *rettv, FunPtr fptr)
}
if (!is_curbuf) {
+ VIsual_active = false;
curbuf_save = curbuf;
curwin_save = curwin;
curbuf = buf;
@@ -1694,6 +1696,7 @@ static void f_deletebufline(typval_T *argvars, typval_T *rettv, FunPtr fptr)
if (!is_curbuf) {
curbuf = curbuf_save;
curwin = curwin_save;
+ VIsual_active = save_VIsual_active;
}
}