summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2020-12-20 15:20:56 +0100
committerBram Moolenaar <Bram@vim.org>2020-12-20 15:20:56 +0100
commitd24602f43cf1f3c37136fe275b83153c26a406e7 (patch)
tree458ce9cf9ff1a87bfd7c62248f960096affbfb47
parentd88dc4d4e950d937b44c523b9965d485f3fae4be (diff)
patch 8.2.2168: Vim9: error for assigning to dict of dictv8.2.2168
Problem: Vim9: error for assigning to dict of dict. Solution: Remember the destination type. (closes #7506)
-rw-r--r--src/testdir/test_vim9_assign.vim6
-rw-r--r--src/version.c2
-rw-r--r--src/vim9compile.c12
3 files changed, 15 insertions, 5 deletions
diff --git a/src/testdir/test_vim9_assign.vim b/src/testdir/test_vim9_assign.vim
index 4a6f1a7e5c..7954aa128e 100644
--- a/src/testdir/test_vim9_assign.vim
+++ b/src/testdir/test_vim9_assign.vim
@@ -560,6 +560,12 @@ def Test_assignment_dict()
dict3.key = 'yet another'
assert_equal(dict3, {key: 'yet another'})
+ # member "any" can also be a dict and assigned to
+ var anydict: dict<any> = {nest: {}, nr: 0}
+ anydict.nest['this'] = 123
+ anydict.nest.that = 456
+ assert_equal({nest: {this: 123, that: 456}, nr: 0}, anydict)
+
var lines =<< trim END
vim9script
var dd = {}
diff --git a/src/version.c b/src/version.c
index 88889b8114..67cc9045bf 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 */
/**/
+ 2168,
+/**/
2167,
/**/
2166,
diff --git a/src/vim9compile.c b/src/vim9compile.c
index c584918801..9bd36981af 100644
--- a/src/vim9compile.c
+++ b/src/vim9compile.c
@@ -5876,7 +5876,8 @@ compile_assignment(char_u *arg, exarg_T *eap, cmdidx_T cmdidx, cctx_T *cctx)
if (has_index)
{
- int r;
+ int r;
+ vartype_T dest_type;
// Compile the "idx" in "var[idx]" or "key" in "var.key".
p = var_start + varlen;
@@ -5913,10 +5914,11 @@ compile_assignment(char_u *arg, exarg_T *eap, cmdidx_T cmdidx, cctx_T *cctx)
else
type = &t_dict_any;
}
- if (type->tt_type == VAR_DICT
+ dest_type = type->tt_type;
+ if (dest_type == VAR_DICT
&& may_generate_2STRING(-1, cctx) == FAIL)
goto theend;
- if (type->tt_type == VAR_LIST
+ if (dest_type == VAR_LIST
&& ((type_T **)stack->ga_data)[stack->ga_len - 1]->tt_type
!= VAR_NUMBER)
{
@@ -5954,12 +5956,12 @@ compile_assignment(char_u *arg, exarg_T *eap, cmdidx_T cmdidx, cctx_T *cctx)
else
generate_loadvar(cctx, dest, name, lvar, type);
- if (type->tt_type == VAR_LIST)
+ if (dest_type == VAR_LIST)
{
if (generate_instr_drop(cctx, ISN_STORELIST, 3) == FAIL)
goto theend;
}
- else if (type->tt_type == VAR_DICT)
+ else if (dest_type == VAR_DICT)
{
if (generate_instr_drop(cctx, ISN_STOREDICT, 3) == FAIL)
goto theend;