]> granicus.if.org Git - vim/commitdiff
updated for version 7.4b.008 v7.4b.008
authorBram Moolenaar <Bram@vim.org>
Fri, 2 Aug 2013 15:08:13 +0000 (17:08 +0200)
committerBram Moolenaar <Bram@vim.org>
Fri, 2 Aug 2013 15:08:13 +0000 (17:08 +0200)
Problem:    'autochdir' causes setbufvar() to change the current directory.
            (Ben Fritz)
Solution:   When disabling autocommands also reset 'acd' temporarily.
            (Christian Brabandt)

src/fileio.c
src/version.c

index 731a7b183d1e0a99965c1b8c12e473615318ece3..20f082b22452a7723a61bf7f979df0961ad0cd4e 100644 (file)
@@ -8861,6 +8861,7 @@ aucmd_prepbuf(aco, buf)
 #ifdef FEAT_WINDOWS
     int                save_ea;
 #endif
+    int                save_acd;
 
     /* Find a window that is for the new buffer */
     if (buf == curbuf)         /* be quick when buf is curbuf */
@@ -8909,11 +8910,10 @@ aucmd_prepbuf(aco, buf)
        aucmd_win->w_s = &buf->b_s;
        ++buf->b_nwindows;
        win_init_empty(aucmd_win); /* set cursor and topline to safe values */
-       vim_free(aucmd_win->w_localdir);
-       aucmd_win->w_localdir = NULL;
 
        /* Make sure w_localdir and globaldir are NULL to avoid a chdir() in
         * win_enter_ext(). */
+       vim_free(aucmd_win->w_localdir);
        aucmd_win->w_localdir = NULL;
        aco->globaldir = globaldir;
        globaldir = NULL;
@@ -8926,9 +8926,15 @@ aucmd_prepbuf(aco, buf)
        make_snapshot(SNAP_AUCMD_IDX);
        save_ea = p_ea;
        p_ea = FALSE;
+
+       /* Prevent chdir() call in win_enter_ext(), through do_autochdir(). */
+       save_acd = p_acd;
+       p_acd = FALSE;
+
        (void)win_split_ins(0, WSP_TOP, aucmd_win, 0);
        (void)win_comp_pos();   /* recompute window positions */
        p_ea = save_ea;
+       p_acd = save_acd;
        unblock_autocmds();
 #endif
        curwin = aucmd_win;
index d34ed63ddf2c68d2ef11cd47eacc7e41fca1140a..22fc9b961b9ec378e490a496140f42a8c8612278 100644 (file)
@@ -727,6 +727,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    8,
 /**/
     7,
 /**/