patch 9.1.0844: if_python: no way to pass local vars to python
Problem: if_python: no way to pass local vars to python
Solution: Add locals argument to py3eval(), pyeval() and pyxeval()
(Ben Jackson)
fixes: #8573
closes: #10594
Signed-off-by: Ben Jackson <puremourning@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
diff --git a/src/evalfunc.c b/src/evalfunc.c
index adae129..2d88668 100644
--- a/src/evalfunc.c
+++ b/src/evalfunc.c
@@ -2487,7 +2487,7 @@
ret_dict_number, f_pum_getpos},
{"pumvisible", 0, 0, 0, NULL,
ret_number_bool, f_pumvisible},
- {"py3eval", 1, 1, FEARG_1, arg1_string,
+ {"py3eval", 1, 2, FEARG_1, arg2_string_dict,
ret_any,
#ifdef FEAT_PYTHON3
f_py3eval
@@ -2495,7 +2495,7 @@
NULL
#endif
},
- {"pyeval", 1, 1, FEARG_1, arg1_string,
+ {"pyeval", 1, 2, FEARG_1, arg2_string_dict,
ret_any,
#ifdef FEAT_PYTHON
f_pyeval
@@ -2503,7 +2503,7 @@
NULL
#endif
},
- {"pyxeval", 1, 1, FEARG_1, arg1_string,
+ {"pyxeval", 1, 2, FEARG_1, arg2_string_dict,
ret_any,
#if defined(FEAT_PYTHON) || defined(FEAT_PYTHON3)
f_pyxeval
@@ -9291,18 +9291,35 @@
{
char_u *str;
char_u buf[NUMBUFLEN];
+ dict_T *locals;
if (check_restricted() || check_secure())
return;
- if (in_vim9script() && check_for_string_arg(argvars, 0) == FAIL)
+ if (in_vim9script()
+ && (check_for_string_arg(argvars, 0) == FAIL
+ || check_for_opt_dict_arg(argvars, 1) == FAIL))
return;
if (p_pyx == 0)
p_pyx = 3;
+ if (argvars[1].v_type == VAR_DICT)
+ {
+ locals = argvars[1].vval.v_dict;
+ }
+ else if (argvars[1].v_type != VAR_UNKNOWN)
+ {
+ emsg(_(e_dictionary_required));
+ return;
+ }
+ else
+ {
+ locals = NULL;
+ }
+
str = tv_get_string_buf(&argvars[0], buf);
- do_py3eval(str, rettv);
+ do_py3eval(str, locals, rettv);
}
#endif
@@ -9315,18 +9332,35 @@
{
char_u *str;
char_u buf[NUMBUFLEN];
+ dict_T *locals;
if (check_restricted() || check_secure())
return;
- if (in_vim9script() && check_for_string_arg(argvars, 0) == FAIL)
+ if (in_vim9script() && (
+ check_for_string_arg(argvars, 0) == FAIL ||
+ check_for_opt_dict_arg(argvars, 1) == FAIL ) )
return;
if (p_pyx == 0)
p_pyx = 2;
+ if (argvars[1].v_type == VAR_DICT)
+ {
+ locals = argvars[1].vval.v_dict;
+ }
+ else if (argvars[1].v_type != VAR_UNKNOWN)
+ {
+ emsg( "Invalid argument: must be dict" );
+ return;
+ }
+ else
+ {
+ locals = NULL;
+ }
+
str = tv_get_string_buf(&argvars[0], buf);
- do_pyeval(str, rettv);
+ do_pyeval(str, locals, rettv);
}
#endif
@@ -9340,7 +9374,9 @@
if (check_restricted() || check_secure())
return;
- if (in_vim9script() && check_for_string_arg(argvars, 0) == FAIL)
+ if (in_vim9script()
+ && (check_for_string_arg(argvars, 0) == FAIL
+ || check_for_opt_dict_arg(argvars, 1) == FAIL))
return;
# if defined(FEAT_PYTHON) && defined(FEAT_PYTHON3)