diff options
author | Bram Moolenaar <Bram@vim.org> | 2022-01-22 20:19:22 +0000 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2022-01-22 20:19:22 +0000 |
commit | 47bcc5f4c83c158f43ac2ea7abfe99dbf5c2e098 (patch) | |
tree | 078894b69ac8ca24d6c9b841c1268b38febd17a5 | |
parent | 3ba685eeefcfbbf895d70664357ef05f252d7b21 (diff) | |
download | vim-git-47bcc5f4c83c158f43ac2ea7abfe99dbf5c2e098.tar.gz |
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.c | 7 | ||||
-rw-r--r-- | src/testdir/test_vim9_import.vim | 30 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 38 insertions, 1 deletions
diff --git a/src/findfile.c b/src/findfile.c index 3a6484574..e8b3fa656 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 1cf1eb069..423ee0dfd 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 bdf7a3a51..c4a690c07 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, |