summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2022-01-22 20:19:22 +0000
committerBram Moolenaar <Bram@vim.org>2022-01-22 20:19:22 +0000
commit47bcc5f4c83c158f43ac2ea7abfe99dbf5c2e098 (patch)
tree078894b69ac8ca24d6c9b841c1268b38febd17a5
parent3ba685eeefcfbbf895d70664357ef05f252d7b21 (diff)
patch 8.2.4184: cannot use an import in 'includeexpr'v8.2.4184
Problem: Cannot use an import in 'includeexpr'. Solution: Set the script context when evaluating 'includeexpr'
-rw-r--r--src/findfile.c7
-rw-r--r--src/testdir/test_vim9_import.vim30
-rw-r--r--src/version.c2
3 files changed, 38 insertions, 1 deletions
diff --git a/src/findfile.c b/src/findfile.c
index 3a6484574e..e8b3fa656d 100644
--- a/src/findfile.c
+++ b/src/findfile.c
@@ -2094,11 +2094,16 @@ file_name_in_line(
eval_includeexpr(char_u *ptr, int len)
{
char_u *res;
+ sctx_T save_sctx = current_sctx;
set_vim_var_string(VV_FNAME, ptr, len);
+ current_sctx = curbuf->b_p_script_ctx[BV_INEX];
+
res = eval_to_string_safe(curbuf->b_p_inex,
- was_set_insecurely((char_u *)"includeexpr", OPT_LOCAL), FALSE);
+ was_set_insecurely((char_u *)"includeexpr", OPT_LOCAL), TRUE);
+
set_vim_var_string(VV_FNAME, NULL, 0);
+ current_sctx = save_sctx;
return res;
}
# endif
diff --git a/src/testdir/test_vim9_import.vim b/src/testdir/test_vim9_import.vim
index 1cf1eb0699..423ee0dfd2 100644
--- a/src/testdir/test_vim9_import.vim
+++ b/src/testdir/test_vim9_import.vim
@@ -787,6 +787,36 @@ def Test_import_in_formatexpr()
set formatexpr=
enddef
+def Test_import_in_includeexpr()
+ writefile(['found it'], 'Xthisfile')
+ new
+
+ var lines =<< trim END
+ vim9script
+ export def DoSub(): string
+ return substitute(v:fname, 'that', 'this', '')
+ enddef
+ END
+ writefile(lines, 'Xinclude.vim')
+
+ lines =<< trim END
+ vim9script
+ import './Xinclude.vim'
+ set includeexpr=Xinclude.DoSub()
+ END
+ CheckScriptSuccess(lines)
+
+ setline(1, ['Xthatfile'])
+ exe "normal \<C-W>f"
+ assert_equal('Xthisfile', expand('%'))
+
+ bwipe!
+ bwipe!
+ set includeexpr=
+ delete('Xinclude')
+ delete('Xthisfile')
+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 bdf7a3a51a..c4a690c072 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 */
/**/
+ 4184,
+/**/
4183,
/**/
4182,