# HG changeset patch # User Bram Moolenaar # Date 1596633303 -7200 # Node ID 33fec24486978a0c97f046fc58077cb558fcbe1f # Parent 03d8640840f57196f78b3052f1810e0cf12eef99 patch 8.2.1374: Vim9: error for assigning empty list to script variable Commit: https://github.com/vim/vim/commit/a71e2633207557c31432c954194078cb6062d04f Author: Bram Moolenaar Date: Wed Aug 5 15:11:03 2020 +0200 patch 8.2.1374: Vim9: error for assigning empty list to script variable Problem: Vim9: error for assigning empty list to script variable. Solution: Use t_unknown for empty list member. (closes https://github.com/vim/vim/issues/6595) diff --git a/src/testdir/test_vim9_script.vim b/src/testdir/test_vim9_script.vim --- a/src/testdir/test_vim9_script.vim +++ b/src/testdir/test_vim9_script.vim @@ -2782,6 +2782,20 @@ def Test_let_type_check() let var: asdf END CheckScriptFailure(lines, 'E1010:') + + lines =<< trim END + vim9script + let s:l: list + s:l = [] + END + CheckScriptSuccess(lines) + + lines =<< trim END + vim9script + let s:d: dict + s:d = {} + END + CheckScriptSuccess(lines) enddef def Test_forward_declaration() diff --git a/src/version.c b/src/version.c --- a/src/version.c +++ b/src/version.c @@ -755,6 +755,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 1374, +/**/ 1373, /**/ 1372, diff --git a/src/vim9compile.c b/src/vim9compile.c --- a/src/vim9compile.c +++ b/src/vim9compile.c @@ -502,22 +502,25 @@ typval2type(typval_T *tv, garray_T *type if (tv->v_type == VAR_STRING) return &t_string; - if (tv->v_type == VAR_LIST - && tv->vval.v_list != NULL - && tv->vval.v_list->lv_first != NULL) - { + if (tv->v_type == VAR_LIST) + { + if (tv->vval.v_list == NULL || tv->vval.v_list->lv_first == NULL) + return &t_list_empty; + // Use the type of the first member, it is the most specific. member_type = typval2type(&tv->vval.v_list->lv_first->li_tv, type_gap); return get_list_type(member_type, type_gap); } - if (tv->v_type == VAR_DICT - && tv->vval.v_dict != NULL - && tv->vval.v_dict->dv_hashtab.ht_used > 0) + if (tv->v_type == VAR_DICT) { dict_iterator_T iter; typval_T *value; + if (tv->vval.v_dict == NULL + || tv->vval.v_dict->dv_hashtab.ht_used == 0) + return &t_dict_empty; + // Use the type of the first value, it is the most specific. dict_iterate_start(tv, &iter); dict_iterate_next(&iter, &value);