]> granicus.if.org Git - vim/commitdiff
patch 8.2.0760: Vim9: dict member errors not tested v8.2.0760
authorBram Moolenaar <Bram@vim.org>
Fri, 15 May 2020 19:44:19 +0000 (21:44 +0200)
committerBram Moolenaar <Bram@vim.org>
Fri, 15 May 2020 19:44:19 +0000 (21:44 +0200)
Problem:    Vim9: dict member errors not tested.
Solution:   Delete unreachable error.  Add tests.

src/testdir/test_vim9_expr.vim
src/version.c
src/vim9execute.c

index 6e8278850f5793db79d59a9c595e37c576daabff..8b937dc722051fd17215d3431d65a5c983773e53 100644 (file)
@@ -799,8 +799,12 @@ enddef
 
 def Test_expr_member()
   assert_equal(1, g:dict_one.one)
+  let d: dict<number> = g:dict_one
+  assert_equal(1, d['one'])
 
   call CheckDefFailure(["let x = g:dict_one.#$!"], 'E1002:')
+  call CheckDefExecFailure(["let d: dict<any>", "echo d['a']"], 'E716:')
+  call CheckDefExecFailure(["let d: dict<number>", "d = g:list_empty"], 'E1029: Expected dict but got list')
 enddef
 
 def Test_expr7_option()
index 1eb94bdd25ec6fbb7a9fab5b97f455a94fc870b2..d447c4b280fb2dbd1bb6320b238d18f7ac4f2386 100644 (file)
@@ -746,6 +746,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    760,
 /**/
     759,
 /**/
index dcc982805ecb8ec9e0aa6b1dcfd67f61b0ce1a4b..f50f8c6e109d6b6742f61a3b98ae87bea6ceaca1 100644 (file)
@@ -2104,20 +2104,13 @@ call_def_function(
 
                    // dict member: dict is at stack-2, key at stack-1
                    tv = STACK_TV_BOT(-2);
-                   if (tv->v_type != VAR_DICT)
-                   {
-                       emsg(_(e_dictreq));
-                       goto failed;
-                   }
+                   // no need to check for VAR_DICT, CHECKTYPE will check.
                    dict = tv->vval.v_dict;
 
                    tv = STACK_TV_BOT(-1);
-                   if (tv->v_type != VAR_STRING)
-                   {
-                       emsg(_(e_stringreq));
-                       goto failed;
-                   }
+                   // no need to check for VAR_STRING, 2STRING will check.
                    key = tv->vval.v_string;
+
                    if ((di = dict_find(dict, key, -1)) == NULL)
                    {
                        semsg(_(e_dictkey), key);