mirror of
https://github.com/vim/vim.git
synced 2025-07-26 11:04:33 -04:00
patch 8.2.4987: after deletion a small fold may be closable
Problem: After deletion a small fold may be closable. Solution: Check for a reverse range. (Brandon Simmons, closes #10457)
This commit is contained in:
parent
8a83ffdc43
commit
3fcccf94e8
16
src/fold.c
16
src/fold.c
@ -829,10 +829,18 @@ foldUpdate(win_T *wp, linenr_T top, linenr_T bot)
|
|||||||
|
|
||||||
if (wp->w_folds.ga_len > 0)
|
if (wp->w_folds.ga_len > 0)
|
||||||
{
|
{
|
||||||
// Mark all folds from top to bot as maybe-small.
|
linenr_T maybe_small_start = top;
|
||||||
(void)foldFind(&wp->w_folds, top, &fp);
|
linenr_T maybe_small_end = bot;
|
||||||
|
|
||||||
|
// Mark all folds from top to bot (or bot to top) as maybe-small.
|
||||||
|
if (top > bot)
|
||||||
|
{
|
||||||
|
maybe_small_start = bot;
|
||||||
|
maybe_small_end = top;
|
||||||
|
}
|
||||||
|
(void)foldFind(&wp->w_folds, maybe_small_start, &fp);
|
||||||
while (fp < (fold_T *)wp->w_folds.ga_data + wp->w_folds.ga_len
|
while (fp < (fold_T *)wp->w_folds.ga_data + wp->w_folds.ga_len
|
||||||
&& fp->fd_top < bot)
|
&& fp->fd_top <= maybe_small_end)
|
||||||
{
|
{
|
||||||
fp->fd_small = MAYBE;
|
fp->fd_small = MAYBE;
|
||||||
++fp;
|
++fp;
|
||||||
@ -2165,7 +2173,7 @@ foldUpdateIEMS(win_T *wp, linenr_T top, linenr_T bot)
|
|||||||
bot = wp->w_buffer->b_ml.ml_line_count;
|
bot = wp->w_buffer->b_ml.ml_line_count;
|
||||||
wp->w_foldinvalid = FALSE;
|
wp->w_foldinvalid = FALSE;
|
||||||
|
|
||||||
// Mark all folds a maybe-small.
|
// Mark all folds as maybe-small.
|
||||||
setSmallMaybe(&wp->w_folds);
|
setSmallMaybe(&wp->w_folds);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1479,4 +1479,33 @@ func Test_indent_append_under_blank_line()
|
|||||||
bw!
|
bw!
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
" Make sure that when you delete 1 line of a fold whose length is 2 lines, the
|
||||||
|
" fold can't be closed since its length (1) is now less than foldminlines.
|
||||||
|
func Test_indent_one_line_fold_close()
|
||||||
|
let lines =<< trim END
|
||||||
|
line 1
|
||||||
|
line 2
|
||||||
|
line 3
|
||||||
|
END
|
||||||
|
|
||||||
|
new
|
||||||
|
setlocal sw=2 foldmethod=indent
|
||||||
|
call setline(1, lines)
|
||||||
|
" open all folds, delete line, then close all folds
|
||||||
|
normal zR
|
||||||
|
3delete
|
||||||
|
normal zM
|
||||||
|
call assert_equal(-1, foldclosed(2)) " the fold should not be closed
|
||||||
|
|
||||||
|
" Now do the same, but delete line 2 this time; this covers different code.
|
||||||
|
" (Combining this code with the above code doesn't expose both bugs.)
|
||||||
|
1,$delete
|
||||||
|
call setline(1, lines)
|
||||||
|
normal zR
|
||||||
|
2delete
|
||||||
|
normal zM
|
||||||
|
call assert_equal(-1, foldclosed(2))
|
||||||
|
bw!
|
||||||
|
endfunc
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@ -746,6 +746,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 */
|
||||||
|
/**/
|
||||||
|
4987,
|
||||||
/**/
|
/**/
|
||||||
4986,
|
4986,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user