]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.1629: Vim9: Not able to use more than 10 type arguments in a generic function v9.1.1629
authorYegappan Lakshmanan <yegappan@yahoo.com>
Wed, 13 Aug 2025 20:39:37 +0000 (22:39 +0200)
committerChristian Brabandt <cb@256bit.org>
Wed, 13 Aug 2025 20:39:37 +0000 (22:39 +0200)
Problem:  Vim9: Not able to use more than 10 type arguments in a generic
          function
Solution: Initialize the types after reading all the type arg variable
          names (Yegappan Lakshmanan)

closes: #17981

Signed-off-by: Yegappan Lakshmanan <yegappan@yahoo.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
src/testdir/test_vim9_generics.vim
src/version.c
src/vim9generics.c

index be279821d621ffee9f2f70f625be7ba78c5a46e3..07648a3326e4ba85704e3fe6224a1c192826bda3 100644 (file)
@@ -3553,4 +3553,21 @@ def Test_generic_enum_constructor_error()
   v9.CheckSourceFailure(lines, "E1010: Type not recognized: A", 4)
 enddef
 
+" Test for using more than 10 type arguments
+def Test_generic_max_type_args()
+  var lines =<< trim END
+    vim9script
+
+    def Fn<A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12>(a1: A1): A1
+      var x: A1 = a1
+      return x
+    enddef
+
+    assert_equal(10, Fn<number, string, string, string, string, string, string, string, string, string, string, string>(10))
+
+    assert_equal('abc', Fn<string, number, number, number, number, number, number, number, number, number, number, number>('abc'))
+  END
+  v9.CheckSourceSuccess(lines)
+enddef
+
 " vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker
index 01eadc2f00d7de78ee418b9093793392169cb454..14178370aee2e90f6a0307fe32892554f2f78dc7 100644 (file)
@@ -719,6 +719,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1629,
 /**/
     1628,
 /**/
index e74e3436eafcfb0677b92b3883c713485ff90580..54400903e42dfcdb75d67d2d473ba4e2fa320c14 100644 (file)
@@ -526,16 +526,6 @@ parse_generic_func_type_params(
        if (name_exists)
            return NULL;
 
-       if (ga_grow(&gfatab->gfat_param_types, 1) == FAIL)
-           return NULL;
-       type_T *gt =
-           &((type_T *)gfatab->gfat_param_types.ga_data)[gfatab->gfat_param_types.ga_len];
-       gfatab->gfat_param_types.ga_len++;
-
-       CLEAR_POINTER(gt);
-       gt->tt_type = VAR_ANY;
-       gt->tt_flags = TTFLAG_GENERIC;
-
        if (ga_grow(&gfatab->gfat_args, 1) == FAIL)
            return NULL;
        generic_T *generic =
@@ -546,7 +536,7 @@ parse_generic_func_type_params(
        if (generic->gt_name == NULL)
            return NULL;
        vim_strncpy(generic->gt_name, name_start, name_len);
-       generic->gt_type = gt;
+       generic->gt_type = NULL;
 
        if (VIM_ISWHITE(*p))
        {
@@ -572,13 +562,32 @@ parse_generic_func_type_params(
     }
     if (*p != '>')
        return NULL;
+    p++;
 
-    if (generic_func_args_table_size(gfatab) == 0)
+    int gfat_sz = generic_func_args_table_size(gfatab);
+
+    if (gfat_sz == 0)
     {
        emsg_funcname(e_empty_type_list_for_generic_function_str, func_name);
        return NULL;
     }
-    p++;
+
+    // set the generic parms to VAR_ANY type
+    if (ga_grow(&gfatab->gfat_param_types, gfat_sz) == FAIL)
+       return NULL;
+
+    gfatab->gfat_param_types.ga_len = gfat_sz;
+    for (int i = 0; i < generic_func_args_table_size(gfatab); i++)
+    {
+       type_T *gt = &((type_T *)gfatab->gfat_param_types.ga_data)[i];
+
+       CLEAR_POINTER(gt);
+       gt->tt_type = VAR_ANY;
+       gt->tt_flags = TTFLAG_GENERIC;
+
+       generic_T *generic = &((generic_T *)gfatab->gfat_args.ga_data)[i];
+       generic->gt_type = gt;
+    }
 
     return p;
 }