# HG changeset patch # User Bram Moolenaar # Date 1642883402 -3600 # Node ID b3ef31c6a922f13b64246d2fadd6d0a1f6291660 # Parent 1644ebf864714e81123c34b8a09175943a96bd84 patch 8.2.4184: cannot use an import in 'includeexpr' Commit: https://github.com/vim/vim/commit/47bcc5f4c83c158f43ac2ea7abfe99dbf5c2e098 Author: Bram Moolenaar Date: Sat Jan 22 20:19:22 2022 +0000 patch 8.2.4184: cannot use an import in 'includeexpr' Problem: Cannot use an import in 'includeexpr'. Solution: Set the script context when evaluating 'includeexpr' diff --git a/src/findfile.c b/src/findfile.c --- 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 --- 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 \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 --- 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,