summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2022-01-23 13:44:35 +0000
committerBram Moolenaar <Bram@vim.org>2022-01-23 13:44:35 +0000
commit7ef4a2fe3736bbeb5bad182782a74576aa06b0db (patch)
tree082731e347d8841572fb8644dacd03506180984b
parente15ebeffb35da4bb7d9054358671735ce6988c28 (diff)
patch 8.2.4192: cannot use an import in 'printexpr'v8.2.4192
Problem: Cannot use an import in 'printexpr'. Solution: Set the script context when evaluating 'printexpr'.
-rw-r--r--src/evalvars.c8
-rw-r--r--src/testdir/test_vim9_import.vim31
-rw-r--r--src/version.c2
3 files changed, 41 insertions, 0 deletions
diff --git a/src/evalvars.c b/src/evalvars.c
index 7578378b3b..196d4d4229 100644
--- a/src/evalvars.c
+++ b/src/evalvars.c
@@ -391,13 +391,21 @@ eval_charconvert(
eval_printexpr(char_u *fname, char_u *args)
{
int err = FALSE;
+ sctx_T saved_sctx = current_sctx;
+ sctx_T *ctx;
set_vim_var_string(VV_FNAME_IN, fname, -1);
set_vim_var_string(VV_CMDARG, args, -1);
+ ctx = get_option_sctx("printexpr");
+ if (ctx != NULL)
+ current_sctx = *ctx;
+
if (eval_to_bool(p_pexpr, &err, NULL, FALSE))
err = TRUE;
+
set_vim_var_string(VV_FNAME_IN, NULL, -1);
set_vim_var_string(VV_CMDARG, NULL, -1);
+ current_sctx = saved_sctx;
if (err)
{
diff --git a/src/testdir/test_vim9_import.vim b/src/testdir/test_vim9_import.vim
index 19379a01aa..482e759d11 100644
--- a/src/testdir/test_vim9_import.vim
+++ b/src/testdir/test_vim9_import.vim
@@ -874,6 +874,37 @@ def Test_import_in_indentexpr()
delete('Xindenter')
enddef
+func Test_import_in_printexpr()
+ CheckFeature postscript
+ call Run_Test_import_in_printexpr()
+endfunc
+
+def Run_Test_import_in_printexpr()
+ var lines =<< trim END
+ vim9script
+ export def PrintFile(): bool
+ g:printed = 'yes'
+ delete('v:fname_in')
+ return false
+ enddef
+ END
+ writefile(lines, 'Xprint.vim')
+
+ lines =<< trim END
+ vim9script
+ import './Xprint.vim'
+ set printexpr=Xprint.PrintFile()
+ END
+ CheckScriptSuccess(lines)
+
+ help
+ hardcopy dummy args
+ assert_equal('yes', g:printed)
+
+ delete('Xprint.vim')
+ set printexpr=
+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 f385750da3..824522f469 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 */
/**/
+ 4192,
+/**/
4191,
/**/
4190,