forked from aniani/vim
patch 8.2.2168: Vim9: error for assigning to dict of dict
Problem: Vim9: error for assigning to dict of dict. Solution: Remember the destination type. (closes #7506)
This commit is contained in:
@@ -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 = {}
|
||||
|
@@ -750,6 +750,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
2168,
|
||||
/**/
|
||||
2167,
|
||||
/**/
|
||||
|
@@ -5877,6 +5877,7 @@ compile_assignment(char_u *arg, exarg_T *eap, cmdidx_T cmdidx, cctx_T *cctx)
|
||||
if (has_index)
|
||||
{
|
||||
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;
|
||||
|
Reference in New Issue
Block a user