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
						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