diff options
author | Bram Moolenaar <Bram@vim.org> | 2022-01-22 20:32:00 +0000 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2022-01-22 20:32:00 +0000 |
commit | 28e60cc088cadd25afb69ee636f0e2e34233ba4e (patch) | |
tree | 91411940fc4d481986c843cc351f83bdcba32512 | |
parent | 47bcc5f4c83c158f43ac2ea7abfe99dbf5c2e098 (diff) |
patch 8.2.4185: cannot use an import in 'indentexpr'v8.2.4185
Problem: Cannot use an import in 'indentexpr'.
Solution: Set the script context when evaluating 'indentexpr'
-rw-r--r-- | src/indent.c | 3 | ||||
-rw-r--r-- | src/testdir/test_vim9_import.vim | 27 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 32 insertions, 0 deletions
diff --git a/src/indent.c b/src/indent.c index a1012d2689..8dd4ef99cd 100644 --- a/src/indent.c +++ b/src/indent.c @@ -1829,6 +1829,7 @@ get_expr_indent(void) int save_State; int use_sandbox = was_set_insecurely((char_u *)"indentexpr", OPT_LOCAL); + sctx_T save_sctx = current_sctx; // Save and restore cursor position and curswant, in case it was changed // via :normal commands @@ -1839,6 +1840,7 @@ get_expr_indent(void) if (use_sandbox) ++sandbox; ++textwinlock; + current_sctx = curbuf->b_p_script_ctx[BV_INDE]; // Need to make a copy, the 'indentexpr' option could be changed while // evaluating it. @@ -1852,6 +1854,7 @@ get_expr_indent(void) if (use_sandbox) --sandbox; --textwinlock; + current_sctx = save_sctx; // Restore the cursor position so that 'indentexpr' doesn't need to. // Pretend to be in Insert mode, allow cursor past end of line for "o" diff --git a/src/testdir/test_vim9_import.vim b/src/testdir/test_vim9_import.vim index 423ee0dfd2..52a0c821da 100644 --- a/src/testdir/test_vim9_import.vim +++ b/src/testdir/test_vim9_import.vim @@ -817,6 +817,33 @@ def Test_import_in_includeexpr() delete('Xthisfile') enddef +def Test_import_in_indentexpr() + var lines =<< trim END + vim9script + export def GetIndent(): number + return 5 + enddef + END + writefile(lines, 'Xindenter') + + lines =<< trim END + vim9script + import './Xindenter' as indent + set indentexpr=indent.GetIndent() + set debug=throw + END + CheckScriptSuccess(lines) + + new + setline(1, 'hello') + normal == + assert_equal(' hello', getline(1)) + + bwipe! + set indentexpr= debug= + delete('Xindenter') +enddef + def Test_export_fails() CheckScriptFailure(['export var some = 123'], 'E1042:') CheckScriptFailure(['vim9script', 'export var g:some'], 'E1022:') diff --git a/src/version.c b/src/version.c index c4a690c072..9571473c96 100644 --- a/src/version.c +++ b/src/version.c @@ -751,6 +751,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 4185, +/**/ 4184, /**/ 4183, |