patch 9.1.1099: Vim9: import with extends may crash
Problem:  Vim9: import with extends may crash, v9.1.1087 wasn't the
          correct way to fix it)
Solution: When using an import class, Check for a valid class member
          variable at compile time (Yegappan Lakshmanan)
related: #16601
closes: #16603
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
						
							e3647c8bf5
						
					
				
				
					commit
					54d7f18c38
				
			| @ -96,7 +96,7 @@ clean: | ||||
| 	-rm -f opt_test.vim test_result.log $(CLEANUP_FILES) | ||||
| 	-rm -rf $(RM_ON_RUN) $(RM_ON_START) | ||||
| 	-rm -f valgrind.* | ||||
| 	-rm -f asan.* | ||||
| 	-rm -f asan.* asan_test_* | ||||
| 	-rm -f guidialog guidialogfile | ||||
|  | ||||
| # Delete the files produced by benchmarking, so they can run again. | ||||
|  | ||||
| @ -3454,8 +3454,7 @@ def Test_vim9_import_and_class_extends() | ||||
|     var myView = View.new('This should be ok') | ||||
|     assert_equal('This should be ok', myView.content.value) | ||||
|   END | ||||
|   # TODO: The root cause will be identified later. | ||||
|   v9.CheckScriptFailure(lines, 'E1099: Unknown error while executing new', 7) | ||||
|   v9.CheckScriptFailure(lines, 'E1376: Object variable "value2" accessible only using class "Run" object', 2) | ||||
| 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 */ | ||||
| /**/ | ||||
|     1099, | ||||
| /**/ | ||||
|     1098, | ||||
| /**/ | ||||
|  | ||||
| @ -2496,9 +2496,10 @@ compile_load_lhs( | ||||
| 	lhs->lhs_type = cctx->ctx_type_stack.ga_len == 0 ? &t_void | ||||
| 						  : get_type_on_stack(cctx, 0); | ||||
|  | ||||
| 	if (lhs->lhs_type->tt_type == VAR_OBJECT) | ||||
| 	if (lhs->lhs_type->tt_type == VAR_CLASS | ||||
| 		|| lhs->lhs_type->tt_type == VAR_OBJECT) | ||||
| 	{ | ||||
| 	    // Check whether the object variable is modifiable | ||||
| 	    // Check whether the class or object variable is modifiable | ||||
| 	    if (!lhs_class_member_modifiable(lhs, var_start, cctx)) | ||||
| 		return FAIL; | ||||
| 	} | ||||
|  | ||||
| @ -2461,15 +2461,9 @@ execute_storeindex(isn_T *iptr, ectx_T *ectx) | ||||
| 		otv = class->class_members_tv; | ||||
| 	    } | ||||
|  | ||||
| 	    if (otv != NULL) | ||||
| 	    { | ||||
| 	    clear_tv(&otv[lidx]); | ||||
| 	    otv[lidx] = *tv; | ||||
| 	} | ||||
| 	    else | ||||
| 		status = FAIL; | ||||
|  | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| 	    status = FAIL; | ||||
|  | ||||
		Reference in New Issue
	
	Block a user