]> granicus.if.org Git - vim/commitdiff
patch 8.2.3154: Vim9: some type checks for builtin functions fail v8.2.3154
authorYegappan Lakshmanan <yegappan@yahoo.com>
Sun, 11 Jul 2021 20:04:25 +0000 (22:04 +0200)
committerBram Moolenaar <Bram@vim.org>
Sun, 11 Jul 2021 20:04:25 +0000 (22:04 +0200)
Problem:    Vim9: some type checks for builtin functions fail.
Solution:   Correct the type checks. (Yegappan Lakshmanan, closes #8551,
            closes #8550)

src/evalfunc.c
src/testdir/test_vim9_builtin.vim
src/version.c

index 4aa3b6d2afae991597665dc9c8a94aa8bc890be3..060b5bbb2839094dd3d17753966ac0b9124594e5 100644 (file)
@@ -431,9 +431,10 @@ arg_item_of_prev(type_T *type, argcontext_T *context)
     static int
 arg_str_or_nr_or_list(type_T *type, argcontext_T *context)
 {
-    if (type->tt_type == VAR_STRING
-                    || type->tt_type == VAR_NUMBER
-                    || type->tt_type == VAR_LIST)
+    if (type->tt_type == VAR_ANY
+               || type->tt_type == VAR_STRING
+               || type->tt_type == VAR_NUMBER
+               || type->tt_type == VAR_LIST)
        return OK;
     arg_type_mismatch(&t_string, type, context->arg_idx + 1);
     return FAIL;
index 2a58747bf63c4ffb531accdd1554fdce0f3238b7..f3e44e3b9edcf699ac35b4c6d9ed6de4b5761f17 100644 (file)
@@ -1523,6 +1523,12 @@ enddef
 def Test_popup_atcursor()
   CheckDefAndScriptFailure2(['popup_atcursor({"a": 10}, {})'], 'E1013: Argument 1: type mismatch, expected string but got dict<number>', 'E450: buffer number, text or a list required')
   CheckDefAndScriptFailure2(['popup_atcursor("a", [1, 2])'], 'E1013: Argument 2: type mismatch, expected dict<any> but got list<number>', 'E715: Dictionary required')
+
+  # Pass variable of type 'any' to popup_atcursor()
+  var what: any = 'Hello'
+  var popupID = what->popup_atcursor({moved: 'any'})
+  assert_equal(0, popupID->popup_getoptions().tabpage)
+  popupID->popup_close()
 enddef
 
 def Test_popup_beval()
@@ -1530,6 +1536,14 @@ def Test_popup_beval()
   CheckDefAndScriptFailure2(['popup_beval("a", [1, 2])'], 'E1013: Argument 2: type mismatch, expected dict<any> but got list<number>', 'E715: Dictionary required')
 enddef
 
+def Test_popup_create()
+  # Pass variable of type 'any' to popup_create()
+  var what: any = 'Hello'
+  var popupID = what->popup_create({})
+  assert_equal(0, popupID->popup_getoptions().tabpage)
+  popupID->popup_close()
+enddef
+
 def Test_popup_dialog()
   CheckDefAndScriptFailure2(['popup_dialog({"a": 10}, {})'], 'E1013: Argument 1: type mismatch, expected string but got dict<number>', 'E450: buffer number, text or a list required')
   CheckDefAndScriptFailure2(['popup_dialog("a", [1, 2])'], 'E1013: Argument 2: type mismatch, expected dict<any> but got list<number>', 'E715: Dictionary required')
@@ -2358,6 +2372,7 @@ def Test_virtcol()
   setline(1, ['abcdefgh'])
   cursor(1, 4)
   assert_equal(4, virtcol('.'))
+  assert_equal(4, virtcol([1, 4]))
   assert_equal(9, virtcol([1, '$']))
   assert_equal(0, virtcol([10, '$']))
   bw!
index 940c7192fa402846e8da5ed04d4b673a5877d611..9159011a71b1946382475e61bf99075cf15ceeaf 100644 (file)
@@ -755,6 +755,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    3154,
 /**/
     3153,
 /**/