forked from aniani/vim
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.
This commit is contained in:
parent
788123c00c
commit
05a5551a86
@ -286,14 +286,14 @@ enddef
|
|||||||
|
|
||||||
def Test_error_in_nested_function()
|
def Test_error_in_nested_function()
|
||||||
" Error in called function requires unwinding the call stack.
|
" Error in called function requires unwinding the call stack.
|
||||||
assert_fails('call FuncWithForwardCall()', 'E1013')
|
assert_fails('call FuncWithForwardCall()', 'E1096')
|
||||||
enddef
|
enddef
|
||||||
|
|
||||||
def Test_return_type_wrong()
|
def Test_return_type_wrong()
|
||||||
CheckScriptFailure(['def Func(): number', 'return "a"', 'enddef', 'defcompile'], 'expected number but got string')
|
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(): 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(): void', 'return "a"', 'enddef', 'defcompile'], 'E1096: Returning a value in a function without a return type')
|
||||||
CheckScriptFailure(['def Func()', 'return "a"', 'enddef', 'defcompile'], 'expected void but got string')
|
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:')
|
CheckScriptFailure(['def Func(): number', 'return', 'enddef', 'defcompile'], 'E1003:')
|
||||||
|
|
||||||
|
@ -754,6 +754,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
1131,
|
||||||
/**/
|
/**/
|
||||||
1130,
|
1130,
|
||||||
/**/
|
/**/
|
||||||
|
@ -4568,9 +4568,19 @@ compile_return(char_u *arg, int set_return_type, cctx_T *cctx)
|
|||||||
stack_type = ((type_T **)stack->ga_data)[stack->ga_len - 1];
|
stack_type = ((type_T **)stack->ga_data)[stack->ga_len - 1];
|
||||||
if (set_return_type)
|
if (set_return_type)
|
||||||
cctx->ctx_ufunc->uf_ret_type = stack_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)
|
== FAIL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user