summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2012-01-10 18:37:58 +0100
committerBram Moolenaar <Bram@vim.org>2012-01-10 18:37:58 +0100
commit1f5965b3c4d2b29e167a5dfecdf0ec59fe4c45c0 (patch)
tree4bcf1069449a9621f1b7ad6d96998232ff90c75c
parenta0f299b4e8dccc2f22ada363a7e293b146c1ece7 (diff)
updated for version 7.3.399v7.3.399
Problem: ":cd" doesn't work when the path contains wildcards. (Yukihiro Nakadaira) Solution: Ignore wildcard errors when the EW_NOTWILD flag is used.
-rw-r--r--src/misc1.c18
-rw-r--r--src/version.c2
2 files changed, 14 insertions, 6 deletions
diff --git a/src/misc1.c b/src/misc1.c
index a5a3ad3147..1cd7cceee8 100644
--- a/src/misc1.c
+++ b/src/misc1.c
@@ -9103,15 +9103,15 @@ dos_expandpath(
}
/* compile the regexp into a program */
- if (flags & EW_NOERROR)
+ if (flags & (EW_NOERROR | EW_NOTWILD))
++emsg_silent;
regmatch.rm_ic = TRUE; /* Always ignore case */
regmatch.regprog = vim_regcomp(pat, RE_MAGIC);
- if (flags & EW_NOERROR)
+ if (flags & (EW_NOERROR | EW_NOTWILD))
--emsg_silent;
vim_free(pat);
- if (regmatch.regprog == NULL)
+ if (regmatch.regprog == NULL && (flags & EW_NOTWILD) == 0)
{
vim_free(buf);
return 0;
@@ -9179,7 +9179,8 @@ dos_expandpath(
* all entries found with "matchname". */
if ((p[0] != '.' || starts_with_dot)
&& (matchname == NULL
- || vim_regexec(&regmatch, p, (colnr_T)0)
+ || (regmatch.regprog != NULL
+ && vim_regexec(&regmatch, p, (colnr_T)0))
|| ((flags & EW_NOTWILD)
&& fnamencmp(path + (s - buf), p, e - s) == 0)))
{
@@ -9419,10 +9420,14 @@ unix_expandpath(gap, path, wildoff, flags, didstar)
else
regmatch.rm_ic = FALSE; /* Don't ignore case */
#endif
+ if (flags & (EW_NOERROR | EW_NOTWILD))
+ ++emsg_silent;
regmatch.regprog = vim_regcomp(pat, RE_MAGIC);
+ if (flags & (EW_NOERROR | EW_NOTWILD))
+ --emsg_silent;
vim_free(pat);
- if (regmatch.regprog == NULL)
+ if (regmatch.regprog == NULL && (flags & EW_NOTWILD) == 0)
{
vim_free(buf);
return 0;
@@ -9452,7 +9457,8 @@ unix_expandpath(gap, path, wildoff, flags, didstar)
if (dp == NULL)
break;
if ((dp->d_name[0] != '.' || starts_with_dot)
- && (vim_regexec(&regmatch, (char_u *)dp->d_name, (colnr_T)0)
+ && ((regmatch.regprog != NULL && vim_regexec(&regmatch,
+ (char_u *)dp->d_name, (colnr_T)0))
|| ((flags & EW_NOTWILD)
&& fnamencmp(path + (s - buf), dp->d_name, e - s) == 0)))
{
diff --git a/src/version.c b/src/version.c
index e3a79e294a..f5e79e5134 100644
--- a/src/version.c
+++ b/src/version.c
@@ -715,6 +715,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 399,
+/**/
398,
/**/
397,