summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2021-06-26 12:40:56 +0200
committerBram Moolenaar <Bram@vim.org>2021-06-26 12:40:56 +0200
commit444d878324525787e55185ce3c3e29a3de9b700a (patch)
tree3ba1d657b5351910b563288156927453af0edc02
parentf3caeb63d62c08b579e9b5f40b35e8bf64dde87a (diff)
downloadvim-git-444d878324525787e55185ce3c3e29a3de9b700a.tar.gz
patch 8.2.3051: Vim9: for loop with one list variable does not workv8.2.3051
Problem: Vim9: for loop with one list variable does not work. Solution: Use a separate flag for unpacking a list. (closes #8452)
-rw-r--r--src/testdir/test_vim9_script.vim7
-rw-r--r--src/version.c2
-rw-r--r--src/vim9compile.c11
3 files changed, 16 insertions, 4 deletions
diff --git a/src/testdir/test_vim9_script.vim b/src/testdir/test_vim9_script.vim
index 1584f173a..84bf907cd 100644
--- a/src/testdir/test_vim9_script.vim
+++ b/src/testdir/test_vim9_script.vim
@@ -2385,6 +2385,13 @@ def Test_for_loop()
endfor
assert_equal('1a2b', res)
+ # unpack with one var
+ var reslist = []
+ for [x] in [['aaa'], ['bbb']]
+ reslist->add(x)
+ endfor
+ assert_equal(['aaa', 'bbb'], reslist)
+
# loop over string
res = ''
for c in 'aéc̀d'
diff --git a/src/version.c b/src/version.c
index 32aec1b50..1270c0c06 100644
--- a/src/version.c
+++ b/src/version.c
@@ -756,6 +756,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 3051,
+/**/
3050,
/**/
3049,
diff --git a/src/vim9compile.c b/src/vim9compile.c
index cd83aea73..dd3f3aec3 100644
--- a/src/vim9compile.c
+++ b/src/vim9compile.c
@@ -7731,6 +7731,7 @@ compile_for(char_u *arg_start, cctx_T *cctx)
char_u *p;
char_u *wp;
int var_count = 0;
+ int var_list = FALSE;
int semicolon = FALSE;
size_t varlen;
garray_T *stack = &cctx->ctx_type_stack;
@@ -7747,6 +7748,8 @@ compile_for(char_u *arg_start, cctx_T *cctx)
return NULL;
if (var_count == 0)
var_count = 1;
+ else
+ var_list = TRUE; // can also be a list of one variable
// consume "in"
wp = p;
@@ -7811,7 +7814,7 @@ compile_for(char_u *arg_start, cctx_T *cctx)
else if (vartype->tt_type == VAR_LIST
&& vartype->tt_member->tt_type != VAR_ANY)
{
- if (var_count == 1)
+ if (!var_list)
item_type = vartype->tt_member;
else if (vartype->tt_member->tt_type == VAR_LIST
&& vartype->tt_member->tt_member->tt_type != VAR_ANY)
@@ -7828,7 +7831,7 @@ compile_for(char_u *arg_start, cctx_T *cctx)
generate_FOR(cctx, loop_lvar->lv_idx);
arg = arg_start;
- if (var_count > 1)
+ if (var_list)
{
generate_UNPACK(cctx, var_count, semicolon);
arg = skipwhite(arg + 1); // skip white after '['
@@ -7899,12 +7902,12 @@ compile_for(char_u *arg_start, cctx_T *cctx)
}
// Reserve a variable to store "var".
- where.wt_index = var_count > 1 ? idx + 1 : 0;
+ where.wt_index = var_list ? idx + 1 : 0;
where.wt_variable = TRUE;
if (lhs_type == &t_any)
lhs_type = item_type;
else if (item_type != &t_unknown
- && !(var_count > 1 && item_type == &t_any)
+ && !(var_list && item_type == &t_any)
&& check_type(lhs_type, item_type, TRUE, where) == FAIL)
goto failed;
var_lvar = reserve_local(cctx, arg, varlen, TRUE, lhs_type);