mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
Merge pull request #18682 from zeertzjq/vim-8.1.0535
vim-patch:8.1.0535,8.2.4991: increment/decrement might get interrupted by updating folds
This commit is contained in:
commit
f0717ffade
@ -775,7 +775,7 @@ void clearFolding(win_T *win)
|
|||||||
/// The changes in lines from top to bot (inclusive).
|
/// The changes in lines from top to bot (inclusive).
|
||||||
void foldUpdate(win_T *wp, linenr_T top, linenr_T bot)
|
void foldUpdate(win_T *wp, linenr_T top, linenr_T bot)
|
||||||
{
|
{
|
||||||
if (compl_busy || State & MODE_INSERT) {
|
if (disable_fold_update || compl_busy || State & MODE_INSERT) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -23,6 +23,7 @@ typedef struct foldinfo {
|
|||||||
|
|
||||||
#define FOLDINFO_INIT { 0, 0, 0, 0 }
|
#define FOLDINFO_INIT { 0, 0, 0, 0 }
|
||||||
|
|
||||||
|
EXTERN int disable_fold_update INIT(= 0);
|
||||||
|
|
||||||
#ifdef INCLUDE_GENERATED_DECLARATIONS
|
#ifdef INCLUDE_GENERATED_DECLARATIONS
|
||||||
# include "fold.h.generated.h"
|
# include "fold.h.generated.h"
|
||||||
|
@ -4911,12 +4911,19 @@ void op_addsub(oparg_T *oap, linenr_T Prenum1, bool g_cmd)
|
|||||||
ssize_t change_cnt = 0;
|
ssize_t change_cnt = 0;
|
||||||
linenr_T amount = Prenum1;
|
linenr_T amount = Prenum1;
|
||||||
|
|
||||||
|
// do_addsub() might trigger re-evaluation of 'foldexpr' halfway, when the
|
||||||
|
// buffer is not completly updated yet. Postpone updating folds until before
|
||||||
|
// the call to changed_lines().
|
||||||
|
disable_fold_update++;
|
||||||
|
|
||||||
if (!VIsual_active) {
|
if (!VIsual_active) {
|
||||||
pos = curwin->w_cursor;
|
pos = curwin->w_cursor;
|
||||||
if (u_save_cursor() == FAIL) {
|
if (u_save_cursor() == FAIL) {
|
||||||
|
disable_fold_update--;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
change_cnt = do_addsub(oap->op_type, &pos, 0, amount);
|
change_cnt = do_addsub(oap->op_type, &pos, 0, amount);
|
||||||
|
disable_fold_update--;
|
||||||
if (change_cnt) {
|
if (change_cnt) {
|
||||||
changed_lines(pos.lnum, 0, pos.lnum + 1, 0L, true);
|
changed_lines(pos.lnum, 0, pos.lnum + 1, 0L, true);
|
||||||
}
|
}
|
||||||
@ -4927,6 +4934,7 @@ void op_addsub(oparg_T *oap, linenr_T Prenum1, bool g_cmd)
|
|||||||
|
|
||||||
if (u_save((linenr_T)(oap->start.lnum - 1),
|
if (u_save((linenr_T)(oap->start.lnum - 1),
|
||||||
(linenr_T)(oap->end.lnum + 1)) == FAIL) {
|
(linenr_T)(oap->end.lnum + 1)) == FAIL) {
|
||||||
|
disable_fold_update--;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4973,6 +4981,8 @@ void op_addsub(oparg_T *oap, linenr_T Prenum1, bool g_cmd)
|
|||||||
amount += Prenum1;
|
amount += Prenum1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
disable_fold_update--;
|
||||||
if (change_cnt) {
|
if (change_cnt) {
|
||||||
changed_lines(oap->start.lnum, 0, oap->end.lnum + 1, 0L, true);
|
changed_lines(oap->start.lnum, 0, oap->end.lnum + 1, 0L, true);
|
||||||
}
|
}
|
||||||
|
@ -217,6 +217,26 @@ func Test_update_folds_expr_read()
|
|||||||
set foldmethod& foldexpr&
|
set foldmethod& foldexpr&
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
" Test for what patch 8.1.0535 fixes.
|
||||||
|
func Test_foldexpr_no_interrupt_addsub()
|
||||||
|
new
|
||||||
|
func! FoldFunc()
|
||||||
|
call setpos('.', getcurpos())
|
||||||
|
return '='
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
set foldmethod=expr
|
||||||
|
set foldexpr=FoldFunc()
|
||||||
|
call setline(1, '1.2')
|
||||||
|
|
||||||
|
exe "norm! $\<C-A>"
|
||||||
|
call assert_equal('1.3', getline(1))
|
||||||
|
|
||||||
|
bwipe!
|
||||||
|
delfunc FoldFunc
|
||||||
|
set foldmethod& foldexpr&
|
||||||
|
endfunc
|
||||||
|
|
||||||
func Check_foldlevels(expected)
|
func Check_foldlevels(expected)
|
||||||
call assert_equal(a:expected, map(range(1, line('$')), 'foldlevel(v:val)'))
|
call assert_equal(a:expected, map(range(1, line('$')), 'foldlevel(v:val)'))
|
||||||
endfunc
|
endfunc
|
||||||
|
Loading…
Reference in New Issue
Block a user