patch 9.0.0217: 'shellslash' works differently when sourcing a script again
Problem: 'shellslash' works differently when sourcing a script again. Solution: Use the name from the script item. (closes #10920)
This commit is contained in:
@ -1534,10 +1534,6 @@ do_source_ext(
|
|||||||
cookie.level = ex_nesting_level;
|
cookie.level = ex_nesting_level;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Keep the sourcing name/lnum, for recursive calls.
|
|
||||||
estack_push(ETYPE_SCRIPT, fname_exp, 0);
|
|
||||||
ESTACK_CHECK_SETUP
|
|
||||||
|
|
||||||
#ifdef STARTUPTIME
|
#ifdef STARTUPTIME
|
||||||
if (time_fd != NULL)
|
if (time_fd != NULL)
|
||||||
time_push(&tv_rel, &tv_start);
|
time_push(&tv_rel, &tv_start);
|
||||||
@ -1630,6 +1626,10 @@ do_source_ext(
|
|||||||
si->sn_is_vimrc = is_vimrc;
|
si->sn_is_vimrc = is_vimrc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Keep the sourcing name/lnum, for recursive calls.
|
||||||
|
estack_push(ETYPE_SCRIPT, si->sn_name, 0);
|
||||||
|
ESTACK_CHECK_SETUP
|
||||||
|
|
||||||
# ifdef FEAT_PROFILE
|
# ifdef FEAT_PROFILE
|
||||||
if (do_profiling == PROF_YES)
|
if (do_profiling == PROF_YES)
|
||||||
{
|
{
|
||||||
|
|||||||
@ -41,7 +41,7 @@ func Test_expand_sfile_and_stack()
|
|||||||
call assert_match('test_expand_func\.vim$', s:sfile)
|
call assert_match('test_expand_func\.vim$', s:sfile)
|
||||||
let expected = 'script .*testdir/runtest.vim\[\d\+\]\.\.function RunTheTest\[\d\+\]\.\.Test_expand_sfile_and_stack'
|
let expected = 'script .*testdir/runtest.vim\[\d\+\]\.\.function RunTheTest\[\d\+\]\.\.Test_expand_sfile_and_stack'
|
||||||
call assert_match(expected .. '$', expand('<sfile>'))
|
call assert_match(expected .. '$', expand('<sfile>'))
|
||||||
call assert_match(expected .. '\[4\]' , expand('<stack>'))
|
call assert_match(expected .. '\[4\]$' , expand('<stack>'))
|
||||||
|
|
||||||
" Call in script-local function
|
" Call in script-local function
|
||||||
call assert_match('script .*testdir/runtest.vim\[\d\+\]\.\.function RunTheTest\[\d\+\]\.\.Test_expand_sfile_and_stack\[7\]\.\.<SNR>\d\+_expand_sfile$', s:expand_sfile())
|
call assert_match('script .*testdir/runtest.vim\[\d\+\]\.\.function RunTheTest\[\d\+\]\.\.Test_expand_sfile_and_stack\[7\]\.\.<SNR>\d\+_expand_sfile$', s:expand_sfile())
|
||||||
@ -59,7 +59,32 @@ func Test_expand_sfile_and_stack()
|
|||||||
call writefile(lines, 'Xstack')
|
call writefile(lines, 'Xstack')
|
||||||
source Xstack
|
source Xstack
|
||||||
call assert_match('\<Xstack\[2\]$', g:stack_value)
|
call assert_match('\<Xstack\[2\]$', g:stack_value)
|
||||||
|
unlet g:stack_value
|
||||||
call delete('Xstack')
|
call delete('Xstack')
|
||||||
|
|
||||||
|
if exists('+shellslash')
|
||||||
|
call mkdir('Xshellslash')
|
||||||
|
let lines =<< trim END
|
||||||
|
let g:stack1 = expand('<stack>')
|
||||||
|
set noshellslash
|
||||||
|
let g:stack2 = expand('<stack>')
|
||||||
|
set shellslash
|
||||||
|
let g:stack3 = expand('<stack>')
|
||||||
|
END
|
||||||
|
call writefile(lines, 'Xshellslash/Xstack')
|
||||||
|
" Test that changing 'shellslash' always affects the result of expand()
|
||||||
|
" when sourcing a script multiple times.
|
||||||
|
for i in range(2)
|
||||||
|
source Xshellslash/Xstack
|
||||||
|
call assert_match('\<Xshellslash/Xstack\[1\]$', g:stack1)
|
||||||
|
call assert_match('\<Xshellslash\\Xstack\[3\]$', g:stack2)
|
||||||
|
call assert_match('\<Xshellslash/Xstack\[5\]$', g:stack3)
|
||||||
|
unlet g:stack1
|
||||||
|
unlet g:stack2
|
||||||
|
unlet g:stack3
|
||||||
|
endfor
|
||||||
|
call delete('Xshellslash', 'rf')
|
||||||
|
endif
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
func Test_expand_slnum()
|
func Test_expand_slnum()
|
||||||
|
|||||||
@ -735,6 +735,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 */
|
||||||
|
/**/
|
||||||
|
217,
|
||||||
/**/
|
/**/
|
||||||
216,
|
216,
|
||||||
/**/
|
/**/
|
||||||
|
|||||||
Reference in New Issue
Block a user