aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2017-03-11 22:46:20 +0100
committerJustin M. Keyes <justinkz@gmail.com>2017-03-12 14:39:32 +0100
commit99a1a58c66b9bc56d98ee7a8d249d594669e9573 (patch)
tree6d7b42944639a96d43e7b8ab0db9c37b94af56ac /src
parent82117da5df93666798b94e4e6e47e11dcb1b4dcd (diff)
downloadrneovim-99a1a58c66b9bc56d98ee7a8d249d594669e9573.tar.gz
rneovim-99a1a58c66b9bc56d98ee7a8d249d594669e9573.tar.bz2
rneovim-99a1a58c66b9bc56d98ee7a8d249d594669e9573.zip
DirChanged: Publish _after_ updating win/tab CWD.
So getcwd() works correctly during DirChanged event. Closes #6260
Diffstat (limited to 'src')
-rw-r--r--src/nvim/ex_docmd.c24
-rw-r--r--src/nvim/file_search.c6
2 files changed, 12 insertions, 18 deletions
diff --git a/src/nvim/ex_docmd.c b/src/nvim/ex_docmd.c
index 146f1b6df6..5ab97d9b9a 100644
--- a/src/nvim/ex_docmd.c
+++ b/src/nvim/ex_docmd.c
@@ -6943,24 +6943,28 @@ void free_cd_dir(void)
/// @param scope Scope of the function call (global, tab or window).
void post_chdir(CdScope scope)
{
- // The local directory of the current window is always overwritten.
+ // Always overwrite the window-local CWD.
xfree(curwin->w_localdir);
curwin->w_localdir = NULL;
- // Overwrite the local directory of the current tab page for `cd` and `tcd`
+ // Overwrite the tab-local CWD for :cd, :tcd.
if (scope >= kCdScopeTab) {
xfree(curtab->tp_localdir);
curtab->tp_localdir = NULL;
}
if (scope < kCdScopeGlobal) {
- // If still in global directory, need to remember current directory as
- // global directory.
+ // If still in global directory, set CWD as the global directory.
if (globaldir == NULL && prev_dir != NULL) {
globaldir = vim_strsave(prev_dir);
}
}
+ char curdir[MAXPATHL];
+ if (os_dirname((char_u *)curdir, MAXPATHL) != OK) {
+ EMSG2(_(e_intern2), "post_chdir()");
+ return;
+ }
switch (scope) {
case kCdScopeGlobal:
// We are now in the global directory, no need to remember its name.
@@ -6968,23 +6972,17 @@ void post_chdir(CdScope scope)
globaldir = NULL;
break;
case kCdScopeTab:
- // Remember this local directory for the tab page.
- if (os_dirname(NameBuff, MAXPATHL) == OK) {
- curtab->tp_localdir = vim_strsave(NameBuff);
- }
+ curtab->tp_localdir = (char_u *)xstrdup(curdir);
break;
case kCdScopeWindow:
- // Remember this local directory for the window.
- if (os_dirname(NameBuff, MAXPATHL) == OK) {
- curwin->w_localdir = vim_strsave(NameBuff);
- }
+ curwin->w_localdir = (char_u *)xstrdup(curdir);
break;
case kCdScopeInvalid:
- // We should never get here
assert(false);
}
shorten_fnames(TRUE);
+ do_autocmd_dirchanged(curdir, scope);
}
/// `:cd`, `:tcd`, `:lcd`, `:chdir`, `:tchdir` and `:lchdir`.
diff --git a/src/nvim/file_search.c b/src/nvim/file_search.c
index 79a39c6503..34696ddd7f 100644
--- a/src/nvim/file_search.c
+++ b/src/nvim/file_search.c
@@ -1519,7 +1519,7 @@ theend:
return file_name;
}
-static void do_autocmd_dirchanged(char_u *new_dir, CdScope scope)
+void do_autocmd_dirchanged(char *new_dir, CdScope scope)
{
static bool recursive = false;
@@ -1587,10 +1587,6 @@ int vim_chdir(char_u *new_dir, CdScope scope)
}
int r = os_chdir((char *)dir_name);
- if (r == 0) {
- do_autocmd_dirchanged(dir_name, scope);
- }
-
xfree(dir_name);
return r;
}