# HG changeset patch # User Bram Moolenaar # Date 1593957604 -7200 # Node ID 1a393685e7ce395c88ed001c6322b9cfc4ab94c9 # Parent 43da8364314e827f9589838b2c2018b03946c8ea patch 8.2.1131: Vim9: error message for returning a value is not clear Commit: https://github.com/vim/vim/commit/05a5551a86e013e35d1dfa10fd0d811c587f9c88 Author: Bram Moolenaar Date: Sun Jul 5 15:52:19 2020 +0200 patch 8.2.1131: Vim9: error message for returning a value is not clear Problem: Vim9: error message for returning a value in a function that does not return anything is not clear. Solution: Add a specific message. diff --git a/src/testdir/test_vim9_func.vim b/src/testdir/test_vim9_func.vim --- a/src/testdir/test_vim9_func.vim +++ b/src/testdir/test_vim9_func.vim @@ -286,14 +286,14 @@ enddef def Test_error_in_nested_function() " Error in called function requires unwinding the call stack. - assert_fails('call FuncWithForwardCall()', 'E1013') + assert_fails('call FuncWithForwardCall()', 'E1096') enddef def Test_return_type_wrong() CheckScriptFailure(['def Func(): number', 'return "a"', 'enddef', 'defcompile'], 'expected number but got string') CheckScriptFailure(['def Func(): string', 'return 1', 'enddef', 'defcompile'], 'expected string but got number') - CheckScriptFailure(['def Func(): void', 'return "a"', 'enddef', 'defcompile'], 'expected void but got string') - CheckScriptFailure(['def Func()', 'return "a"', 'enddef', 'defcompile'], 'expected void but got string') + CheckScriptFailure(['def Func(): void', 'return "a"', 'enddef', 'defcompile'], 'E1096: Returning a value in a function without a return type') + CheckScriptFailure(['def Func()', 'return "a"', 'enddef', 'defcompile'], 'E1096: Returning a value in a function without a return type') CheckScriptFailure(['def Func(): number', 'return', 'enddef', 'defcompile'], 'E1003:') 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 */ /**/ + 1131, +/**/ 1130, /**/ 1129, diff --git a/src/vim9compile.c b/src/vim9compile.c --- a/src/vim9compile.c +++ b/src/vim9compile.c @@ -4568,9 +4568,19 @@ compile_return(char_u *arg, int set_retu stack_type = ((type_T **)stack->ga_data)[stack->ga_len - 1]; if (set_return_type) cctx->ctx_ufunc->uf_ret_type = stack_type; - else if (need_type(stack_type, cctx->ctx_ufunc->uf_ret_type, -1, cctx) + else + { + if (cctx->ctx_ufunc->uf_ret_type->tt_type == VAR_VOID + && stack_type->tt_type != VAR_VOID + && stack_type->tt_type != VAR_UNKNOWN) + { + emsg(_("E1096: Returning a value in a function without a return type")); + return NULL; + } + if (need_type(stack_type, cctx->ctx_ufunc->uf_ret_type, -1, cctx) == FAIL) return NULL; + } } else {