From f9547eb6ef02e305203b859d2dcfdae930b9d544 Mon Sep 17 00:00:00 2001 From: Bram Moolenaar Date: Mon, 1 Feb 2021 19:24:55 +0100 Subject: patch 8.2.2447: 'foldlevel' not applied to folds restored from session Problem: 'foldlevel' not applied to folds restored from session. Solution: Set 'foldlevel' after creaiting the folds. (closes #7767) --- src/fold.c | 5 +++-- src/testdir/test_mksession.vim | 26 ++++++++++++++++++++++++++ src/version.c | 2 ++ 3 files changed, 31 insertions(+), 2 deletions(-) (limited to 'src') diff --git a/src/fold.c b/src/fold.c index f889f4c74d..75b436a67e 100644 --- a/src/fold.c +++ b/src/fold.c @@ -3309,7 +3309,7 @@ foldlevelExpr(fline_T *flp) // KeyTyped may be reset to 0 when calling a function which invokes // do_cmdline(). To make 'foldopen' work correctly restore KeyTyped. save_keytyped = KeyTyped; - n = (int)eval_foldexpr(flp->wp->w_p_fde, &c); + n = eval_foldexpr(flp->wp->w_p_fde, &c); KeyTyped = save_keytyped; switch (c) @@ -3526,7 +3526,8 @@ put_folds(FILE *fd, win_T *wp) if (foldmethodIsManual(wp)) { if (put_line(fd, "silent! normal! zE") == FAIL - || put_folds_recurse(fd, &wp->w_folds, (linenr_T)0) == FAIL) + || put_folds_recurse(fd, &wp->w_folds, (linenr_T)0) == FAIL + || put_line(fd, "let &fdl = &fdl") == FAIL) return FAIL; } diff --git a/src/testdir/test_mksession.vim b/src/testdir/test_mksession.vim index 723eb8ed2d..82c96ce639 100644 --- a/src/testdir/test_mksession.vim +++ b/src/testdir/test_mksession.vim @@ -504,6 +504,32 @@ func Test_mkview_terminal_windows() call delete('Xtestview') endfunc +func Test_mkview_open_folds() + enew! + + call append(0, ['a', 'b', 'c']) + 1,3fold + " zR affects 'foldlevel', make sure the option is applied after the folds + " have been recreated. + normal zR + write! Xtestfile + + call assert_equal(-1, foldclosed(1)) + call assert_equal(-1, foldclosed(2)) + call assert_equal(-1, foldclosed(3)) + + mkview! Xtestview + source Xtestview + + call assert_equal(-1, foldclosed(1)) + call assert_equal(-1, foldclosed(2)) + call assert_equal(-1, foldclosed(3)) + + call delete('Xtestview') + call delete('Xtestfile') + %bwipe +endfunc + " Test :mkview with a file argument. func Test_mkview_file() " Create a view with line number and a fold. diff --git a/src/version.c b/src/version.c index bba9da818f..61acfadd46 100644 --- a/src/version.c +++ b/src/version.c @@ -750,6 +750,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 2447, /**/ 2446, /**/ -- cgit v1.2.3