mirror of
https://github.com/vim/vim.git
synced 2025-09-27 04:14:06 -04:00
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;
|
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 skipping or the ":if" was TRUE, reset ACTIVE, otherwise set it
|
||||||
if (skip || cstack->cs_flags[cstack->cs_idx] & CSF_TRUE)
|
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)
|
v9.CheckDefAndScriptFailure(lines, ['E1143:', 'E15:'], 4)
|
||||||
enddef
|
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_true = v:true
|
||||||
let g:bool_false = v:false
|
let g:bool_false = v:false
|
||||||
|
|
||||||
|
@@ -746,6 +746,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 */
|
||||||
|
/**/
|
||||||
|
4873,
|
||||||
/**/
|
/**/
|
||||||
4872,
|
4872,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user