Skip to content

Commit

Permalink
patch 8.2.3739: in wrong directory when using win_execute() with 'acd…
Browse files Browse the repository at this point in the history
…' set

Problem:    In wrong directory when using win_execute() with 'acd' set.
Solution:   Restore the directory when returning to the window. (closes #9276)
  • Loading branch information
brammool committed Dec 4, 2021
1 parent 23bdef2 commit dea4a61
Show file tree
Hide file tree
Showing 3 changed files with 36 additions and 0 deletions.
29 changes: 29 additions & 0 deletions src/testdir/test_autochdir.vim
Expand Up @@ -25,6 +25,33 @@ func Test_set_filename()
call delete('samples/Xtest')
endfunc

func Test_set_filename_other_window()
call ch_logfile('logfile', 'w')
let cwd = getcwd()
call test_autochdir()
call mkdir('Xa')
call mkdir('Xb')
call mkdir('Xc')
try
args Xa/aaa.txt Xb/bbb.txt
set acd
let winid = win_getid()
snext
call assert_equal('Xb', substitute(getcwd(), '.*/\([^/]*\)$', '\1', ''))
call win_execute(winid, 'file ' .. cwd .. '/Xc/ccc.txt')
call assert_equal('Xb', substitute(getcwd(), '.*/\([^/]*\)$', '\1', ''))
finally
set noacd
call chdir(cwd)
call delete('Xa', 'rf')
call delete('Xb', 'rf')
call delete('Xc', 'rf')
bwipe! aaa.txt
bwipe! bbb.txt
bwipe! ccc.txt
endtry
endfunc

func Test_verbose_pwd()
let cwd = getcwd()
call test_autochdir()
Expand Down Expand Up @@ -53,6 +80,8 @@ func Test_verbose_pwd()
set noacd
call assert_match('\[autochdir\].*testdir[/\\]Xautodir', execute('verbose pwd'))
wincmd w
call assert_match('\[autochdir\].*testdir[/\\]Xautodir', execute('verbose pwd'))
execute 'cd' cwd
call assert_match('\[global\].*testdir', execute('verbose pwd'))
wincmd w
call assert_match('\[window\].*testdir[/\\]Xautodir', execute('verbose pwd'))
Expand Down
2 changes: 2 additions & 0 deletions src/version.c
Expand Up @@ -753,6 +753,8 @@ static char *(features[]) =

static int included_patches[] =
{ /* Add new patch number below this line */
/**/
3739,
/**/
3738,
/**/
Expand Down
5 changes: 5 additions & 0 deletions src/window.c
Expand Up @@ -4858,6 +4858,11 @@ win_enter_ext(win_T *wp, int flags)
void
fix_current_dir(void)
{
#ifdef FEAT_AUTOCHDIR
if (p_acd)
do_autochdir();
else
#endif
if (curwin->w_localdir != NULL || curtab->tp_localdir != NULL)
{
char_u *dirname;
Expand Down

0 comments on commit dea4a61

Please sign in to comment.