mirror of
https://github.com/vim/vim.git
synced 2025-09-23 03:43:49 -04:00
patch 9.0.1805: Vim9: problem compiling object method as function call arg
Problem: Vim9: problem compiling object method as function call arg Solution: After a object/class method call, remove the object/class from the stack. closes: #12081 closes: #12929 Signed-off-by: Christian Brabandt <cb@256bit.org> Co-authored-by: Yegappan Lakshmanan <yegappan@yahoo.com>
This commit is contained in:
committed by
Christian Brabandt
parent
cd7293bf6c
commit
639751d218
@@ -3391,4 +3391,51 @@ def Test_interface_private_class_method()
|
|||||||
v9.CheckScriptFailure(lines, 'E1349: Function "_Foo" of interface "Intf" not implemented')
|
v9.CheckScriptFailure(lines, 'E1349: Function "_Foo" of interface "Intf" not implemented')
|
||||||
enddef
|
enddef
|
||||||
|
|
||||||
|
" Test for using the return value of a class/object method as a function
|
||||||
|
" argument.
|
||||||
|
def Test_objmethod_funcarg()
|
||||||
|
var lines =<< trim END
|
||||||
|
vim9script
|
||||||
|
|
||||||
|
class C
|
||||||
|
def Foo(): string
|
||||||
|
return 'foo'
|
||||||
|
enddef
|
||||||
|
endclass
|
||||||
|
|
||||||
|
def Bar(a: number, s: string): string
|
||||||
|
return s
|
||||||
|
enddef
|
||||||
|
|
||||||
|
def Baz(c: C)
|
||||||
|
assert_equal('foo', Bar(10, c.Foo()))
|
||||||
|
enddef
|
||||||
|
|
||||||
|
var t = C.new()
|
||||||
|
Baz(t)
|
||||||
|
END
|
||||||
|
v9.CheckScriptSuccess(lines)
|
||||||
|
|
||||||
|
lines =<< trim END
|
||||||
|
vim9script
|
||||||
|
|
||||||
|
class C
|
||||||
|
static def Foo(): string
|
||||||
|
return 'foo'
|
||||||
|
enddef
|
||||||
|
endclass
|
||||||
|
|
||||||
|
def Bar(a: number, s: string): string
|
||||||
|
return s
|
||||||
|
enddef
|
||||||
|
|
||||||
|
def Baz()
|
||||||
|
assert_equal('foo', Bar(10, C.Foo()))
|
||||||
|
enddef
|
||||||
|
|
||||||
|
Baz()
|
||||||
|
END
|
||||||
|
v9.CheckScriptSuccess(lines)
|
||||||
|
enddef
|
||||||
|
|
||||||
" vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker
|
" vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker
|
||||||
|
@@ -699,6 +699,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 */
|
||||||
|
/**/
|
||||||
|
1805,
|
||||||
/**/
|
/**/
|
||||||
1804,
|
1804,
|
||||||
/**/
|
/**/
|
||||||
|
@@ -1902,6 +1902,10 @@ generate_CALL(
|
|||||||
// drop the argument types
|
// drop the argument types
|
||||||
cctx->ctx_type_stack.ga_len -= argcount;
|
cctx->ctx_type_stack.ga_len -= argcount;
|
||||||
|
|
||||||
|
// For an object or class method call, drop the object/class type
|
||||||
|
if (ufunc->uf_class != NULL)
|
||||||
|
cctx->ctx_type_stack.ga_len--;
|
||||||
|
|
||||||
// add return type
|
// add return type
|
||||||
return push_type_stack(cctx, ufunc->uf_ret_type);
|
return push_type_stack(cctx, ufunc->uf_ret_type);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user