patch 8.2.4873: Vim9: using "else" differs from using "endif/if !cond"
Problem: Vim9: using "else" differs from using "endif/if !cond". Solution: Leave the block and enter another one. (closes #10320)
This commit is contained in:
		| @ -1124,6 +1124,11 @@ ex_else(exarg_T *eap) | ||||
| 	skip = TRUE; | ||||
|     } | ||||
|  | ||||
|     // Variables declared in the previous block can no longer be | ||||
|     // used.  Needs to be done before setting "cs_flags". | ||||
|     leave_block(cstack); | ||||
|     enter_block(cstack); | ||||
|  | ||||
|     // if skipping or the ":if" was TRUE, reset ACTIVE, otherwise set it | ||||
|     if (skip || cstack->cs_flags[cstack->cs_idx] & CSF_TRUE) | ||||
|     { | ||||
|  | ||||
| @ -1640,6 +1640,50 @@ def Test_if_elseif_else_fails() | ||||
|   v9.CheckDefAndScriptFailure(lines, ['E1143:', 'E15:'], 4) | ||||
| enddef | ||||
|  | ||||
| def Test_if_else_func_using_var() | ||||
|   var lines =<< trim END | ||||
|       vim9script | ||||
|  | ||||
|       const debug = true | ||||
|       if debug | ||||
|         var mode_chars = 'something' | ||||
|         def Bits2Ascii() | ||||
|           var x = mode_chars | ||||
|           g:where = 'in true' | ||||
|         enddef | ||||
|       else | ||||
|         def Bits2Ascii() | ||||
|           g:where = 'in false' | ||||
|         enddef | ||||
|       endif | ||||
|  | ||||
|       Bits2Ascii() | ||||
|   END | ||||
|   v9.CheckScriptSuccess(lines) | ||||
|   assert_equal('in true', g:where) | ||||
|   unlet g:where | ||||
|  | ||||
|   lines =<< trim END | ||||
|       vim9script | ||||
|  | ||||
|       const debug = false | ||||
|       if debug | ||||
|         var mode_chars = 'something' | ||||
|         def Bits2Ascii() | ||||
|           g:where = 'in true' | ||||
|         enddef | ||||
|       else | ||||
|         def Bits2Ascii() | ||||
|           var x = mode_chars | ||||
|           g:where = 'in false' | ||||
|         enddef | ||||
|       endif | ||||
|  | ||||
|       Bits2Ascii() | ||||
|   END | ||||
|   v9.CheckScriptFailure(lines, 'E1001: Variable not found: mode_chars') | ||||
| enddef | ||||
|  | ||||
| let g:bool_true = v:true | ||||
| let g:bool_false = v:false | ||||
|  | ||||
|  | ||||
| @ -746,6 +746,8 @@ static char *(features[]) = | ||||
|  | ||||
| static int included_patches[] = | ||||
| {   /* Add new patch number below this line */ | ||||
| /**/ | ||||
|     4873, | ||||
| /**/ | ||||
|     4872, | ||||
| /**/ | ||||
|  | ||||
		Reference in New Issue
	
	Block a user