patch 8.2.3126: Vim9: for loop error reports wrong line number
Problem:    Vim9: for loop error reports wrong line number.
Solution:   Save and restore the line number when evaluating the expression.
            (closes #8514)
			
			
This commit is contained in:
		| @ -1225,9 +1225,14 @@ ex_while(exarg_T *eap) | |||||||
| 	    } | 	    } | ||||||
| 	    else | 	    else | ||||||
| 	    { | 	    { | ||||||
|  | 		long save_lnum = SOURCING_LNUM; | ||||||
|  |  | ||||||
| 		// Evaluate the argument and get the info in a structure. | 		// Evaluate the argument and get the info in a structure. | ||||||
| 		fi = eval_for_line(eap->arg, &error, eap, &evalarg); | 		fi = eval_for_line(eap->arg, &error, eap, &evalarg); | ||||||
| 		cstack->cs_forinfo[cstack->cs_idx] = fi; | 		cstack->cs_forinfo[cstack->cs_idx] = fi; | ||||||
|  |  | ||||||
|  | 		// Errors should use the first line number. | ||||||
|  | 		SOURCING_LNUM = save_lnum; | ||||||
| 	    } | 	    } | ||||||
|  |  | ||||||
| 	    // use the element at the start of the list and advance | 	    // use the element at the start of the list and advance | ||||||
|  | |||||||
| @ -2545,6 +2545,7 @@ def Test_for_loop_fails() | |||||||
|   CheckDefAndScriptFailure(['for # in range(5)'], 'E690:') |   CheckDefAndScriptFailure(['for # in range(5)'], 'E690:') | ||||||
|   CheckDefAndScriptFailure(['for i In range(5)'], 'E690:') |   CheckDefAndScriptFailure(['for i In range(5)'], 'E690:') | ||||||
|   CheckDefAndScriptFailure2(['var x = 5', 'for x in range(5)', 'endfor'], 'E1017:', 'E1041:') |   CheckDefAndScriptFailure2(['var x = 5', 'for x in range(5)', 'endfor'], 'E1017:', 'E1041:') | ||||||
|  |   CheckScriptFailure(['vim9script', 'var x = 5', 'for x in range(5)', '# comment', 'endfor'], 'E1041:', 3) | ||||||
|   CheckScriptFailure(['def Func(arg: any)', 'for arg in range(5)', 'enddef', 'defcompile'], 'E1006:') |   CheckScriptFailure(['def Func(arg: any)', 'for arg in range(5)', 'enddef', 'defcompile'], 'E1006:') | ||||||
|   delfunc! g:Func |   delfunc! g:Func | ||||||
|   CheckDefFailure(['for i in xxx'], 'E1001:') |   CheckDefFailure(['for i in xxx'], 'E1001:') | ||||||
|  | |||||||
| @ -755,6 +755,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 */ | ||||||
|  | /**/ | ||||||
|  |     3126, | ||||||
| /**/ | /**/ | ||||||
|     3125, |     3125, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user