changeset 24996:0136c6ee1961 v8.2.3035

patch 8.2.3035: Vim9: crash when calling :def function with partial Commit: https://github.com/vim/vim/commit/831bdf8622fdfce7f02d48f847005e3909a055a8 Author: Bram Moolenaar <Bram@vim.org> Date: Tue Jun 22 19:32:17 2021 +0200 patch 8.2.3035: Vim9: crash when calling :def function with partial Problem: Vim9: crash when calling :def function with partial and return type is not set. Solution: When the return type is not set handle like the return type is unknown. (closes #8422)
author Bram Moolenaar <Bram@vim.org>
date Tue, 22 Jun 2021 19:45:03 +0200
parents 541097a70f43
children 6cd844668030
files src/testdir/test_vim9_func.vim src/version.c src/vim9type.c
diffstat 3 files changed, 18 insertions(+), 2 deletions(-) [+]
line wrap: on
line diff
--- a/src/testdir/test_vim9_func.vim
+++ b/src/testdir/test_vim9_func.vim
@@ -1005,6 +1005,20 @@ def Test_pass_legacy_lambda_to_def_func(
       Foo()
   END
   CheckScriptSuccess(lines)
+
+  lines =<< trim END
+      vim9script
+      def g:TestFunc(f: func())
+      enddef
+      legacy call g:TestFunc({-> 0})
+      delfunc g:TestFunc
+
+      def g:TestFunc(f: func(number))
+      enddef
+      legacy call g:TestFunc({nr -> 0})
+      delfunc g:TestFunc
+  END
+  CheckScriptSuccess(lines)
 enddef
 
 " Default arg and varargs
--- a/src/version.c
+++ b/src/version.c
@@ -756,6 +756,8 @@ static char *(features[]) =
 static int included_patches[] =
 {   /* Add new patch number below this line */
 /**/
+    3035,
+/**/
     3034,
 /**/
     3033,
--- a/src/vim9type.c
+++ b/src/vim9type.c
@@ -171,7 +171,7 @@ alloc_func_type(type_T *ret_type, int ar
     if (type == NULL)
 	return &t_any;
     type->tt_type = VAR_FUNC;
-    type->tt_member = ret_type;
+    type->tt_member = ret_type == NULL ? &t_unknown : ret_type;
     type->tt_argcount = argcount;
     type->tt_args = NULL;
     return type;
@@ -188,7 +188,7 @@ get_func_type(type_T *ret_type, int argc
     // recognize commonly used types
     if (argcount <= 0)
     {
-	if (ret_type == &t_unknown)
+	if (ret_type == &t_unknown || ret_type == NULL)
 	{
 	    // (argcount == 0) is not possible
 	    return &t_func_unknown;