diff options
author | vimboss <devnull@localhost> | 2008-01-02 20:08:25 +0000 |
---|---|---|
committer | vimboss <devnull@localhost> | 2008-01-02 20:08:25 +0000 |
commit | 168a51a79eba73fdd77ff8ce26173275aa599a6e (patch) | |
tree | ff3ba23da766ed20a36549241e246f8c8c723637 | |
parent | 9fe790b99532202022fd2d0ceb55f47adda8f4bd (diff) | |
download | vim-168a51a79eba73fdd77ff8ce26173275aa599a6e.tar.gz |
-rw-r--r-- | src/ex_docmd.c | 2 | ||||
-rw-r--r-- | src/fileio.c | 7 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 10 insertions, 1 deletions
diff --git a/src/ex_docmd.c b/src/ex_docmd.c index d44fcb41..c6a4bafa 100644 --- a/src/ex_docmd.c +++ b/src/ex_docmd.c @@ -7799,6 +7799,7 @@ static char_u *prev_dir = NULL; free_cd_dir() { vim_free(prev_dir); + prev_dir = NULL; } #endif @@ -9521,6 +9522,7 @@ eval_vars(src, srcstart, usedlen, lnump, errormsg, escaped) *errormsg = (char_u *)_("E495: no autocommand file name to substitute for \"<afile>\""); return NULL; } + result = shorten_fname1(result); break; case SPEC_ABUF: /* buffer number for autocommand */ diff --git a/src/fileio.c b/src/fileio.c index f6a4da79..bcf35525 100644 --- a/src/fileio.c +++ b/src/fileio.c @@ -5556,7 +5556,7 @@ make_bom(buf, name) #endif #if defined(FEAT_VIMINFO) || defined(FEAT_BROWSE) || \ - defined(FEAT_QUICKFIX) || defined(PROTO) + defined(FEAT_QUICKFIX) || defined(FEAT_AUTOCMD) || defined(PROTO) /* * Try to find a shortname by comparing the fullname with the current * directory. @@ -8546,6 +8546,8 @@ apply_autocmds_group(event, fname, fname_io, force, group, buf, eap) /* * Set the file name to be used for <afile>. + * Make a copy to avoid that changing a buffer name or directory makes it + * invalid. */ if (fname_io == NULL) { @@ -8558,6 +8560,8 @@ apply_autocmds_group(event, fname, fname_io, force, group, buf, eap) } else autocmd_fname = fname_io; + if (autocmd_fname != NULL) + autocmd_fname = FullName_save(autocmd_fname, FALSE); /* * Set the buffer number to be used for <abuf>. @@ -8740,6 +8744,7 @@ apply_autocmds_group(event, fname, fname_io, force, group, buf, eap) vim_free(sourcing_name); sourcing_name = save_sourcing_name; sourcing_lnum = save_sourcing_lnum; + vim_free(autocmd_fname); autocmd_fname = save_autocmd_fname; autocmd_bufnr = save_autocmd_bufnr; autocmd_match = save_autocmd_match; diff --git a/src/version.c b/src/version.c index cb266270..587e05dd 100644 --- a/src/version.c +++ b/src/version.c @@ -667,6 +667,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 186, +/**/ 185, /**/ 184, |