patch 8.1.2412: crash when evaluating expression with error
Problem: Crash when evaluating expression with error. (Dhiraj Mishra) Solution: Check parsing failed. (closes #5329)
This commit is contained in:
		| @ -2902,7 +2902,7 @@ eval_lambda( | |||||||
|     rettv->v_type = VAR_UNKNOWN; |     rettv->v_type = VAR_UNKNOWN; | ||||||
|  |  | ||||||
|     ret = get_lambda_tv(arg, rettv, evaluate); |     ret = get_lambda_tv(arg, rettv, evaluate); | ||||||
|     if (ret == NOTDONE) |     if (ret != OK) | ||||||
| 	return FAIL; | 	return FAIL; | ||||||
|     else if (**arg != '(') |     else if (**arg != '(') | ||||||
|     { |     { | ||||||
|  | |||||||
| @ -302,3 +302,8 @@ func Test_lambda_with_index() | |||||||
|   let Extract = {-> function(List, ['foobar'])()[0]} |   let Extract = {-> function(List, ['foobar'])()[0]} | ||||||
|   call assert_equal('foobar', Extract()) |   call assert_equal('foobar', Extract()) | ||||||
| endfunc | endfunc | ||||||
|  |  | ||||||
|  | func Test_lambda_error() | ||||||
|  |   " This was causing a crash | ||||||
|  |   call assert_fails('ec{@{->{d->()()', 'E15') | ||||||
|  | endfunc | ||||||
|  | |||||||
| @ -742,6 +742,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 */ | ||||||
|  | /**/ | ||||||
|  |     2412, | ||||||
| /**/ | /**/ | ||||||
|     2411, |     2411, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user