summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorvimboss <devnull@localhost>2008-01-02 20:08:25 +0000
committervimboss <devnull@localhost>2008-01-02 20:08:25 +0000
commit168a51a79eba73fdd77ff8ce26173275aa599a6e (patch)
treeff3ba23da766ed20a36549241e246f8c8c723637
parent9fe790b99532202022fd2d0ceb55f47adda8f4bd (diff)
downloadvim-168a51a79eba73fdd77ff8ce26173275aa599a6e.tar.gz
updated for version 7.1-186v7.1.186v7-1-186
-rw-r--r--src/ex_docmd.c2
-rw-r--r--src/fileio.c7
-rw-r--r--src/version.c2
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,