patch 9.1.0286: Vim9: E1027 with defcompile for abstract methods
Problem:  Vim9: E1027 with defcompile for abstract methods with
          non-void return types, but still compiles it
          (zzzyxwvut)
Solution: Don't compile abstract methods
          (Yegappan Lakshmanan)
fixes: #14443
closes: #14447
Signed-off-by: Yegappan Lakshmanan <yegappan@yahoo.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
			
			
This commit is contained in:
		
				
					committed by
					
						 Christian Brabandt
						Christian Brabandt
					
				
			
			
				
	
			
			
			
						parent
						
							78c51500f1
						
					
				
				
					commit
					1af0fbf955
				
			| @ -10583,4 +10583,46 @@ def Test_lambda_block_in_class() | ||||
|   v9.CheckScriptSuccess(lines) | ||||
| enddef | ||||
|  | ||||
| " Test for defcompiling an abstract method | ||||
| def Test_abstract_method_defcompile() | ||||
|   # Compile an abstract class with abstract object methods | ||||
|   var lines =<< trim END | ||||
|     vim9script | ||||
|     abstract class A | ||||
|       abstract def Foo(): string | ||||
|       abstract def Bar(): list<string> | ||||
|     endclass | ||||
|     defcompile | ||||
|   END | ||||
|   v9.CheckScriptSuccess(lines) | ||||
|  | ||||
|   # Compile a concrete object method in an abstract class | ||||
|   lines =<< trim END | ||||
|     vim9script | ||||
|     abstract class A | ||||
|       abstract def Foo(): string | ||||
|       abstract def Bar(): list<string> | ||||
|       def Baz(): string | ||||
|         pass | ||||
|       enddef | ||||
|     endclass | ||||
|     defcompile | ||||
|   END | ||||
|   v9.CheckScriptFailure(lines, 'E476: Invalid command: pass', 1) | ||||
|  | ||||
|   # Compile a concrete class method in an abstract class | ||||
|   lines =<< trim END | ||||
|     vim9script | ||||
|     abstract class A | ||||
|       abstract def Foo(): string | ||||
|       abstract def Bar(): list<string> | ||||
|       static def Baz(): string | ||||
|         pass | ||||
|       enddef | ||||
|     endclass | ||||
|     defcompile | ||||
|   END | ||||
|   v9.CheckScriptFailure(lines, 'E476: Invalid command: pass', 1) | ||||
| enddef | ||||
|  | ||||
| " vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker | ||||
|  | ||||
| @ -704,6 +704,8 @@ static char *(features[]) = | ||||
|  | ||||
| static int included_patches[] = | ||||
| {   /* Add new patch number below this line */ | ||||
| /**/ | ||||
|     286, | ||||
| /**/ | ||||
|     285, | ||||
| /**/ | ||||
|  | ||||
| @ -3723,6 +3723,8 @@ defcompile_class(class_T *cl) | ||||
| 	{ | ||||
| 	    ufunc_T *ufunc = loop == 1 ? cl->class_class_functions[i] | ||||
| 						: cl->class_obj_methods[i]; | ||||
| 	    // Don't compile abstract methods | ||||
| 	    if (!IS_ABSTRACT_METHOD(ufunc)) | ||||
| 		defcompile_function(ufunc, cl); | ||||
| 	} | ||||
|     } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user